Introduction to the Arrange-Act-Assert Pattern
Learn how to structure end-to-end tests using the Arrange-Act-Assert pattern.
We'll cover the following
When writing end-to-end tests, we often test complex scenarios with multiple services running simultaneously. We need a systematic way to write tests that are simple to understand. While Cypress makes writing our tests simple by providing us with some basic building blocks, it is fairly uncomplicated when it comes to structuring our tests. Having a reproducible structure makes writing even complicated test scenarios straightforward. Let’s look at one of the most common formulas, the Arrange-Act-Assert pattern.
Testing formula
Most tests can be divided into three distinct steps: arrange, act, and assert. When writing our tests, it’s helpful to take some time and try to follow this pattern. Using the same structure for all of our tests makes it easy to understand what is happening in each test with a quick glance. Let’s learn what we should do in each step.
Arrange
In the first step, we set up our application state to our liking. Here are some actions that we perform:
Resetting the database
Seeding the database
Setting up cookies
Visiting the correct URL
Act
In the second step, we perform actions that cause some event to happen, such as:
Filling up form fields
Clicking a button
Clicking on a link
Assert
In the last step, we check that our application state matches what we expect it to.
Get hands-on with 1400+ tech skills courses.