Skip to content

Latest commit

 

History

History
139 lines (75 loc) · 6.37 KB

README.md

File metadata and controls

139 lines (75 loc) · 6.37 KB

SROC acceptance tests

The Tactical Charging Module (TCM) is a web application designed to enable billing adminstrators to apply new categories to permit charges to enable correct amounts to be processed.

This service is an internally facing service only, used by billing administration staff.

This project contains acceptance tests for the service. It is built using Cypress and the cypress-cucumber-preprocessor. We favour writing our tests in a BBD style using Gherkin hence the cucumber-preprocessor plugin.

Pre-requisites

You just need Node.js installed, ideally an LTS version.

You'll also need Chrome. It's what we use when working on the tests, and is one of 2 browsers available to our users.

Installation

First clone the repository and then drop into your new local repo

git clone https://github.com/DEFRA/sroc-acceptance-tests.git && cd sroc-acceptance-tests

Next download and install the dependencies

npm install

Configuration

Important! Do not add environment files to source control

We have 5 environments where the CHA could be running; local, development, test, pre-production, and production.

Each has its own config file stored in environments/. Any configuration shared across the environments is stored in cypress.json. But this can be overidden in the environment config files.

Environment files

The config or 'environment' files hold environment variables which are key-value pairs; name of the thing and the value of the thing. For example, CYPRESS_PASSWORD=password12345.

Depending on the environment selected the Cypress dotenv plugin will read in the values and make them available via Cypress.env() in the tests.

Using these .env files allows us to store both config and credentials that change across environments in one place but it is important they are never committed to source control.

Checkout environments/.env.example for an example of the file you'll need to create for each environment.

Execution

You can run tests using the Cypress test runner or headlessly using the Cypress CLI.

Test runner

Cypress runs tests in a unique interactive runner that allows you to see commands as they execute while also viewing the application under test.

Screenshot of test runner

To open the test runner use npm run cy:open:[env] replacing [env] with your chosen environment

npm run cy:open:local

WIP

The project supports only running scenarios tagged as @wip. This can be very useful when working on new scenarios or trying to debug failing ones. Reducing the number being run reduces the noise and test output allowing you to focus.

Behind the scenes it behaves the same as using the Test runner only you use a different command to start Cypress.

npm run cy:wip:local

The test runner will open as normal but when you run a feature only those scenarios tagged with @wip will run.

CLI

Runs Cypress tests to completion. By default, cypress run will run all tests headlessly in the Electron browser.

Screenshot of test runner

To open the test runner use npm run cy:run:[env] replacing [env] with your chosen environment

npm run cy:run:local

Test structure

In order to test our environments as well as our application, we created a standalone project rather than install Cypress into an existing one.

We have also opted to write our tests as features using the BDD style. As such our project's structure is a little different from the common examples you'll find Googling.

Features

Feature files (*.feature) need to be stored in cypress/integration/ to be visible as tests. Along with each feature you will need to create a folder with the same name. In the folder create a *.js and add your steps for the feature there.

The steps file can be called anything. But we have opted to use the same name as the feature file and folder. This way makes it a little easier to track things when working across multiple files.

Common steps

Any steps which can be shared across features can be placed in cypress/integration/common/. Check the existing files to see if one that fits already exists and add your steps to it. Else create a new *.js file. Again, the name of the file does not matter.

Pages

Another preference of the team is to use the Page object pattern. Essentially, we store the code to interact with a page of our service in one place. Tests interact with our page object not the page directly. So should something change, we only have to change it in one place.

Pages live in cypress/pages.

Reporting

Built into the project is the ability to generate a HTML report of your last test run.

Screenshot of html report

Each time you use cy:open or cy:run the project will automatically delete the previous test results and generate new ones based on what tests are run.

If you then call npm run report the project will generate a HTML report based on the test results. You can access the report at cypress/reports/html/report.html.

Contributing to this project

If you have an idea you'd like to contribute please log an issue.

All contributions should be submitted via a pull request.

Licence

THIS INFORMATION IS LICENSED UNDER THE CONDITIONS OF THE OPEN GOVERNMENT LICENCE found at:

http://www.nationalarchives.gov.uk/doc/open-government-licence/version/3

The following attribution statement MUST be cited in your products and applications when using this information.

Contains public sector information licensed under the Open Government licence v3

About the licence

The Open Government Licence (OGL) was developed by the Controller of Her Majesty's Stationery Office (HMSO) to enable information providers in the public sector to license the use and re-use of their information under a common open licence.

It is designed to encourage use and re-use of information freely and flexibly, with only a few conditions.