The CI lints SASS and JavaScript, and runs unit and functional tests with Node.
To check the whole codebase, run:
npm test
This will trigger standard and stylelint for linting, and Jest for unit and functional tests.
See Tasks for details of what npm test
does.
See CSS Coding Standards for details.
See JavaScript Coding Standards for details.
We use Jest, an automated testing platform with an assertion library, and Puppeteer that is used to control headless Chrome.
We test individual components and for instance global Sass files. See all.test.js. for examples of global tests we run, and checkboxes.test.js for an example of component tests.
We aim to write the description of our tests in as "natural language" as possible, for instance "back-link component fails to render if the required fields are not included".
You can run a subset of the test suite that only tests components by running:
`npm test -- src/govuk/components/button`
Note: There's a watch mode that keeps a testing session open waiting for changes that can be used with:
`npm test -- --watch src/govuk/components/button`
Snapshot tests are used for preventing unintended changes - when the snapshot test runs, it compares the previously captured snapshot to the current markup. For components, the snapshots are stored in [component-name directory]/_snapshots_
.
If a snapshot test fails, review the difference in the console. If the change is the correct change to make, run:
npm test -- -u src/govuk/components/button
This will update the snapshot file. Commit this file separately with a commit message that explains you're updating the snapshot file and an explanation of what caused the change.