In November I am going to give a series of presentations about Scrum and how it is applied in real projects. If you are interested, please register at BPM-SOA-Center.
Category: Agile
Definition of Done – Never without
One of the keys to success in agile projects is a proper Definition of Done (DoD). Only if everybody knows what has to be produced in order to complete a sprint, the goal can be achieved.
The ideal outcome of a sprint is a product increment that is potentially shippable. To achieve that, all necessary actions to create a high quality product, such as writing documentation and thorough testing, have to be carried out within a sprint.
In order to be really sure whether a an artifact is done, acceptance criteria are needed. Otherwise “done” would not be measurable. The criteria depends on the produced artifact.
Software-Artifacts
Software products usually comprise the following:
Acceptance criteria
In order to prove that the above artifacts are really done, they need to be tested. Because the amount of test grows for each sprint, there is no way around automated regression testing. Therefore a continuous build,test and integration system, such as Team Foundation Server or Hudson, is essential for agile projects. The following tasks should be automated (in the brackets you can see an example of acceptance criteria for each task).
- Unit testing (error ratio maximum=10%, code coverage minimum=60%)
- Load + Performance testing (concurrent users=20)
- User acceptance testing, UI tests (error ratio maximum = 15%)
- Integration (successful installation and availability)
- Code quality checks (warnings maximum = 20)
Some tests, such as UI tests, might be difficult to automate. But if you do it, you team will be rewarded with a highly accepted software product at the end of each sprint. As you can see the acceptance criteria is not 0% errors or 100% coverage, because this would not be realistic.
Concept-Artifacts
Some projects develop their concepts using Scrum as well. Something that I would encourage to do. Although in Scrum the amount of written documents is greatly reduced, concepts are often helpful and required. For instance to refine coarse grained user stories from the product backlog or if the implementation of an idea can not be realised immediately. Concepts can be written in many ways as long as they clearly describe the idea down to a level that is sufficient for the implementation. For instance text documents, wiki pages, prototypes or design sketches.
Acceptance criteria
How can a concept be defined as done in terms of a DoD? As always! Conduct a review with people from within the team or other stakeholders from within the organization. When a concept is successfully reviewed, it is done.
Summary
Having a proper Definition of Done which clearly lists the required artifacts and acceptance critera is essential for successful Scrum projects. It creates a common understanding of what “done” actually means and is a key artifact to deliver high quality software in agile projects.
Scrum Agile Workshop
Today we released our new workshop agile software development using Scrum.
The workshop covers not only the basic principles of agile development and Scrum but also advanced topics which are based on real project experience.
It is full of best practices and is conducted in German or English by certified Scrum professionals.
Certified Scrum Professional
After applying Scrum in several projects I am convinced that it is a very successful approach to develop software. So it was about time to strive for the next Scrum certification level.
Now I am a Certified Scrum Professional. Great!
BPM, Optimization and Scrum
One of the goals of Business Process Management (BPM) is the continuous optimization of business processes.
In fact when we start analyzing existing processes, in most cases it turns out that those processes are far from being ideal.
Usually the first impulse is to say, all right let’s improve the processes while we automate them.
At first sight this seems to be reasonable, but practice shows that it is not.
Why not?
Usually the process knowledge is in the heads of the business users who live the processes every day.
Even if they have some sort of documentation, they feel that they own the process. And they do!
Once you start changing the existing processes you take the ownership and leave the real owners behind.
This can quickly turn into a acceptance problem cause the business users are a vital part of BPM as they have the process knowledge.
Practice shows that it is better to automate processes as is first and keep the business users involved.
Start small (and think big) for instance with partial processes. Then show the benefits and start the optimization loop.
This can be ideally done in an agile setting such as Scrum in which the idea of continuous improvement (Kaizen) is built-in.
A nice side-effect is that not only the business process is improved over time, but also the analysis and implementation process itself.
Scrum Poster
When introducing Scrum in a project it is essential for the team to get used to the terms quickly.
The Scrum Poster gives a nice overview which might help in this regard.
Certified Scrum Master
Scrum techniques are more and more used in todays IT projects.
After applying those techniques in several projects I decided to go for a more formal certification.
I got the certification yesterday and now I am a Certified Scrum Master.