Writing user stories
XC Staff
A user story is a short, simple description of a feature told from the perspective of the person who desires the new capability, usually a user or customer of the system.
When we write software, we want to keep the focus on our users. We want everyone to know the value of the work we do and why we are doing it. As such, we create user personas that represent the customers we'll serve. Each story is written from their perspectives.
Stories include every layer of a system, for example, UI, services, and data. This is called a vertical slice. We do this so that we can deliver value sooner, and shrink the feedback loop so that we can continuously improve.
No, user stories are not synonymous with requirements. A story starts as a placeholder for conversation. Its purpose is to to define how to help accomplish a user goal.
Stories have acceptance criteria which may include some requirements, but are typically focused on system behavior, not implementation details.
Anyone can! They are just a placeholder for a conversation, remember?
The Product Manager will typically do most of the heavy lifting, but there are no restrictions on which team members can contribute to stories.
Every user story starts with a description that explains what a user wants and their motivations. They typically follow this format:
As
I want
so that
Acceptance criteria define the scope of the story. All acceptance criteria must be met before the story is considered complete. They are typically written in Gherkin syntax when defining system behavior:
Given <state/precondition> -- This is a pre-requisite, what has already happened.
When -- Something that happens (a user interaction or a system event).
Then -- What is expected to happen as a result of the preceding action.
INVEST is a helpful mnemonic for writing good user stories:
As a product manager, I want users to be able to enroll in a Medicare plan so that I can boost conversion rates.
Given I am on the plan details page
When I click the "enroll now" button
Then take me to the enrollment confirmation page
This story is not focused on the end user, it is a statement of a business objective. The acceptance criteria is heavy on implementation details with references to pages and clicking and even button names. But it is missing the behavior -- enrolling the customer in a Medicare plan.
As Deb, I want to enroll in a Medicare plan so that my insurance needs are covered for next year.
Given I am viewing a plan's details
When I choose to enroll
Then enroll me in a plan
And display confirmation details
This story is focused on the customer persona. Acceptance criteria are clear and capture the system behavior without specifying how to implement.
[Pivotal Tracker](Pivotal Tracker)