what_does_it_mean_to_be_done
Differences
This shows you the differences between two versions of the page.
Next revision | Previous revision | ||
what_does_it_mean_to_be_done [2016/05/08 13:44] – created hpsamios | what_does_it_mean_to_be_done [2021/04/28 12:45] (current) – [Who is Responsible for the Definition of Done?] hans | ||
---|---|---|---|
Line 3: | Line 3: | ||
Or what is the " | Or what is the " | ||
- | ====== Premise ====== | + | One of the key ideas in Scrum and Agile is to focus delivering valuable work (or more basically, running, tested features.) There are two key tools in understanding when something is complete: |
- | One of the key ideas in Scrum and agile is to focus delivering valuable | + | * Acceptance Criteria (or Conditions |
+ | * Definition of Done (DoD): From an Scrum or Agile Team perspective, have we done everything we need to in order to say this is a good piece of work. Here we talk about testing, coding standards, documentation and so on that tells us that all the work is complete. In other words, the DoD describe the " | ||
- | * Conditions of Satisfaction: | + | ====== What is the Goal of the Definition of Done (DoD)? ====== |
- | * Definition of Done (DoD): From a Scrum Team perspective, | + | |
- | ====== Purpose ====== | + | The primary goal of the DoD is for every team to be able to say "we are potentially shippable at the end of every Iteration (Sprint)." |
- | The goal of the DoD is for every team to be able to say "we are potentially shippable at the end of every Sprint." | + | While this is important from a business perspective, |
- | The " | + | And finally, by leveraging the DoD we can establish a quality standard for the Team which helps ensure that we are not creating new Technical Debt as a result of the work we are doing, and also allows us to incrementally address the Technical Debt we already have in the code base. |
+ | |||
+ | In summary, the " | ||
* Understand what it means to be done from an internal perspective. | * Understand what it means to be done from an internal perspective. | ||
- | * Reduce the build-up of Technical Debt by making sure we don't cut corners in our work. This is because our detailed plan for the Sprint takes into consideration all the things that are part of the DoD. | + | |
+ | | ||
- | ====== Sources ====== | + | Because of this: |
- | Teams are responsible for maintaining their quality standard. They do this by: | + | > "A stronger ' |
+ | |||
+ | ====== How Does the Definition of Done Help Us Address Technical Debt? ====== | ||
+ | |||
+ | The DoD helps us deal with Technical Debt in two ways: | ||
+ | |||
+ | - We ensure the Team does not cut corners thus intentionally increasing their technical debt. | ||
+ | - We ensure the Team can do the small incremental work to regularly improve the quality of existing work. | ||
+ | |||
+ | Many people think that because you are doing all this work you are slowing delivery down. Reality is that re-work takes a lot more time than completing work correctly in the first place, but the work is often hidden and so it really just seems this way. Bottom line is that the Lean discussion has taught us that if you focus on quality you will increase how much you deliver over time. This is a classic example of: | ||
+ | |||
+ | > "Go slower to go faster" | ||
+ | |||
+ | By leveraging the DoD, Teams make sure they do not cut corners in on their work. The DoD establishes the quality standard for the Team. As professionals we know cutting corners slows down all future work and is not good practice. Often we will pretend to ourselves that we will come to back to it later. But the reality is that: | ||
+ | |||
+ | > "Later = Never" - LeBlanc' | ||
+ | |||
+ | By having a public Definition of Done we can help ensure that we are able to maintain our quality standard. The plan for the Iteration (Sprint) takes into consideration all the things that are part of the DoD and so we are able to complete quality work. It's up to us to ensure we don't add to the mess; we need to maintain our quality standards: | ||
+ | |||
+ | > "A mess is not Technical Debt; a mess is just a mess" - Uncle Bob Martin | ||
+ | |||
+ | We also know that left alone without care, existing code rots. Its kind of like entropy applied to code; if you don't apply effort to the code it will decay. The DoD can help here to. As part of the DoD we can think about an incremental approach to improving code. For example, perhaps our DoD includes the Boy Scout rule "Leave the code in better shape than when you found it." This allows you to do random acts of kindness to the code; if the naming of variables doesn' | ||
+ | |||
+ | There are a lot of ways to focus this incremental improvement. For example focus on improvement before you start working on a new capability: | ||
+ | |||
+ | > "Make the change easy; then make the easy change." | ||
+ | |||
+ | Or establish a working agreement whereby as you work an area of code and see something that needs fixing, you create a reference and estimate the changes needed. Then, the next time someone on the Team has to go into that code base, you ensure that the estimate that you provide to do the new work also includes the work required to fix the existing problems. | ||
+ | |||
+ | No matter what, do not underestimate the impact of incremental improvements - see [[how_do_small_changes_lead_to_big_improvements|How Do Small Changes Lead to Big Improvements? | ||
+ | |||
+ | ====== Who is Responsible for the Definition of Done? ====== | ||
+ | |||
+ | Agile Teams are responsible for maintaining their quality standard. They do this by: | ||
* Working to their DoD | * Working to their DoD | ||
* Working to make their DoD tighter and tighter as they become more effective at delivering software. | * Working to make their DoD tighter and tighter as they become more effective at delivering software. | ||
- | The Scrum Team's DoD will not be a purely | + | Having said that, the Team's DoD will not be a purely |
- Corporate: Corporate standards that need to be met | - Corporate: Corporate standards that need to be met | ||
- Portfolio: Portfolio standards that need to be met | - Portfolio: Portfolio standards that need to be met | ||
- | - Release: Criteria that must be met to consider a Release ready for production | + | - Program or Release: Criteria that must be met to consider a Release ready for production |
- User Story: Criteria that must be met to know that all the work is complete | - User Story: Criteria that must be met to know that all the work is complete | ||
- | - Scrum Team: Things the team learns it needs, especially at a technical level | + | - Agile Team: Things the team learns it needs, especially at a technical level |
- | Teams have a known, public DoD. Teams are explicit both in being visible about their DoD (available on the Scrum Team's page). They are also transparent about the practice they use to ensure their Definition of Done is addressed. It is up to the team to determine their approach. | + | Teams have a known, public DoD. Teams are explicit both in being visible about their DoD (for example, |
Example approaches we have seen include: | Example approaches we have seen include: | ||
- | * Teams create tasks associated with their definition of done so that when the sub-tasks are done, the story is done. | + | * Teams create tasks associated with their DoD so that when the sub-tasks are done, the story is done. |
* Teams maintain a spreadsheet and check-off the definition of done at the end of the Sprint. | * Teams maintain a spreadsheet and check-off the definition of done at the end of the Sprint. | ||
* Teams create a task that is the Definition of Done checklist that is updated as work proceeds on the story | * Teams create a task that is the Definition of Done checklist that is updated as work proceeds on the story | ||
- | ====== | + | ====== |
- | As said, the aim of this DoD is to ensure we are getting closer to " | + | As said, the aim of this DoD is to ensure we are getting closer to " |
- | might be required for other kinds of work: | + | |
- | * If your team does work that is not necessarily new feature or maintenance oriented. For example a documentation or QA team would have different considerations. (Note: this is not an ideal set up but still does happen - see [[what_should_we_consider_when_forming_a_new_team|What Should We Consider When Forming a New Team?]] for more discussion here. | + | * If your team does work that is not necessarily new feature or maintenance oriented. For example a documentation or QA team would have different considerations. (Note: this is not an ideal set up but still does happen - see [[:what_should_we_consider_when_forming_a_new_team|What Should We Consider When Forming a New Team]] for more discussion here.) |
* If your team identifies different types of work. For example, a research user story (spike) would have different DoD than development work. | * If your team identifies different types of work. For example, a research user story (spike) would have different DoD than development work. | ||
- | The key thing for the DoD is that all the stakeholders understand what it means when the team says it is done so communication is a required part of the on-going work associated with the DoD. | + | Most of the examples that you will see are DoDs related to software delivery. If you are doing other types of work - hardware, marketing, finance - then your DoD will be substantially different. |
- | ====== | + | ====== |
Here is an example DoD for a team, for new product and on-going maintenance development work: | Here is an example DoD for a team, for new product and on-going maintenance development work: | ||
* Code is complete: | * Code is complete: | ||
- | | + | |
- | * Code meets product coding standards | + | * Code meets product coding standards |
- | * Code has been run through static and/or dynamic analysis tools (e.g., Coverity) | + | * Code has been run through static and/or dynamic analysis tools (e.g., Coverity) |
- | * Code is checked into source control (with developer and peer reviewer names recorded) | + | * Code is checked into source control (with developer and peer reviewer names recorded) |
- | * Internationalization considerations have been met | + | * Internationalization considerations have been met |
- | * Internal and external documentation is updated with applicable support information included such as help files and public APIs | + | * Internal and external documentation is updated with applicable support information included such as help files and public APIs |
- | * Code is integrated with the main trunk (if not already done) | + | * Code is integrated with the main trunk (if not already done) |
- | * Code (or other deliverables) has been peer reviewed (e.g., pair programming counts as peer review) | + | * Code (or other deliverables) has been peer reviewed (e.g., pair programming counts as peer review) |
* Code meets quality standards | * Code meets quality standards | ||
- | | + | |
- | * Test plans have been run and passed and (hopefully) automated | + | * Test plans have been run and passed and (hopefully) automated |
- | * Test plans are in place for the ' | + | * Test plans are in place for the ' |
* No new defects | * No new defects | ||
* End-user documentation is complete | * End-user documentation is complete | ||
- | | + | |
- | * " | + | * " |
- | * Some organizations also add in " | + | * Some organizations also add in " |
* Item statuses in related tracking systems (Jira, Siebel, etc.) have been updated | * Item statuses in related tracking systems (Jira, Siebel, etc.) have been updated | ||
+ | * Code area is left in better shape than when we started the work on this user story | ||
+ | |||
+ | ====== Want to Know More? ====== | ||
+ | |||
+ | * [[: | ||
+ | * [[how_do_small_changes_lead_to_big_improvements|How Do Small Changes Lead to Big Improvements? | ||
Line 80: | Line 121: | ||
- | ~~LINKBACK~~ | ||
- | ~~DISCUSSION~~ |
/home/hpsamios/hanssamios.com/dokuwiki/data/attic/what_does_it_mean_to_be_done.1462740245.txt.gz · Last modified: 2020/06/02 14:30 (external edit)