Stories represent tactical increments of individually-valuable work deliverable by a squad within a single iteration... often an isolated change in functionality aimed at achieving a goal for a particular kind of stakeholder, whether customer, user, or operator/admin. Stories are tracked on the collections of the squad that has taken responsibility for them, or in an icebox or under a future Feature as warranted.
Stories progress through these columns (although there is some variation from squad to squad):
- Triage (where reported issues, and newly-identified stories appear)
- Backlog (when they are sequenced alongside other stories prioritized for attention)
- Icebox (where they go when they are not planned to get attention any time soon)
Note that Triage and Icebox lists are typically at the left in Favro. This is because those lists tend to get loooooong. By separating them from the board, it remains easy to scroll around when you have multiple boards in your collection.
- Grooming (when they're being refined for implementation)
- Ready (when they're in a shovel-worthy state, just waiting for team capacity to do the work)
- In Progress (when someone is actively working on the issue)
- Blocked/waiting (when there's a dependency on someone responding or something happening outside the team)
- Awaiting Acceptance (when work is considered complete and awaiting review/merging/feedback)
- Done (when work warrants demonstration to stakeholders and is awaiting the next sprint review)
- Done, but archived (when work has been demoed, released, announced, and is no longer worth looking at)
An agile "Definition of Done" (DoD) captures the team's agreed-upon standards for how we get work done at a consistent level of quality. Having a DoD ensures that non-functional requirements (NFRs) don't have to be re-litigated for every piece of work taken on, cards can be focused on just the relevant details, and new team members aren't surprised by assumed expectations of their colleagues.
At our sprint reviews, we demo work that has reached the "Done" column and is of interest to our users, teammates, or other people apart from the squad that built it. (As an example of finished work that may not be necessary to demo, fixing internal tech debt may not be of interest outside the squad that fixed it.)
For cloud.gov, our DoD is broken up into a set of statements that should be true for each card before it moves to the next column on the board.
Before advancing a card from one column to the next on the board, it should meet the "exit criteria" for the current column, which are listed below.
- Relevant points from any discussion in the comments is captured in the initial post.
- Decision is made to move to the Backlog or Icebox columns, or close.
- Indicate the intended benefit and who the story is for in one of these forms:
- Story: We prefer the "In order" form (rather than the common "As a/I want/so that" form).
- Hypothesis: What's the lean hypothesis being tested, and how it will be validated?
- Has testable/demoable Acceptance Criteria that we expect to be able to check off to help us understand when the work is done. (Try wording them as Gherkin, and use GFM checklists for them).
- Discussed by the team and implementation sketched (use more checklists here).
- We believe the benefit of the story is easily deliverable within in a few days of concentrated work (otherwise, split it into smaller stories!)
- Any authentication/authorization and data persistence points are discussed and requirements are addressed via Acceptance Criteria (e.g., "Authenticate using [login.fr.cloud.gov]" or "Any ephemeral data resulting from usage is backed up/recoverable").
- There's a communication plan for any user-visible changes which require their attention/action.
Required for compliance:
- If the story is not part of a larger feature which has already undergone Security Impact Analysis, we have applied that same Security Impact Analysis evaluation process for this story and filed any necessary SCR.
- No info or assistance is needed from outside the team to start work and likely finish it.
- There's capacity available to work on the story (e.g., this column is a buffer of shovel-ready work).
- Acceptance criteria are demonstrably met.
- Relevant tasks complete, irrelevant checklists removed or captured on a new story.
- Follows documented coding conventions.
- Pair-programmed or peer-reviewed (e.g., use pull-requests).
- Test coverage exists and overall coverage hasn't been reduced.
- User-facing and internal operation docs have been updated.
- Demoable to other people in their own time (e.g., staging environment, published branch).
- Any deployment is repeatable (e.g., at least documented to increase bus factor beyond one) and if possible automated via CI/CD.
- If the deployment is difficult to automate, then a story for making it automated is created at the top of
Triage
.
- If the deployment is difficult to automate, then a story for making it automated is created at the top of
- All UAA accounts are provisioned using the Cloud Foundry secrets or the cloud.gov service account or identity provider services.
Required for compliance:
- The deployment must follow our Configuration Management plan. If not possible, contact the Program Management team to modify the story or discuss how to update the Configuration Management plan.
- If the deployment includes 18F-developed code, ensure the repository is configured to run Code Climate static analysis on each PR.
- Code Climate scan results are reviewed, and any false positives are flagged / scanning rules are updated to exclude irrelevant files (vendored code, tests, etc).
- A team-local proxy for the people the story affects reviews and approves the work as meeting acceptance criteria.
- If the work is suitable to demo at our biweekly sprint review, add a description of it to the sprint review slide deck, ideally including a link to the live work or a screenshot (especially for visual work).
- If the work as completed is obviously unscalable and will cause problems if we try, then a story for making it scalable is created at the top of
Triage
.
Required for compliance:
- The work completed adheres to all of cloud.gov's policies and procedures.
- If the work changes an aspect of our system or operating environment that is (or should be) documented in our System Security Plan (SSP), note necessary changes in our pending SSP change document to note the change.
- The work is user-visible and announceable at any time.