Anatomy of an agile development project

Making the transition to agile development requires discipline

Making the move from waterfall to agile can be a difficult transition. Although agile allows flexibility in terms of adjusting priorities and specifications, the general consensus among those adopting the approach is that the discipline required is far greater than with more traditional approaches.

"One of the common misconceptions about agile is that there is no discipline involved," says Susan Scott, director of the project management office at gambling web site Betfair.

"I would argue the opposite. The discipline associated with agile is far greater than a waterfall model. You have to have discipline within the team to follow all of the methods and make it work," she adds.

Other companies have learned the hard way. Debbie Ashton, vice president of products at cloud applications provider FinancialForce.com, partner site to SalesForce.com, agrees, and suggests that training is essential if firms want to take the plunge and switch development methods.

"People assume you can jump straight into it and everything will work - I did exactly that. We had a couple of textbooks and thought we were experts. Suffice to say, we did not succeed and we found ourselves slowly moving back to waterfall," explains Ashton.

"So when we tried it again, we made sure every single person on the project went on a training course. We got experts in to monitor progress and we make sure employees receive regular additional training throughout the year."

But how does agile work in practice? There are several aspects to the approach.

Scrums, stories and sprints

"Scrum" is the most widely used agile methodology, and provides a project management overview of how development work should be carried out. With scrum, a project backlog is created at the beginning of each project. This comprises "stories", which essentially describe tasks that need completing throughout the length of the project. This project backlog can be compared with the specifications and requirements defined in waterfall, except that they can be changed and reprioritised throughout the project.

The project is then carried out in "sprints", where the team works on a selection of stories for anywhere between two to six weeks. The stories are chosen at a planning meeting at the beginning of each sprint. Once stories are selected for a sprint, they are fixed for the duration of the sprint, and change is not encouraged at this point.

Throughout each sprint the team will have a daily scrum, or meeting, which will last about 15 minutes. Observers and other members of the team may attend and listen at each scrum, but it is strictly developers that should talk about what they have done, what problems they had, and what they are going to do next.

Each sprint is carried out with the purpose of delivering a workable piece of software that is testable and demonstrable. Although each release does not have to be a commercial product, the feature that is delivered should be as complete as possible.

There are other techniques that can form part of the agile development process. These include test-driven development and pair programming. With test-driven development, developers write a test before they write the code. This method aims to help developers think about what the essential requirements are before spending time writing the code.

Pair programming is based on the assumption that two heads are better than one. Two developers work together throughout a sprint, they share a keyboard and take turns writing code, every 10 to 15 minutes. While one developer is typing, the other observes what is being written on screen.

The idea is to encourage a continuous dialogue. If two programmers agree that what is being coded is going in the right direction, the outcome is likely to be more consistent at the end of each sprint.