DevOps

Acceptance Test-Driven Development (ATDD)

What is Acceptance Test-Driven Development (ATDD)?

Acceptance Test-Driven Development (ATDD) is a development methodology where tests are written from the user's perspective prior to development. It focuses on satisfying the functional requirements of the system.

Acceptance Test-Driven Development (ATDD) is a development methodology that promotes collaboration among all stakeholders in a software development project. It is a key component of the DevOps approach, which emphasizes the integration of development and operations teams to deliver software more efficiently and reliably. This glossary entry will delve into the intricacies of ATDD, its role in DevOps, and its practical applications.

ATDD involves the creation of acceptance tests by the customer, developer, and tester before the implementation of the software. These tests serve as a clear and measurable definition of what the software should do, providing a shared understanding of the requirements and reducing the risk of misunderstandings. ATDD is closely related to, but distinct from, Test-Driven Development (TDD), which focuses on unit tests created by developers.

Definition of Acceptance Test-Driven Development

Acceptance Test-Driven Development (ATDD) is a development practice where the team collaboratively discusses acceptance criteria, with examples, and then distills them into a set of concrete acceptance tests before development begins. It's the best way to ensure that we all have the same shared understanding of what it is we're actually building. It's also the best way to ensure we have a shared understanding of what "done" means.

The acceptance tests are a set of automated tests that verify the functionality of the system from the user's perspective. They are written in a language that is understandable to the non-technical stakeholders, using a tool that allows them to be executed automatically. The acceptance tests serve as a contract that the development team agrees to fulfill.

Distinction from Test-Driven Development

While both ATDD and Test-Driven Development (TDD) involve writing tests before the code, they differ in their focus and scope. TDD is a development practice used by programmers to create detailed specifications for small units of code, typically methods or functions. The tests in TDD are written by the developers and are aimed at other developers.

On the other hand, ATDD focuses on the system as a whole and its behavior from the user's perspective. The tests in ATDD are written by or with the involvement of the customer and are aimed at the entire team, including the non-technical stakeholders. The goal of ATDD is to ensure that the software meets the customer's needs and expectations.

Role of ATDD in DevOps

DevOps is a set of practices that aims to shorten the system development life cycle and provide continuous delivery with high software quality. ATDD plays a crucial role in the DevOps approach by promoting collaboration, shared understanding, and early validation of the requirements.

By creating acceptance tests before the implementation, the team can have a clear and measurable definition of what the software should do. This helps to prevent misunderstandings and conflicts later in the development process. The automated execution of the acceptance tests also supports the continuous integration and continuous delivery practices of DevOps.

Collaboration and Shared Understanding

One of the key principles of DevOps is the collaboration between all stakeholders in a software development project. ATDD supports this principle by involving the customer, developer, and tester in the creation of the acceptance tests. This collaborative process helps to build a shared understanding of the requirements and the definition of "done".

Furthermore, the acceptance tests serve as a communication tool that bridges the gap between the technical and non-technical stakeholders. They are written in a language that is understandable to the non-technical stakeholders, allowing them to participate in the discussion and decision-making process.

Early Validation and Continuous Delivery

Another key principle of DevOps is the early and continuous delivery of valuable software. ATDD supports this principle by providing a mechanism for early validation of the requirements. The acceptance tests serve as a contract that the development team agrees to fulfill. If the software passes the acceptance tests, it is considered to meet the requirements and is ready for delivery.

The automated execution of the acceptance tests also supports the continuous delivery practice of DevOps. It allows the team to quickly and reliably verify the functionality of the software after each change, reducing the risk of regression and increasing the speed of delivery.

Practical Applications of ATDD

ATDD has been successfully applied in a wide range of software development projects, from small startups to large enterprises. It is particularly beneficial in complex projects where the requirements are not fully understood at the beginning and evolve over time. ATDD helps to manage this complexity by providing a clear and measurable definition of what the software should do.

ATDD is also beneficial in projects with diverse stakeholders, including non-technical stakeholders. The acceptance tests serve as a communication tool that bridges the gap between the technical and non-technical stakeholders, allowing them to participate in the discussion and decision-making process.

Case Study: Large Enterprise

In a large enterprise, ATDD was used to develop a complex business application. The project involved multiple teams and stakeholders, including business analysts, developers, testers, and end-users. The requirements were not fully understood at the beginning and evolved over time.

The team used ATDD to manage this complexity. They collaboratively created acceptance tests before the implementation, providing a clear and measurable definition of what the software should do. The acceptance tests served as a contract that the development team agreed to fulfill. They also served as a communication tool that bridged the gap between the technical and non-technical stakeholders.

Case Study: Small Startup

In a small startup, ATDD was used to develop a mobile application. The project involved a small team of developers and a few key stakeholders, including the product owner and the end-users. The requirements were relatively simple but subject to change due to the fast-paced nature of the startup environment.

The team used ATDD to manage these changes. They collaboratively created acceptance tests before the implementation, providing a clear and measurable definition of what the software should do. The acceptance tests served as a contract that the development team agreed to fulfill. They also served as a communication tool that facilitated the discussion and decision-making process.

Conclusion

Acceptance Test-Driven Development (ATDD) is a powerful tool for managing complexity and promoting collaboration in software development projects. It is a key component of the DevOps approach, supporting its principles of shared understanding, early validation, and continuous delivery. By creating acceptance tests before the implementation, the team can have a clear and measurable definition of what the software should do, reducing the risk of misunderstandings and conflicts.

ATDD has been successfully applied in a wide range of projects, from small startups to large enterprises. It is particularly beneficial in complex projects where the requirements are not fully understood at the beginning and evolve over time. It is also beneficial in projects with diverse stakeholders, including non-technical stakeholders. The acceptance tests serve as a communication tool that bridges the gap between the technical and non-technical stakeholders, allowing them to participate in the discussion and decision-making process.

Join other high-impact Eng teams using Graph
Ready to join the revolution?
Join other high-impact Eng teams using Graph
Ready to join the revolution?

Build more, chase less

Add to Slack