Pitfalls when creating user stories
In the chapter about user stories and writing user stories I have provided you with the silver bullet for great user stories. Everyone, however has heart the war stories around user stories and why they do not work. During my agile coaching and workshops I have come across quite a few of them. As a result I have found that, when making user stories there are certain pitfalls to avoid. In this piece I will explain some of these pitfalls and how to avoid them.
Some product owners and teams are so fond of user stories that everything is expressed as a user story. This results in some rather odd stories. For example user stories that try to capture the user interface design, complex user interactions, and technical requirements. It might also be that due to everything being packed in a user story these aspects are simply overlooked. These product Owners suffer from Story Mania.
Like any technique, user story writing has its strengths and limitations. I find user stories particularly well suited to capture product functionality, and when applied properly, non-functional requirements. But user interface design and complex user interactions are better described by other techniques including design sketches, mock-ups, scenarios, and storyboards. Complement your user stories therefore with other techniques, and don’t feel obliged to only use stories.
Another pitfall, which I have encountered several times is the so called “User Incognito” This occurs when A user story tells a story about a user interacting with the product. Some stories, however, omit the beneficiary altogether, or they talk about a mysterious user as in “As the user, I want to …” But if it’s not clear who the user is, why should the story be developed? When we don’t know the user, how can we be sure that the story will benefit someone?
Make sure that all your stories have a clear user or user attached to it. As I like to work with personas, I use personas in my stories (instead of user roles). This connects each story to the right persona, and it allows me to understand if and to which extend the story addresses the persona’s need or goal. To achieve this, I use the following template: As <persona>, I want <something> so that (Because) <benefit>.
In relation to user stories, the devil is in the details: Some user stories are too big and vague for the team to understand and implement. Others contain too much detail, or even prescribe a solution. Getting the details right seems to be a battle the product owner can only loose.
My recommendation is: Start with big, overarching user stories called epics particularly for all new features. Epics allow you to capture an idea without committing to the details. Then break an epic into more detailed user stories. The new user stories replace the epic, and they provide more information about the product’s functionality. Pay particular attention to the user stories that are pulled into a sprint. These stories have to be ready: clear, feasible, and testable.
Keep constantly refining your stories keeps your Product Canvas or backlog concise, it makes it easier to integrate new insights, and it reduces the effort required to stock your initial canvas or backlog. This is particularly valuable for new products and new features. Make sure you do not prescribe a solution in your stories. Rather focus on the “what”, than the “how”. The “how” is best captured in an architecture diagram.
Some product owners diligently write user stories, and give them to the development team in the sprint planning meeting. This hand-off is usually sub-optimal, as it wastes the team’s ideas and knowledge. Stories can hence be inappropriate, difficult to understand, unfeasible and not testable.
User stories, however, are not meant to be standalone documents. They should be complemented by a conversation between the product owner and the team, or even better: written collaboratively. A user story wants to capture the essentials, and not specify every detail: The latter would be difficult for new features and too slow and too expensive in an agile / lean context.
User story writing should be a team effort, where product owner and development team create the stories together. Allocate time for a collaborative Product brainstorming workshop or backlog grooming meeting, particularly when you develop a new product or new features. Trust me: Better stories and a better product will be your reward.
Last but not least, acceptance criteria are maybe the most misunderstood part of user’s stories. I have seen detailed stories with no acceptance criteria, criteria that restate the narrative, and criteria that hide new stories, or even contain entire workflows.
The idea behind acceptance criteria is simple: They allow you to describe the conditions that have to be fulfilled so that the story is done, that it can be exposed to the users and the other stakeholders. This ensures that you gather feedback and/or release features, and it helps the team plan and track their work: The criteria enrich the story and make it more precise and testable. (The criteria all stories have to fulfil such as “online help is available” are not stated in the acceptance criteria but in the Definition of Done.)
As a rule of thumb, I like to work with three to five criteria per story, and I am not worried if my epics don’t have acceptance criteria to start with. Ready stories, however, must provide meaningful criteria.
With these tips and tricks, I hope you are in a good position to avoid these pitfalls and create the best collaborative user stories with your team possible.