Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Overview of testing strategy

...

What we are testing

...

What we’re not testing

...

The initial aims of the DCB Admin Automated Testing Strategy are as follows:

  • To write basic tests to detect unexpected changes or behaviour in DCB Admin, so that the core user experience can be protected.

  • To test basic actions within DCB Admin, with a view to testing more complex ones in future work.

  • To make the DCB Admin codebase more resilient, providing ‘guardrails’ that complement the existing code review process and provide additional protection against unintentional, unexpected or incorrect changes to DCB Admin functionality.

  • To prevent regression where possible, and to provide a method of detecting instances of regression when they do occur, so that they can be promptly fixed.

    • Regression in this context is defined as a feature or other part of the DCB Admin UX that breaks or experiences previously unseen unexpected behaviour after a change has been made.

    • Example 1: Changes to the page titles within DCB Admin are pushed, but contain unintentional mistakes. Cypress tests detect this and flag the unexpected behaviour before it even reaches the user.

    • Example 2: Changes to the DataGrids within DCB Admin are pushed and unintentionally break the ability to search. Cypress tests detect this unexpected action, and alert us to the regression so that it can be fixed.

What we are testing presently

  • The correct rendering of the core DCB Admin pages: agencies, patron requests, groups, hostlmss, sourceBibs and locations - do these pages load as they should, with the data and UI elements we expect?

  • The search functionality on the aforementioned DCB Admin pages: can a user find what they’re looking for, and does search return the expected results?

    • This is an area for particular development - search has been tested as an example DataGrid action, and filtering and sorting should be tested in the same way.

  • The creation of new groups, and whether new groups are displayed (and displayed with the correct information) on the groups page after their creation.

    • This is an example of an action test: there are many other actions that could be tested within DCB Admin, such as uploading mappings and adding agencies to groups.

  • Login and logout within DCB Admin, whether core UI elements render as they should, and whether they change and render correctly when a user is logged in / logged out.

What we may seek to test in the future

  • Other page functionality, such as sorting and filtering - particularly when this shifts to being done on the server-side for other pages.

  • The home and mappings pages, in a similar vein to how the other pages have been tested.

  • The process of uploading mappings, and whether the page updates correctly once uploaded or displays the appropriate error messages.

  • The Details page and its variants, and their corresponding actions (closing accordions etc).

  • The 404 and unauthorised pages.

  • The content of the header, footer and sidebar (particularly release information).

  • Other functionality as it is added, to prevent future regression and improve reliability.

Why Cypress was chosen for this work

With Cypress, we can write end-to-end (E2E) tests that navigate the application just as a user would. This is extremely helpful when testing the overall user experience, as opposed to component testing, which has a much narrower focus. E2E integration tests allow us to look at the broader picture of how users may use our apps, enabling us to test actions, paths and journeys within DCB Admin.

Cypress has numerous useful features for testing. It takes snapshots as our tests run, meaning we can identify exactly what the user is seeing at any point. This means that when tests do fail, we can see exactly what happened, which is very useful when trying to fix it. Debugging Cypress tests is also very straightforward, and can be done through common tools such as Chrome DevTools - this also aids in speeding up our investigations.

Finally, Cypress gives us extremely powerful network traffic control tools. These empower us to stub requests and responses, and simulate application behaviour in a range of network conditions, all without having to send actual requests to the server. All of these features are also available through Continuous Integration, meaning that while we may start with a local Cypress setup, there is the potential to run Cypress tests through Gitlab and unlock a range of benefits - not least spotting potentially UX-breaking code before it even hits code review.

Configuration / setup within DCB Admin

Info
  • Infrastructure

  • Folder setup

  • Config files in play

Cypress is currently configured locally within DCB Admin. This means that you may have to run npm install when you attempt to run the Cypress tests for the first time. The configuration is as follows:

...

  • A /cypress directory has been created. It contains the following sub-directories.

    • /downloads - for files downloaded during a test. Not yet used.

    • /e2e - this is where all of our E2E integration tests go. All tests follow the format exampleTest.cy.ts.

    • /fixtures - for Cypress fixtures.

    • /screenshots - Cypress automatically saves screenshots it takes from the tests to this location. These are not to be committed to Git, but are sometimes useful for evidencing test failures or diagnosing an issue.

    • /support - contains configuration files for Cypress such as e2e.ts, which manages config for E2E tests, and commands.ts, which is where Cypress custom commands are registered.

      • An example of a custom command is cy.login() - as we generally have to login at the start of most tests, refactoring the necessary code into a command makes sense.

    • /utils - holds any required utility functions.

Preparing and writing tests

  • Also located within this directory is the Cypress tsconfig.json file, which regulates the behaviour of the TypeScript compiler when dealing with Cypress files.

  • Outside of this directory, cypress.config.ts manages global Cypress configuration settings.

Preparing and writing tests

Refer to https://docs.cypress.io/guides/end-to-end-testing/writing-your-first-end-to-end-test for a useful in-depth tutorial (but remember we use TypeScript)- below is a quick summary.

  • Create your test file. The filename should be yourName.cy.ts.

  • All Cypress tests start with a describe statement, like so: describe('My First DCB Admin Test', () => {}

    • This should be a concise test name. You will outline your test cases within this describe block.

  • Outline your individual test cases like so: it('should add this example', () => {}.

    • This should be a clear description of the action or behaviour you are testing - i.e. what should happen, or what should be possible. See the existing tests and the ERM tests for examples.

  • Cypress has excellent documentation - make use of it when writing your tests. Many common questions can be answered by reading it.

    • For questions around best practice, see here. Cypress docs also include many highly useful examples.

Running tests locally

To run the Cypress tests locally, you have two options.

...

For more information on running Cypress through the command line, please refer to the documentation.

Running coverage reports

While code coverage is currently disabled due to several known issues with Next.js, the SWC compiler and Cypress code coverage, the information below will be how it works when these issues have been resolved.

Our Cypress setup has code coverage reporting configured automatically through the cypress/code-coverage plugin. This will generate a code coverage report and save it to the coverage directory. However, if you want to see a summary of the code coverage after the tests have been run, run the following command.

...

  • patronRequests.cy.ts will serve as an example for testing a simple, data-grid displaying page.

  • agencies.cy.ts will serve as an example for testing a page with an additional form (the ‘add agencies form’)

Debugging

Cypress' documentation has an excellent guide to debugging that can be found here. The standard Developer Tools for your browser can be used in operation with Cypress, making debugging considerably easier.

Keeping the tests up-to-date

To keep our tests updated, a few key principles should be followed.

  • When a general set of test data is defined, it should be added to the relevant fixtures - these presently use data taken from dcb-dev.

  • When a page covered by tests is changed, the relevant tests should always be run and, if necessary, updated to test any new UI elements or functionality.

  • We should continually strive for greater test coverage. As such, we should ensure that all new features or pages have corresponding Cypress tests - this will ensure our code coverage isn’t reduced when new features are added.