Features and stories serve different purposes in software delivery. Seb Rose finishes off his BDD series by encouraging us to be mindful of the difference.
This is the fourth in a series of articles digging into user stories, what they’re used for, and how they interact with a BDD approach to software development. This is the last in this series, but certainly not the last time I’ll be talking about user stories. However, since it brings the current narrative arc to a close, it is perhaps the end of the beginning [Churchill42].
Lifecycle of a story – revisited
User Stories start off as placeholders for a conversation [Rose22]. They’re ideas, often large, not fully formed. They could be valuable, but they’re not ready for development just yet.
As we refine them (through discovery [Rose23]) they become better understood. Collaboration ensures that they make sense to the whole team. The business requirements that limit their scope are negotiated and agreed.
Now it’s possible to see what’s involved in delivering the story, we can split them into smaller chunks. Smaller chunks mean faster feedback, smoother flow, and less waste [Rose24]. They’re no longer placeholders. Now they’re detailed small increments, each one carrying a small payload of valuable functionality (see Figure 1).
Figure 1 |
As the stories get plucked off the backlog, they deliver enhancements and brand new features. Not in a big bang, but incrementally and iteratively. Many stories contribute to each feature. Some stories contribute to many features. No feature is ever finished – it’s just done for now.
No further value
Just because something has been useful doesn’t mean that it will continue to be useful. On the contrary, once you have used something its value usually diminishes. Consider a tube of toothpaste or a pack of stickies.
The story never was a requirement. It starts as a placeholder and is then transformed, first into a narrative and then into several detailed small increments of functionality. That process is important, because it enables the team to learn about the problem and the solution. It’s important, because it allows us to discover the requirements. However, it is the feature files (and ancillary documentation) that capture the requirements, not the stories.
Have you ever tried to make sense of a team’s system by reading the completed stories from their issue tracker? It’s impossible.
Stories only make sense when seen as a sequence of events, playing out over time. Like one of those flip book animations that you made at school. Useful documentation, on the other hand, describes how the system behaves now – not the history of how it evolved to behave like it does.
Back in the mists of time, when stories were written on index cards, XP teams used to indulge in a confetti party at the end of each iteration. The story cards in the ‘done’ column were torn into small pieces and thrown into the air, to rain down as the team danced around, celebrating their success. Most teams have moved on to electronic story tracking systems, which saves paper, but makes the disposal of stories problematic and much less fun.
Stories, once delivered, have no further value. Certainly not as documentation of the system’s behaviour.
Souvenirs
So if we don’t want to capture stories in our living documentation, what do we want in there?
Well, there are many useful things you can capture in a feature file. Written prose that explains the context and need for a feature is still useful for people reading the documentation for the first time. You can add links out to other sources of information like UX wireframes or user research data. But probably the most important thing to document alongside your scenarios are the rules.
If you cast your mind back to our earlier discussion of example mapping [Rose23], you’ll remember that requirements are also known as acceptance criteria or rules [Keogh11].
Modern versions of Gherkin provide a defined way to capture rules – the Rule
keyword. All scenarios that follow a Rule
statement are expected to illustrate that rule. The Rule
statement is in scope until either the next Rule
statement is encountered or the end of the feature file.
Feature: Hear Shout Rule: Shouts have a range of 1000m Scenario: In range, shout is heard … Scenario: Out of range, shout is not heard … Rule: Shouts must not be empty Scenario: Zero length, not valid … Scenario: Only whitespace, not valid … Scenario: Single character, valid …
The bottom line is:
- Stories helped us decide what we want (and how to deliver it).
- Features document what we’ve got.
By all means keep the story index cards in your drawer as a souvenir (although I guarantee you’ll never look at them). Please don’t pollute your feature files with them.
Traceability
There are processes and organisations that value historical stories. The word I hear most often in this regard is ‘traceability’, so I’d like to write a few words about the challenges.
In regulated industries (health, defence, finance) there is a need to demonstrate a rigorous end-to-end development process, from inception to delivery. Since stories are a visible, tangible artefact, often stored in electronic data management systems, they are easy to include in the web of traceability.
The trouble is that stories are neither definitive nor independent. Their lifecycle makes them no more suitable for traceability purposes than conversations around a watercooler or notes scribbled on your tablet. If you use stories for traceability, one of these days you’re sure of a big surprise [Wohlrab20].
Following a link from a story through to the commit(s) that delivered the code and test scripts might give you confidence that the necessary work has been done. And since feature files will be part of those commits, the resulting behaviour is also documented. However, since subsequent stories may have been delivered, this means that you cannot infer anything about the current behaviour of the system by traversing links from a story through to commits.
Tools are currently being developed that will make it simpler to trace from a specific version of a scenario through to the stories that caused it to be written, which will help with some compliance needs. Nonetheless, it is important to remember that stories are neither requirements nor deliverables. They are transient artefacts that facilitate delivery, not persistent artefacts that document behaviour.
Continue the conversation
In this article, I hope that I’ve demonstrated why there’s no place for stories inside your feature files. If you have any feedback or questions, I’d be happy to hear it.
References
[Churchill42] Winston Churchill, 1942, uploaded on 15 May 2010 at https://www.youtube.com/watch?v=pdRH5wzCQQw
[Keogh11] Liz Keogh ‘Acceptance Criteria vs. Scenarios’, posted on 20 June 2011 at https://lizkeogh.com/2011/06/20/acceptance-criteria-vs-scenarios/
[Rose22] Seb Rose ‘User Stories and BDD – Part 1’ in Overload 171, October 2022, available at https://accu.org/journals/overload/30/171/rose/
[Rose23] Seb Rose ‘User Stories and BDD – Part 2, Discovery’ in Overload 178, December 2023, available at https://accu.org/journals/overload/31/178/rose/
[Rose24] Seb Rose ‘User Stories and BDD – Part 3, Small or Far Away?’ in Overload 179, February 2024, available at https://accu.org/journals/overload/32/179/rose/
[Wohlrab20] R Wohlrab, E Knauss, JP Steghöfer et al. (2020) ‘Collaborative traceability management: a multiple case study from the perspectives of organization, process, and culture’, Requirements Eng 25, 21–45, available at https://doi.org/10.1007/s00766-018-0306-1
This article was first published on Seb Rose’s blog on 30 January 2020: https://cucumber.io/blog/bdd/user-stories-and-bdd-features-are-not-stories/ It has been reviewed and updated for Overload.
Seb has been a consultant, coach, designer, analyst and developer for over 40 years. Co-author of the BDD Books series Discovery and Formulation (Leanpub), lead author of The Cucumber for Java Book (Pragmatic Programmers), and contributing author to 97 Things Every Programmer Should Know (O’Reilly).