Here is the exercise I'll be covering in this Blog. Making a cup of Tea:
- Fetch the kettle
- Open the lid on the kettle
- Turn on the cold tap
- Fill up the kettle to the max line
- Turn off the cold tap
- Put the lid back on the kettle
- Put the kettle back on it's base
- Plug the kettle in to the electrical socket
- Turn the kettle on at the electrical socket
- Switch the kettle on
- Open the cupboard door
- Get a mug
- Put the mug on the worktop
- Go back to the cupboard and get a tea bag
- Put the tea bag in the mug
- Wait for the kettle to finish boiling
- Pick up the kettle
- Pour water into the mug to the desired level
- Leave for 3 minutes
- Go to the drawer and get a spoon
- Stir the tea and remove the teabag
- Open the bin
- Put the used teabag in the bin
- Close the bin
- Put the spoon down next to the mug
- Go to the fridge and open it
- Get the milk out
- Open the milk
- Add some milk to the mug with tea in it
- Close the milk
- Put the milk back in the fridge
- Close the fridge
- Pick up the spoon from next to the mug
- Use the spoon to stir the tea
- Drink
Now this is quitovee straightforward, any first year university student could have a reasonable stab at this with a high success rate but let's take it a step further. Let's say that you were meeting a customer for a discovery workshop and they passed you a requirement to make a cup of tea. You decompose it down into a series of managable tasks and race to the implementing of it but I've made a common and fatal mistake in the process list above. It's blindling obvious but has caused no end of problems in projects since the dawn of IT. I've potentially made some fatal assumptions: Do we have a kettle? Do we have Teabags? Does the customer want their tea without Sugar? The list goes on and on...
The point of this is that don't be in a rush to implement, think about the requirements,
- List all your assumptions, get them verified by the customer.
- Think about your happy path and get this in place first
- Think about all your exception flows and hang them off the happy path flow
- Thnk about how you are going to test it?
- What are the pre-conditions?
- What are the post-conditions?
This may be a very simplistic way of demostrating my point but it's a simple thing that if done incorrectly can have serious consequences? We could potentially have gotten to step 27 before we realised that we hadn't actually got any milk!
Finally, I suppose I should give the answer to my previous blog, this is quite simple once you start to dry run the principles in your head and you have ever got a divide by zero exception :). The answer is simply that the equations don't work as if X == Y then X-Y will always equal 0... Therefore, to divide by X - Y is to divide by 0 which cannot be done
Great Post Chris, and lets face it, if you make mistakes during the requirements stage, you run the risk of ending up with a Chocolate Tea Pot at the end of the project !
ReplyDelete