Tuesday, 23 October 2007

Contracts for Agile Outsourcing

The question of how to frame contracts and customer/supplier relationships for an agile project is a tough one. To use some patterns terminology, the fundamental 'forces' are:-

  1. The customer wants to be sure that they will get value for money

  2. The supplier wants to know what they need to do to get paid

  3. Agile tells us that we cant specify systems well, so we need to 'embrace change' and minimise the cost of making changes mid-course.

Force 3 is not a big issue for the customer, but will make suppliers used to 'Big Design Up Front' (BDUF) pretty uncomfortable since it is making the commitment rather open-ended and conflicting with force 2.

One possible way to resolve the forces is with a time and materials (T&M) contract. This resolves forces 2 & 3 from the supplier's perspective nicely, but at a first glance, is not a good answer for force 1. In practice, it is not so bad as it seems, - if iteration cycles are kept short and real value is delivered during each iteration then the customer is protected by a rapid feedback mechanism to ensure that things are on a productive track (even if it is not the same track which was envisioned at the start!).

Life isnt always like that though and sometimes customer purchasing policy may insist on fixed price contracts. So what do we do then?

One variation on the fixed price contract is the fixed effort contract in which the supplier commits to providing a specified number of man days to the project. This may be thought of as T&M in fixed price clothing, so its resolution of the forces is similar to those of T&M, with the additional benefit of keeping the purchasing department happy.

Then there are customers who insist on fixed price AND fixed scope. This is a tricky situation to reconcile with agile, because 'fixed scope' sounds a lot like BDUF, which is exactly what Agile tells us we don't know how to do well. On the face of it then, the customer's expectations of Agile and fixed scope are contradictory, so how does a supplier cope? Well, there are several possibilities:-

  • Accept the business and the risk of unscoped changes. This may be acceptable where the customer and supplier have a track record with each other and are comfortable that the risk can be assessed.

  • Say 'no thanks' and walk away. This doesnt happen very often in my experience. Maybe it should!

  • Adopt a two-tiered approach to requirements and agility in which 'broad brush' high level requirements (epic user stories?) are used to fix scope but at a detailed user story level, agile practices are followed.

  • Allocating a fixed size change budget which the customer can spend during the period of the project, although this does require impact assessment or detailed tracking of activity for each change, both of which may be counter to the spirit of 'embrace change'

And finally, when you really know your stuff, there are customers who want a fixed price and business benefit-related payments. This needs the supplier to at least be able to size the work up front without any commitent to a scope (correct or not) from the customer. The commitment here from the supplier's side is so open-ended that the he must be really sure that he knows both the business and the customer. My feeling on this is that Agile is actually very well suited to such a scenario - in this case the rapid feedback mechanism which I described earlier will help the supplier to pick up problems early, although his options for resolving them without affecting the bottom line may be limited. Clearly it is better if the benefit measurement can be broken down into the same short iterations that the delivery is broken into, so that tracking is clear and course corrections can be done quickly. Tom and Kai Gilb's article on Incremental value delivery and measurement includes some very relevant advice for suppliers and customers who are using value-based payments.

Wednesday, 8 August 2007

Big Boxes

I like to work in an Agile project environment. Recently I have found myself in the happy position of being able to work for a client who is really buying into the whole Agile movement. The client is a very big telco, so its systems need to be... well... very big too.

This presents a few problems. One which is on my mind right now is how to size and budget for buying suitable hardware to host our new system. At the moment, we have tackled some of the lower volume products but in later cycles we will be doing some really big stuff against some really imperative deadlines.

We dont yet have detailed requirements for the big stuff (it's Agile, remember?), but we need to put a box in place which is going to have to cope with them. How to do it? Here are a couple of options...
  • Rely on commodity boxes and horizontal scalability. That way, we can roll out incrementally and we dont need to know up front how many boxes we will eventually need. This works well for the app server tier, but is of less help for the database tier.

  • Get the best picture we can of upcoming volumetric requirements (I dont think we can bet on 'You Arent Going To Need It') and pick a hardware range with enough memory, processor etc expansion capacity to support the eventual need.
To further complicate matters, we need to budget for floor space in the data centre - if we get it wrong, we may find that our boxes are hundreds of miles apart, which isnt going to do much for latency.

Challenges to Agile Development

It must be at least 12 years now since I attended the excellent two day course entitled 'Object Oriented Project Management'. Frankly it wasn't much about Object Oriented development and would perhaps have been better entitled 'Enlightened Project Management'. It introduced me to concepts like Boehm's spiral lifecycle, Tom Gilb's evolutionary delivery ideas and books of wisdom like 'The Mythical Man Month'. I had zero project management training prior to this but the wisdom on this course rather ruined me as an audience for the purveyors of more traditional project management techniques who have crossed my path since then.

As a result of this and my experience since then, I have become an advocate of agile development approaches (although it wasnt called 'agile' 12 years ago!). I have also encountered a lot of situations which pose challenges for agile practices. The main ones are:-

  • Management of non-functional requirements - agile user stories tend to focus on obvious functional value. The fit of agile techniques to cross-cutting (but critical) concerns like security, performance or availability is less clear. Some have proposed non-functional user stories, but at the moment I think the jury is out.

  • Outsourcing - having a customer/supplier relationship introduces barriers in communication, potentially conflicting motivation and reward systems and, in its usual form requires some form of big specification up front saying what is being paid for. All of these are driving us in the oppposite direction from the Agile Manifesto.

  • Offshoring - an extension of outsourcing which introduces the additional challenges of physical distance, poor communications infrastructure, timezones, language and cultural differences - all of which conspire to hinder the free flow of communication which is the life blood of an agile project.

I dont claim to have all the answers to these issues. Some would say that a 'high ceremony' methodology is the only answer, but I'm not so sure. I do find myself facinng them on a regular basis, so at least I have some material for future posts!