<linearGradient id="sl-pl-bubble-svg-grad01" linear-gradient(90deg, #ff8c59, #ffb37f 24%, #a3bf5f 49%, #7ca63a 75%, #527f32)
Loading ...

QA essentials

Your go-to quality assurance source

Cypress User Registration Testing: A Beginner’s Guide to Cypress

In previous article about Cypress setup and first tests we described some of the basics. In this second part of the Cypress tutorial we will continue with creating tests on a simulated environment. This time we will use Cypress for user registration testing. By doing all these tests we will understand the following:

  • working with Mocha hooks
  • basics of finding elements
  • some of the Cypress functions for manipulating elements
  • how to check if the server returns a valid response
  • aliasing

Let’s start our learning without further ado.

Creating new test for Cypress user registration testing

First thing I will do is to delete the auto-generated tests when we first started Cypress in the previous tutorial along with the first test we created. What we need to do next is to create a new file which will cover this test. We should put this file in new folder named Registration Tests. The name of the new file will be userRegistration.cy.js. The folder structure should look like this now:

cypress user registration testing

In this file we will first create new describe block and in it the before block. The describe and before are hooks Cypress borrowed from Mocha. Mocha is a powerful test framework running on Node.js. There is a large number of hooks but we will mention those that we will use frequently:

  • We use describe to organize lower level blocks
  • Block labeled with before runs once before all the other blocks
  • beforeEach block will be executed every time before any it block
  • it block is usually the block where we put all our tests
  • afterEach gets executed after each it block
  • after is executed once after all the it blocks finish

For now, we will only create the blocks inside the newly created file. If the Visual Studio Code does not offer suggestions when you start typing you should add new file in root Test folder named jsconfig.json and add this line of code in it.

{
  "include": ["./node_modules/cypress", "cypress/**/*.js"]
}

Save the file, ignore the errors it shows and check if the VS Code offers auto suggestions when you type something in the test file. Let’s create all the blocks representing our test cases.

test structure

Notice that the name of each it block displays clear intent of the test and what it should assert.

Create before block

As already mentioned in before block we put the code we would like to execute first before any of the other commands. This is a setup of the test. In this block we will prepare for the test by opening the URL of the test page. In our case we need to visit the home page URL, hover over My account button and click on Register button. We will not validate if the page opened by using some assert because we shouldn’t do such check in before block but we will check if the response of the request was successful. For this check we will use intercept and wait commands. The important thing to know is that every Cypress command starts with cy and all the other commands are chained off cy.

Intercept and aliasing

To start we need to open the test environment in our browser and inspect the page. To do that press F12 and your keyboard and click on Network panel. For more information about Network panel check out the in depth article on our blog. Now, we will manually perform the action we would like to replicate using Cypress. After we click on Register button a new GET request is sent to the server. We take the complete URL of this request and put it as an argument in intercept function. After this we put command as and name this action as we like. Cypress call this aliasing. Alias is like a variable in which we store this entire request. These intercept actions are usually written at the top of the block for better visibility. We do not need to write them in any particular order. You can place them anywhere in the block.

Visit URL

After this we add new line of code for visiting https://ecommerce-playground.lambdatest.io/. The command in charge of this is cy.visit and we pass the URL to the test application as an argument.

Hovering an element

Next thing we need to do is to hover an element to make the button for registration appear. There are multiple ways to do this in Cypress, but in our case we can use trigger function which triggers Javascript events like mouseover. To find the element we need to interact with we will use Elements panel in Chrome Dev Tools. The complete command is:

cy.get('a[role="button"]').contains('My account').trigger('mouseover');

First we find a button that contains label My account and then we trigger the mouseover event over it. When the Register button appears we click on it.

Waiting for the page to load

If you are familiar with Selenium then you know something about waits. In Cypress the best practice suggest that we should use wait command to wait for the page to load. In this case we actually wait for the alias of the intercepted request and while we get the response we can confirm that it was successful by checking its response status code. The entire before block should look like below:

cypress user registration testing

First test

In first test we check if all the elements on the page are visible. The checkbox and radio buttons are custom commands so the HTML elements are not visible. We cannot assert they are visible, but we can check if they exist on the page. For this we will use Mocha assertions performed on specific HTML elements. We find the element we want to interact with again by using Elements panel in Dev Tools and chain the should keyword off it. We do this for each of the elements.

first it block in cypress user registration testing tutorial

Cypress user registration test with all empty fields

One of the most common test cases to check is the test with trying to send the form with empty mandatory fields. We can perform this test by simple click on a submit button while all the fields are empty and hopefully we will get a validation message preventing the page to send the form. In this test we will explore the concept of chaining assertions using and keyword. It allows us to have multiple assertions on a single element without duplicating the lines of code. Also, we explore the option to find an element by its index with eq keyword and the index of an element as an argument. Indexes start at 0. This is an option when we have multiple elements in HTML with the same attributes and no unique attribute is available.

cypress user registration testing empty fields test

Don’t allow registration with existing email

In this test of our Cypress user registration testing tutorial we will fill out the form but we will use an email which is linked to a registered user. I have used a fake email address I used to register another user during exploratory testing of this page. This should also trigger validation and stop the page to send the form. In this test we learn how to type text into fields on the page. We use Cypress type command for this action and we also use a new command for checking off the checkbox for privacy policy. Cypress recommends to use check command for this. Since checkbox is a custom command and the HTML element is hidden we need to pass {force: true} as an argument to force clicking on a hidden element. The result of this test should be an alert message that the email is already registered.

user registration test with already registered email

Checking registration with invalid email address

This test is quite similar to the above and we will mostly copy the same steps except for the assert which should check for a different message. Why are we spending time on this in this basic tutorial? When I was a junior QA engineer my aim was to do so much in as little tests as possible. I would set up loops, conditional logic, switches, anything just to avoid writing additional code. In this test and the above I could have used the same logic for populating the fields and just add an if statement which would check in one case for existing email alert message and in the other case for invalid email.

We should avoid conditional logic in test code. There are valid test cases when we could use it but this is not one of them. In this case, it is better to split the logic, retain readability at a cost of repeating a few lines of code. Plus, we might be able to do something later to reduce the repeating of the code but for now we will continue like this.

For this test we cannot quite check the message that appears when the email address is invalid. It is an in-built PHP message which is a function of the browser. We should not try to test the functionality of the browser but our application. To check if the page sends the form with invalid email we can assert the URL. The URL contains route=account/success when the registration is successful. We should assert that the URL does not contain this string after clicking submit which would mean that we stayed on the same page.

cypress test with invalid email

Exploring negative asserts

In the following test we assert that the page will not send the form when privacy policy is not checked off. We add a new skill by exploring the Mocha negative assertions. Try typing the command for finding the checkbox followed by should command and start the assertion argument with ‘not’. You will see a list of all the possibilities for negative assertions. In our case we need not.be.checked.

assert checkboxes cypress user registration

Happy path test

Finally we will go through happy path test in this Cypress user registration testing tutorial. For happy path we complete the form with all the valid information and submit it. We will validate the page and its content to make sure that everything works fine.

happy path test

Running the Cypress user registration test

If you remember from the previous article in the series, we start the Cypress runner by typing npx cypress open in the terminal window. Then we select E2E tests and select a browser to run the test. Then our test specification should be visible. When we click on it the test will start. However, the Cypress does clean up after every it block which means that every block should start from the very beginning. In our case, first test will run without problems and others will fail. This can be solved in two ways, by adding testIsolation: false in cypress.config file or by changing our before block to beforeEach.

const { defineConfig } = require("cypress");

module.exports = defineConfig({
  e2e: {
    setupNodeEvents(on, config) {
      // implement node event listeners here
    },
    testIsolation: false
  },
});

The best practice says that we should keep our test isolated and that is the option we will choose. Just rename the before block to beforeEach and try to run the tests now. All the tests should pass.

Summary

In this Cypress user registration testing tutorial we have touched many important topics. Although this list of test cases is not exhaustive it is designed to cover broad range of different topics. Just to mention some of them: aliasing; waiting for the server to return the response; type, check, trigger and hover commands; Mocha hooks, assertions and negative assertions. This by itself is enough for a small scale testing even though we haven’t discussed yet the Page Object Model in Cypress. In one of the next articles we will expand our tests with reusable custom commands, POM and setup of baseUrl.

Oh hi there 👋
It’s nice to meet you.

Sign up to receive awesome content in your inbox, every month.

We don’t spam! We keep your data private and share it only with third parties that make this service possible. Read our privacy policy for more info.

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.