No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
When you are dropped by parachute deep behind enemy lines with nothing but your analytical skills – where do you start? Ok, I probably should not compare the client and their business with hostile territory filled with enemies. Sorry! But still! Where do you start if you know nothing? | When you are dropped by parachute, deep behind enemy lines with nothing but your analytical skills – where do you start? Ok, I probably should not compare the client and their business with hostile territory filled with enemies. Sorry! But still! Where do you start if you know nothing? | ||
You say “Hi!” to everyone, exercise your complete toolbox of people skills, follow everyone to lunch, buy the informal leaders beer etc… But that is not enough is it? | You say “Hi!” to everyone, exercise your complete toolbox of people skills, follow everyone to lunch, buy the informal leaders beer, etc… But that is not enough, is it? | ||
Being a developer | Being a developer who uses ECO and the strategies proposed by DDD, I will know what to do once I know what “the whole thing is about”. However, the client is not well equipped to tell me what I need to know spontaneously, so I need some strategy to extract that information from them. | ||
This post is about that strategy. | This post is about that strategy. I know there must be like a million ideas on how this is done. This is the way we do it: | ||
# Gather a representative group of people from the domain | # Gather a representative group of people from the domain. | ||
# Set up a workshop and let them brainstorm on who is showing any interest at all in what they do. More specifically ask them: who calls you on the phone, who emails you, who comes to visit, who delivers stuff, who sends you stuff, who buys your stuff, etc. All these questions are reversible: Who do you call, Who do you email etc | # Set up a workshop and let them brainstorm on who is showing any interest at all in what they do. More specifically ask them: who calls you on the phone, who emails you, who comes to visit, who delivers stuff, who sends you stuff, who buys your stuff, etc. All these questions are reversible: Who do you call, Who do you email, etc? Collect this information and keep it as the '''Triggers'''. | ||
# For each unique persona from step 2 find out what the goal of this persona is; why does X email you | # For each unique persona from step 2, find out what the goal of this persona is; why does X email you and what is their goal? Why do you email that person, what is your goal? Collect this information and keep it as the '''Goals'''. | ||
# Split your group into smaller groups and let them break down each | # Split your group into smaller groups and let them break down each no-nonsense combination of trigger and goal into some steps that are central to getting to the goal. Make them aim for 5 steps. If they have a hard time getting started, encourage them to bring up just 1 step. Example: “Trigger is Customer, Goal is Getting a loaf of bread”. One obvious step is “handing the bread to the customer”. Great! Now force your group to explain what they do before - and what they do after that step. “Need to fetch the bread from the shelf” is before, and “Receive payment” is after. This is going great! Continue like this, and throw away the silly steps and keep the important steps. What they create here are overviews of what their business is about. Keep this information as '''Processes'''. | ||
After you | After you have gone through these steps, you will have a pretty good idea of what you are up against. You will have a set of high-level processes. Document these in AppComplete or ECO: | ||
[[File:Where to begin - 1.png|frameless|352x352px]] | [[File:Where to begin - 1.png|frameless|352x352px]] | ||
Line 16: | Line 16: | ||
[[File:Where to begin - 2.png|frameless|425x425px]] | [[File:Where to begin - 2.png|frameless|425x425px]] | ||
Some processes that you have already found might be detailing processes for | Some processes that you have already found might be detailing processes for another process. Also, some steps in a found process might need detailing in further steps; you should callback your domain group to help you out with that. | ||
By arranging the processes as “detailing” a step, you build up a structure in the Modlr tree: | By arranging the processes as “detailing” a step, you build up a structure in the Modlr tree: | ||
Line 22: | Line 22: | ||
[[File:Where to begin - 3.png|frameless|342x342px]] | [[File:Where to begin - 3.png|frameless|342x342px]] | ||
Do you really need to involve real domain people? Will it not suffice | Do you really need to involve real domain people? Will it not suffice to read some existing documentation and talk to some IT guys in the company? '''No.''' It will not suffice for 2 major reasons: | ||
# You do not know what the real issue is – it might be that the current documentation and or the current IT | # You do not know what the real issue is – it might be that the current documentation and/or the current IT crew is wrong. | ||
# You | # You need to get real people involved so that they feel and know that you are on their side. After all, you will be a central player when it comes to change in these people's working environment. You need to earn trust, you need to communicate, and you need to involve them. If you do not, you will have a difficult time trying to get real people to understand the greatness of your work once you are done. And then it is all for nothing. | ||
When you have | When you have reached this far, start on the information model. Create 1 class diagram per process and associate the two: | ||
[[File:Where to begin - 5.png|frameless]] | [[File:Where to begin - 5.png|frameless]] | ||
As you focus on a specific process when creating this class diagram you get a small and readable result: | As you focus on a specific process when creating this class diagram, you get a small and readable result: | ||
[[File:Where to begin - 6.png|frameless|422x422px]] | [[File:Where to begin - 6.png|frameless|422x422px]] | ||
The Process diagrams indicate that they are associated | The Process diagrams indicate that they are associated with class diagrams, and you can click the icon to jump straight to the class diagram: | ||
[[File:Where to begin - 7.png|frameless|436x436px]] | [[File:Where to begin - 7.png|frameless|436x436px]] | ||
Furthermore, the Process tree gives you a good structure of diagrams: | |||
[[File:Where to begin - 8.png|frameless|293x293px]] | [[File:Where to begin - 8.png|frameless|293x293px]] | ||
Now you have the big picture | Now, you have the big picture of “What it is that happens” from the processes and you get the “What information” view from the class diagrams. All you need now is the detailed business rules that control this process. Being totally into declarative development, I only consider a short while to actually start to write c# code to catch these. The state diagrams are better because the documentation becomes clearer and maintenance will be cheaper in that form (from our point of view). You can associate these with processes as well: | ||
[[File:Where to begin - 9.png|frameless|337x337px]] | [[File:Where to begin - 9.png|frameless|337x337px]] | ||
Once you have reached this far you may want to take it yet another step: Declare a | Once you have reached this far, you may want to take it yet another step: Declare a ViewModel per process… But I will save ViewModels for another post. | ||
=== Summing | === Summing It Up === | ||
The process tree will give you | The process tree will give you some navigation of diagrams and artifacts. The processes will make it easier for an outsider to understand the domain. If you are a group of people - where some do client communication with process modeling and some take it further with development - you can now share one tool to keep your development efforts collected. | ||
Whether you choose to do everything in your development declaratively as we do, or as only part of your work declaratively and the rest by traditional coding, is entirely up to you. | |||
[[Category:Learning MDriven]] | [[Category:Learning MDriven]] |
Revision as of 06:40, 29 March 2023
When you are dropped by parachute, deep behind enemy lines with nothing but your analytical skills – where do you start? Ok, I probably should not compare the client and their business with hostile territory filled with enemies. Sorry! But still! Where do you start if you know nothing?
You say “Hi!” to everyone, exercise your complete toolbox of people skills, follow everyone to lunch, buy the informal leaders beer, etc… But that is not enough, is it?
Being a developer who uses ECO and the strategies proposed by DDD, I will know what to do once I know what “the whole thing is about”. However, the client is not well equipped to tell me what I need to know spontaneously, so I need some strategy to extract that information from them.
This post is about that strategy. I know there must be like a million ideas on how this is done. This is the way we do it:
- Gather a representative group of people from the domain.
- Set up a workshop and let them brainstorm on who is showing any interest at all in what they do. More specifically ask them: who calls you on the phone, who emails you, who comes to visit, who delivers stuff, who sends you stuff, who buys your stuff, etc. All these questions are reversible: Who do you call, Who do you email, etc? Collect this information and keep it as the Triggers.
- For each unique persona from step 2, find out what the goal of this persona is; why does X email you and what is their goal? Why do you email that person, what is your goal? Collect this information and keep it as the Goals.
- Split your group into smaller groups and let them break down each no-nonsense combination of trigger and goal into some steps that are central to getting to the goal. Make them aim for 5 steps. If they have a hard time getting started, encourage them to bring up just 1 step. Example: “Trigger is Customer, Goal is Getting a loaf of bread”. One obvious step is “handing the bread to the customer”. Great! Now force your group to explain what they do before - and what they do after that step. “Need to fetch the bread from the shelf” is before, and “Receive payment” is after. This is going great! Continue like this, and throw away the silly steps and keep the important steps. What they create here are overviews of what their business is about. Keep this information as Processes.
After you have gone through these steps, you will have a pretty good idea of what you are up against. You will have a set of high-level processes. Document these in AppComplete or ECO:
Some processes that you have already found might be detailing processes for another process. Also, some steps in a found process might need detailing in further steps; you should callback your domain group to help you out with that.
By arranging the processes as “detailing” a step, you build up a structure in the Modlr tree:
Do you really need to involve real domain people? Will it not suffice to read some existing documentation and talk to some IT guys in the company? No. It will not suffice for 2 major reasons:
- You do not know what the real issue is – it might be that the current documentation and/or the current IT crew is wrong.
- You need to get real people involved so that they feel and know that you are on their side. After all, you will be a central player when it comes to change in these people's working environment. You need to earn trust, you need to communicate, and you need to involve them. If you do not, you will have a difficult time trying to get real people to understand the greatness of your work once you are done. And then it is all for nothing.
When you have reached this far, start on the information model. Create 1 class diagram per process and associate the two:
As you focus on a specific process when creating this class diagram, you get a small and readable result:
The Process diagrams indicate that they are associated with class diagrams, and you can click the icon to jump straight to the class diagram:
Furthermore, the Process tree gives you a good structure of diagrams:
Now, you have the big picture of “What it is that happens” from the processes and you get the “What information” view from the class diagrams. All you need now is the detailed business rules that control this process. Being totally into declarative development, I only consider a short while to actually start to write c# code to catch these. The state diagrams are better because the documentation becomes clearer and maintenance will be cheaper in that form (from our point of view). You can associate these with processes as well:
Once you have reached this far, you may want to take it yet another step: Declare a ViewModel per process… But I will save ViewModels for another post.
Summing It Up
The process tree will give you some navigation of diagrams and artifacts. The processes will make it easier for an outsider to understand the domain. If you are a group of people - where some do client communication with process modeling and some take it further with development - you can now share one tool to keep your development efforts collected.
Whether you choose to do everything in your development declaratively as we do, or as only part of your work declaratively and the rest by traditional coding, is entirely up to you.