Behavior-Driven Development (BDD) is a well-known practice for collaboration, and teams use it to bridge the gap between product management and the software development team. It is also very popular among quality engineers to develop test automation frameworks. BDD helps in describing requirements in the form of feature files and scenarios; scenarios further get described in the format of Given, When, and Then.
Gherkin language can be used to write feature files in more than 40 languages. Some of the important keywords of Gherkin mentioned below that help in describing features and scenarios:- Feature, Scenario, Given, When, Then, And, But, Background, Scenario Outline, and Examples
How to write a Feature file?You can write a feature file in Notepad or some popular IDEs like Visual Studio, Eclipse, IntelliJ, etc. Basically, there is no need to know any particular tools. But the most important thing is how to prepare for these scenarios. There is a very popular practice known as the 3 Amigos session.
Here is a brief about this session, as described in the glossary on Agile Alliance. Three amigos refer to the primary perspectives to examine an increment of work before, during, and after development. Those perspectives are:
Business — What problem are we trying to solve?
Development — How might we build a solution to solve that problem?
Testing — What about this? What could possibly happen?
People holding these different perspectives should collaborate to define what to do and agree on how they know when it is done correctly. The end result of such a collaboration results in a clearer description of an increment of work, often in the form of examples, leading to a shared understanding for the team.
If you are developing software using Scrum then you may like to host these sessions during Product Backlog Refinement or Sprint Planning. It is because The Product Owner and The Development Team participate during both where The Product Owner provides business prospective, and The Development Team (consisting of developers and testers along with other members) provides development and testing prospectives.
Example of a Feature using BDDFeature: Search Flight As a flyer, I want to search for available flights between Bangalore and Chennai So that I can book to travel on a given date. #above story/description is optional
Scenario: Search all available flight based on date, origin, and destination Given flyer enter travel date as “12/12/2020” and origin as “Bangalore and Destination as “Chennai” When Click on the Search button Then Search page should show all available flight And Provide option to book flight What is a complex story/requirement? Take the above example of flight search, this looks very simple but can it be delivered in 2 weeks of the sprint? Do we have an answer to the below questions?
- Who is the user (persona) of this story?
- Do you know the data sources for each airline?
- Do we know what these personas expect from this feature?
- What’s going to be the order of data?
- Will have filters?
- What are the actions users perform?
Yes, it is. So how to slice this feature to have a releasable product increment by meeting DoD at the end of the sprint? Use the BDD scenario like below to slice it and then prioritize based on the value that you see in each slice. Develop stories incrementally and ensure you get feedback to maximize user experience and optimize the value of the work.
Basic examples of slicing using ScenariosNow change the scenario to search flights for one airline at a time because connecting multiple sources may not be possible in one sprint and modify it like below.
Scenario: Search only Indigo flight based on date, origin, and destination Given flyer enter travel date as “12/12/2020” and origin as “Bangalore and Destination as “Chennai” When Click on the Search button Then Search page should show all available flights And Provide option to book flight.
Scenario: Search only Spicejet flight based on date, origin, and destination Given flyer enter travel date as “12/12/2020” and origin as “Bangalore and Destination as “Chennai” When Click on the Search button Then Search page should show all available flight And Provide option to book flight.
Scenario: Search only Jet Airways flight based on date, origin, and destination Given flyer enter travel date as “12/12/2020” and origin as “Bangalore and Destination as “Chennai” When Click on the Search button Then Search page should show all available flight And Provide option to book flight Now the team can decide to build only those scenarios that can be delivered within one sprint and rest scenarios in upcoming sprints (if it makes sense).
The above scenarios can also be further sliced like below if needed.
- Scenario: One-way flight of Indigo
- Scenario: Return flight of Indigo
- Scenario: Multiple location search for Indigo etc.
- Small increment
- Less waste
- Early release of a feature
- Better quality
How does Behavior-Driven Development optimize the value of the work done?BDD helps in getting done all. Developing stories based on scenarios help in getting small increment out, release it internally or externally if it makes sense. Getting in detail of each story reduces ambiguity, rework, and rejection so the team produces less waste. BDD scenarios get automated with the help of various tools such as Cucumber, SpecFlow, and Behave so regression tests become easy to execute every time. Better quality can be achieved by continuously refactoring code and developers feel safe in refactoring as these tests protect them from breaking running code.
Hope it is useful and if you have further queries then reach out to me on firstname.lastname@example.org. We at Agilemania provides Scrum and Agile Training including TDD, BDD, and Extreme Programming, if you are interested in learning these.