Comprehensive documentation
A couple of months ago we where about to be finished with a project we've been working on for a customer. We had a meeting with the customer to discuss a couple of things. The customer then asked if we could deliver a system documentation. Instinctively, agile as we are ("Working software over comprehensive documentation"), we responded "Who is the receiver of this documentation? What is the purpose of the documentation? Remember that documentation tends to be quickly outdated." We also emphasized that we gladly produced the asked for documentation, but first we need that information to know what kind of documentation to produce. We haven't heard anything about the documentation since then...Comprehensive estimation
I wonder: Isn't it the same thing with estimates? ”Working software over comprehensive estimations” - there is more value in developers writing code than developers doing estimates.Shouldn't we, agile as we are, instinctively ask the same questions when asked for estimates? "Who is the receiver of this estimate? What is the purpose of the estimate? What do we do if our estimate turns out to be incorrect? Remember that estimates tends to be quickly outdated."
Those questions should come as natural and instinctively as we responded about the documentation.
"How much will it cost?"
Note that this has nothing to do with the customer wanting to know what something will cost. You always want to know - roughly - what something will cost you. Who wouldn't? And we should give our customers a rough sence of what it will cost. Is it $1.000 or $100.000. You want to know. If it is $100.000 or $120.000, is (almost) irrelevant. I think that a customer asking "How long will this take?" actually is asking, in a more discreet way, "How much will it cost?" Because we almost always charge our customers by the hour, they can then do the math by themselves of how much, approximately, it will cost them.Time and cost are not (should not be?) the same thing
Personally, I would rather work on something knowing that I have "unlimited" amount of time with a given cost than to know that I have a limited amount of time with an unlimited cost. There is a psychological effect when working against time, a self fulfilling prophecy. If I start working on an item, knowing that someone (or meself) has said that it will take approximately 10 hours, I will focus on doing it in 10 hours. If I have worked 8 hours then I know it's only 2 hours left, let's skip some testing, let's skip some refactoring to be finished in 2 hours. I.e. I drop quality and creativity to prioritize the estimate. What value does that bring my customer?But what if I am done in 6 hours? My customer will probably only be happy about it. But what value did it bring that I (or someone else) said 10 hours?
Estimates are promises
Estimates becomes promises. That's the problem. Stop promise result. Promise your own behaviour instead. Read more about it here: Promises, promises (in swedish though). If I instead say: "I think this will take between a day or two but I'm not sure, but I will let you know when I start working on it, and I will call you when I've worked on it for 4 (or anything) hours and tell/show you how I'm progressing, is that ok?" You haven't promised a result, you have promised to get back, and let the customer decide if we should continue the work or not, based on how we're actually progressing - real value. And you have promised to start working on it instead of trying to give a more detailed estimate.Give them a rough feeling. Give them value - quickly
As I said, today we charge our customer by the hour. We almost never give them a fixed price (very agile! :-). If it takes 14 hours instead of 10 we charge them 14 hours. But this also means that the one taking "the blow" if our estimate is incorrect is: our customer. Is that fair? Well, I think it is. They paid what it actually costed to get it done. Nothing more, nothing less. The problem is that we gave them an estimate, a promise, an expactation, that turned out to be wrong. Stop giving them false expectations. Stop promise result. Give them a rough feeling, but only promise to get back to tell them if that rough feeling turned out to be correct or not. Ask if you can get 4 hours to start working on it and return with result and then discuss if we should continue or not.The same thing if working on larger projects. Make sure to produce small slices. Ask "Can we start building this little thing to know more about how hard it seems to solve? Give us X hours and we will show you how we're progressing, and then we - together - can decide if we should continue or not".
The customer always want to know what it will cost, and we should give them that rough feeling. But don't spend hours and hours estimating. That rough feeling is almost instant. Dan North calls it Blink Estimation. Start working on it instead. Start giving customer a valuable product as soon as possible. Dicuss how we can deliver something to deploy live in 4 weeks from now: "What should we build/do if we deploy live in 4 weeks? How will it look like, what will it be?"
No comments:
Post a Comment