Agile software development is still a bit obscure to me. As I have been hearing a lot about it recently, primarily through company presentations at the Meet & Greet in preparation of Summer of Tech, I went to a presentation today to find out more about “agile”.
The Agile Professionals Network organized the presentation “Agile Undercover: When Customers Don’t Collaborate” given by Rashina Hoda. Her presentation, as already suggested by the title, focused on the customer and what an agile team can do if the customer is not fully on board.
She has identified 6 types of customers in agile projects in her research in India and New Zealand that she placed on a continuum:
- Product owner: That’s the perfect customer, a rare breed (in any project). 🙂
- Story owner: The project is split up into multiple stories (in non-agile words: parts) and each one has a person responsible from the customer side. That means that the responsibilities don’t have to be centered in one person who may not always have time, but different people from the customer side are involved at different times.
This ensures that a customer representative is there at all times. However, I see the danger in not being able to tie everything together. This type of customer requires that the individual story owners talk to each other and keep each other informed so that decisions are made along the same lines.
- Just demos: Sometimes agile development projects can be happy if the customer shows up for the demos (no other interaction willingly or out of necessity). They then try to sneak in a discussion at the end to go over the development and receive feedback on it as well as some pointers for further development.
- E-collaboration: Sometimes it’s not possible to meet face-to-face. That’s when e-collaboration comes in handy so that the developers and the customer can still see each other and discuss work. Video-conferencing where possible, but also text chat help greatly to stay in touch and involved.
I would have placed e-collaboration before just demos because I sense a greater involvement than in the just demos part, but of course, that always depends on the project.
- Customer proxy: If a customer can’t be present, somebody else from the development team or closely related can act as stand-in to lead discussions and then communicate the results back to the customer, receive their opinion and feed that back to the team.
- Extreme undercover: That is the worst-case scenario. This can happen when the development team decides to use agile methods, but the customer is not aware of that and thus is not involved in the process. That is often the case if the customer as too scared of using agile or opposes it.
These types of customer are not new because I can also see them in “regular” projects. However, Rashina pointed out that customer involvement is particularly crucial for the success in agile projects, and a team has to find ways of compensating for not-ideal customers.
As I just got a brief glimpse into agile software development / agile methods, it would be great to actually see such a project work and compare it to my project work experience.
This presentation was based on “Agile Undercover: When Customers Don’t Collaborate” by Rashina Hoda, James Noble, and Stuart Marshall which they presented at XP 2010 in Trondheim, Norway, in June 2010.
This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.