Behavioural-driven development (BDD) is a software development approach that uses plain language understandable by non-technical teams to create tests for desired feature behaviour. Specifications are defined in accordance with customers before development starts, and these specifications are used as acceptance criteria.
The tests are written based on structured formal language with key words "GIVEN ..., WHEN ..., THEN ..." or "WHEN ..., IF ..., THEN ...". The purpose of these terms are explained in the tables below:
Term | Action |
---|---|
GIVEN | some pre-conditions |
WHEN | some action occurs |
THEN | the application should have the desired result |
Term | Action |
---|---|
WHEN | some situation happens |
IF | some action occurs |
THEN | the application should have the desired result |
Behavioural-driven development uses these specifications to create automated tests. Thus, testing ensures that the application behaviour matches the customer's wishes.
Example: Take the following example of a customer requesting an application that uses a login system.
User Story: a registered user will be able to log in to see the app contents.
Specification:
Term Action GIVEN the user is in the login page and not logged in WHEN the user provides the correct credentials THEN log them in and allow them to view the home page Or equivalently:
Term Action WHEN the user is in the login page and not logged in IF the user provides the correct credentials THEN log them in and allow them to view the home page
The developer could write a unit test to test a function that does what the specification details, and the specifications would be listed in the test documentation for readability. For example, they may write a function log_in
that takes as parameters a user and the current page the user is on. The function then checks for valid credentials provided by the user, and if the user is currently on the log in page and not logged in, then the function changes the current page to the home page and updates the user's status to "logged in ". The specific design of this function (e.g. creating helper functions to get credentials or verify credentials, placing files in different modules) is up to the developer, but the unit test must pass for the acceptance criteria to be met.
Since the test documentation is written in plain language, it is easy for both technical and non-technical teams to see that the test confirms some desired behaviour. If the application is tested in this way for all specifications, it is easy to see how automated testing under BDD ensures the application aligns with the customer's vision.
As part of clean coding, use the same naming convention across all tests created using BDD. For example, WhenXThenY
or when_x_then_y
or given_x_when_y_then_z
.
BDD works best in rapid iterations, and is commonly used in conjunction with Agile methodology. The development process can be summarized as follows:
- Take a small change, e.g. a user story, and come up with concrete examples which use this new functionality.
- Document these examples for automated testing, such as writing unit tests, and confirm that the customer agrees with the functionality.
- Implement the new functionality based on the documented examples.
Behavioural-driven development provide benefits in the following categories during the development process.
A software team receives more specific requirements using BDD.
For example, instead of receiving a requirement "implement the login feature", the team is provided a specific requirement "when the user is on the login page, if they provide valid credentials, then the application logs them in and opens the home page".
New features or changes will still meet the acceptance criteria for both previous and new behaviour while using BDD. If any acceptance criteria is not met, then the new changes will cause testing to fail.
Otherwise, guaranteeing that all features work in the way that the customer is looking for becomes a more diffult task. Some repercussions are as follows:
- customers/users may notice unintended behaviour
- developer may need to run manual tests
- general worry or anxiety about the application's behaviour
It is easier to write tests using BDD because test cases can be derived from specifications approved by the user. The tests also serve as documentation for desired behaviour of a feature.
Otherwise, the developer may need to put more time and effort into creating tests while writing the code to ensure that the tests are useful.
The information on this page comes from the following resources:
- CSC301 Week 9 Lecture Slides
- https://cucumber.io/docs/bdd/
- https://cucumber.io/blog/bdd/getting-started-with-bdd-part-1/
- https://www.softwaretestinghelp.com/bdd-framework/
These resources also provide further reading on behavioural-driven development if you wish to learn more.