Skip to content

Commit

Permalink
Merge branch 'main' into major-release
Browse files Browse the repository at this point in the history
  • Loading branch information
alessioventuriniAND committed Sep 9, 2024
2 parents 2d3fe20 + 07f4ee1 commit f64203e
Show file tree
Hide file tree
Showing 24 changed files with 493 additions and 265 deletions.
2 changes: 2 additions & 0 deletions .github/workflows/macro-and-script-tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,5 +18,7 @@ jobs:
node-version-file: '.nvmrc'
- name: Install dependencies
run: yarn install
- name: Clear jest cache
run: yarn test:clear-cache
- name: Run macro and script tests
run: yarn test
2 changes: 1 addition & 1 deletion .nvmrc
Original file line number Diff line number Diff line change
@@ -1 +1 @@
v20.10.0
v20.16.0
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -106,13 +106,13 @@ _Note_: This command is of limited use since JavaScript and SCSS files will only

It is sometimes useful to adjust the following settings when writing tests or diagnosing issues:

- `headless` in 'jest-puppeteer.config.js' - when set to `false` will show web browser whilst running tests. Many browser windows open since jest runs tests in parallel so it is useful to also adjust the `test` script inside 'package.json' such that it targets a specific test file. `await page.waitForTimeout(100000)` can be temporarily added to a test to allow yourself time to inspect the browser that appears.
- `headless` in 'jest-puppeteer.config.js' - when set to `false` will show web browser whilst running tests. Many browser windows open since jest runs tests in parallel so it is useful to also adjust the `test` script inside 'package.json' such that it targets a specific test file. `await new Promise(r => setTimeout(r, 100000));` can be temporarily added to a test to allow yourself time to inspect the browser that appears.

- `testTimeout` in 'jest.config.js' - set to a high value such as `1000000` to prevent tests from timing out when doing the above.

## Testing - Visual regression tests

This project uses [Backstop JS](https://github.com/garris/BackstopJS) for visual regression testing. The tests run in Chrome headless using pupeteer inside docker and run in three viewports; 1920 (desktop), 768 (tablet) and 375 (mobile). Reference images are stored in Git LFS and any approved changes will automatically be stored in Git LFS when pushed to the repository.
This project uses [Backstop JS](https://github.com/garris/BackstopJS) for visual regression testing. The tests run in Chrome headless using Pupeteer inside docker and run in three viewports; 1920 (desktop), 768 (tablet) and 375 (mobile). Reference images are stored in Git LFS and any approved changes will automatically be stored in Git LFS when pushed to the repository.

The visual tests will run automatically on pull requests and the result will be available in the Github Action logs. If the tests fail, the process for viewing the failures and approving changes will need to be handled locally using the following workflow and commands.

Expand Down
5 changes: 3 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
"start": "gulp start",
"watch": "gulp watch",
"test": "gulp build-assets && TEST_PORT=3020 TEST_WITH_PUPPETEER=1 jest '.*\\.spec\\.js'",
"test:clear-cache": "jest --clearCache",
"test:no-build": "TEST_PORT=3020 TEST_WITH_PUPPETEER=1 jest '.*\\.spec\\.js'",
"test:with-log": "yarn test --no-color 2>test.log",
"test:start-server": "TEST_PORT=3020 gulp start-dev-server",
Expand Down Expand Up @@ -98,7 +99,7 @@
"jest": "^29.6.1",
"jest-axe": "^8.0.0",
"jest-environment-jsdom": "^29.6.1",
"jest-puppeteer": "^9.0.0",
"jest-puppeteer": "^10.0.0",
"lighthouse": "^11.0.0",
"lint-staged": "^15.2.0",
"lodash": "^4.17.21",
Expand All @@ -111,7 +112,7 @@
"prepend-file": "^2.0.1",
"prettier": "^3.2.5",
"prettier-plugin-jinja-template": "^1.4.0",
"puppeteer": "^21.0.2",
"puppeteer": "^22.0.0",
"remark-cli": "^12.0.0",
"remark-lint": "^9.1.2",
"remark-preset-lint-recommended": "^6.1.3",
Expand Down
29 changes: 17 additions & 12 deletions src/components/address-input/autosuggest.address.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,8 @@ const EXAMPLE_ADDRESS_INPUT_WITH_API = {
externalInitialiser: true,
};

const { setTimeout } = require('node:timers/promises');

describe('script: address-input', () => {
const apiFaker = new PuppeteerEndpointFaker(EXAMPLE_ADDRESS_INPUT_WITH_API.apiDomain);

Expand Down Expand Up @@ -185,15 +187,15 @@ describe('script: address-input', () => {
describe('When the component initializes', () => {
it('checks api status by trying a request', async () => {
await setTestPage('/test', renderComponent('address-input', EXAMPLE_ADDRESS_INPUT_WITH_API));
await page.waitForTimeout(50);
await setTimeout(50);

expect(apiFaker.getRequestCount('/addresses/eq?input=cf142&limit=10')).toBe(1);
});

describe('when api status is okay', () => {
beforeEach(async () => {
await setTestPage('/test', renderComponent('address-input', EXAMPLE_ADDRESS_INPUT_WITH_API));
await page.waitForTimeout(50);
await setTimeout(50);
});

it('does not switch to manual input', async () => {
Expand All @@ -217,7 +219,7 @@ describe('script: address-input', () => {
});

await setTestPage('/test', renderComponent('address-input', EXAMPLE_ADDRESS_INPUT_WITH_API));
await page.waitForTimeout(50);
await setTimeout(50);
});

it('switches to manual input', async () => {
Expand Down Expand Up @@ -272,6 +274,7 @@ describe('script: address-input', () => {
});

it('has expected suggestion entries', async () => {
await setTimeout(100);
const suggestions = await page.$$eval('.ons-autosuggest__option', (nodes) => nodes.map((node) => node.textContent.trim()));
expect(suggestions).toEqual(['196 College Road, Birmingham, B44 8HF', '196 College Road, Whitchurch, Cardiff, CF14 2NZ']);
});
Expand Down Expand Up @@ -306,7 +309,7 @@ describe('script: address-input', () => {

await page.$eval('.ons-js-autosuggest-input', (node) => (node.value = 'Penlline Road, Whitchurch, Cardiff, CF14 2N'));
await page.type('.ons-js-autosuggest-input', 'Z');
await page.waitForTimeout(100);
await setTimeout(100);
});

it('provides expected parameters to the address API', async () => {
Expand All @@ -329,7 +332,7 @@ describe('script: address-input', () => {
beforeEach(async () => {
await page.keyboard.press('ArrowDown');
await page.keyboard.press('Enter');
await page.waitForTimeout(100);
await setTimeout(100);
});

it('makes expected request when a suggestion is selected', async () => {
Expand All @@ -353,7 +356,7 @@ describe('script: address-input', () => {

await page.$eval('.ons-js-autosuggest-input', (node) => (node.value = 'CF14 '));
await page.type('.ons-js-autosuggest-input', '2');
await page.waitForTimeout(200);
await setTimeout(200);
});

it('provides expected parameters to the address API', async () => {
Expand All @@ -372,7 +375,7 @@ describe('script: address-input', () => {
beforeEach(async () => {
await page.keyboard.press('ArrowDown');
await page.keyboard.press('Enter');
await page.waitForTimeout(200);
await setTimeout(200);
});

it('makes expected request', async () => {
Expand All @@ -394,7 +397,7 @@ describe('script: address-input', () => {
beforeEach(async () => {
await page.keyboard.press('ArrowDown');
await page.keyboard.press('Enter');
await page.waitForTimeout(200);
await setTimeout(200);
});

it('populates manual input fields with address from selection', async () => {
Expand Down Expand Up @@ -438,7 +441,7 @@ describe('script: address-input', () => {
await page.type('.ons-js-autosuggest-input', '2', { delay: 20 });
await page.keyboard.press('ArrowDown');
await page.keyboard.press('Enter');
await page.waitForTimeout(100);
await setTimeout(100);

const isManualElementHidden = await page.$eval('.ons-js-address-input__manual', (node) =>
node.classList.contains('ons-u-db-no-js_enabled'),
Expand Down Expand Up @@ -481,7 +484,7 @@ describe('script: address-input', () => {
await page.type('.ons-js-autosuggest-input', 'T', { delay: 20 });
await page.keyboard.press('ArrowDown');
await page.keyboard.press('Enter');
await page.waitForTimeout(100);
await setTimeout(100);

const urpnValueBefore = await page.$eval('.ons-js-hidden-uprn', (node) => node.value);
expect(urpnValueBefore).toBe('100070332099');
Expand Down Expand Up @@ -620,7 +623,7 @@ describe('script: address-input', () => {
await page.keyboard.press('ArrowDown');
await page.keyboard.press('Enter');

await page.waitForTimeout(50);
await setTimeout(50);
});

it('then the retrieveAddress function will be called', async () => {
Expand Down Expand Up @@ -731,6 +734,8 @@ describe('script: address-input', () => {
await page.$eval('.ons-js-autosuggest-input', (node) => (node.value = '196 coll'));
await page.type('.ons-js-autosuggest-input', 'e');

await setTimeout(50);

expect(apiFaker.getRequestCount(searchEndpoint)).toBe(1);
});

Expand All @@ -740,7 +745,7 @@ describe('script: address-input', () => {
await page.keyboard.press('ArrowDown');
await page.keyboard.press('Enter');

await page.waitForTimeout(50);
await setTimeout(50);

expect(apiFaker.getRequestCount(uprnEndpoint)).toBe(1);
});
Expand Down
12 changes: 7 additions & 5 deletions src/components/autosuggest/autosuggest.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,8 @@ const EXAMPLE_AUTOSUGGEST_WITH_LANGUAGE = {
language: 'en-gb',
};

const { setTimeout } = require('node:timers/promises');

describe('script: autosuggest', () => {
const apiFaker = new PuppeteerEndpointFaker('/test/fake/api');

Expand Down Expand Up @@ -298,11 +300,11 @@ describe('script: autosuggest', () => {
const suggestionCountSample1 = await page.$$eval('.ons-autosuggest__option', (nodes) => nodes.length);
expect(suggestionCountSample1).toBe(2);

await page.waitForTimeout(200);
await setTimeout(200);
const suggestionCountSample2 = await page.$$eval('.ons-autosuggest__option', (nodes) => nodes.length);
expect(suggestionCountSample2).toBe(2);

await page.waitForTimeout(320);
await setTimeout(320);
const suggestionCountSample3 = await page.$$eval('.ons-autosuggest__option', (nodes) => nodes.length);
expect(suggestionCountSample3).toBe(0);
});
Expand All @@ -312,7 +314,7 @@ describe('script: autosuggest', () => {

await page.type('.ons-js-autosuggest-input', 'Unite', { delay: 20 });
await page.keyboard.press('Tab');
await page.waitForTimeout(320);
await setTimeout(320);

const listboxInnerHTML = await page.$eval('.ons-js-autosuggest-listbox', (node) => node.innerHTML);
expect(listboxInnerHTML).toBe('');
Expand All @@ -323,7 +325,7 @@ describe('script: autosuggest', () => {

await page.type('.ons-js-autosuggest-input', 'Unite', { delay: 20 });
await page.keyboard.press('Tab');
await page.waitForTimeout(320);
await setTimeout(320);

const hasClass = await page.$eval('.ons-autosuggest', (node) => node.classList.contains('ons-autosuggest--has-results'));
expect(hasClass).toBe(false);
Expand All @@ -334,7 +336,7 @@ describe('script: autosuggest', () => {

await page.type('.ons-js-autosuggest-input', 'Unite', { delay: 20 });
await page.keyboard.press('Tab');
await page.waitForTimeout(320);
await setTimeout(320);

const attributes = await getNodeAttributes(page, '.ons-js-autosuggest-input');
expect(attributes['aria-activedescendant']).toBeUndefined();
Expand Down
6 changes: 4 additions & 2 deletions src/components/back-to-top/back-to-top.spec.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion src/components/cookies-banner/cookies-banner.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ const EXAMPLE_COOKIES_BANNER_PAGE = renderComponent('cookies-banner', {});

describe('script: cookies-banner', () => {
beforeEach(async () => {
const client = await page.target().createCDPSession();
const client = await page.createCDPSession();
await client.send('Network.clearBrowserCookies');
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,8 @@ const EXAMPLE_MUTUALLY_EXCLUSIVE_CHECKBOXES_PARAMS = {
},
};

const { setTimeout } = require('node:timers/promises');

describe('script: mutually-exclusive', () => {
describe('checkboxes', () => {
beforeEach(async () => {
Expand Down Expand Up @@ -93,7 +95,7 @@ describe('script: mutually-exclusive', () => {
});

it('then the aria-live message should reflect the removed non exclusive options', async () => {
await page.waitForTimeout(SCREEN_READER_TIMEOUT_DELAY);
await setTimeout(SCREEN_READER_TIMEOUT_DELAY);

const alertText = await page.$eval('.ons-js-exclusive-alert', (node) => node.textContent);
expect(alertText).toBe('Gas deselected. Electric deselected. Other deselected. Please specify deselected.');
Expand Down Expand Up @@ -125,7 +127,7 @@ describe('script: mutually-exclusive', () => {
});

it('then the aria-live message should reflect the removed exclusive option', async () => {
await page.waitForTimeout(SCREEN_READER_TIMEOUT_DELAY);
await setTimeout(SCREEN_READER_TIMEOUT_DELAY);

const alertText = await page.$eval('.ons-js-exclusive-alert', (node) => node.textContent);
expect(alertText).toBe('No central heating deselected.');
Expand All @@ -137,7 +139,7 @@ describe('script: mutually-exclusive', () => {
});

it('the aria-live message should not be updated', async () => {
await page.waitForTimeout(SCREEN_READER_TIMEOUT_DELAY);
await setTimeout(SCREEN_READER_TIMEOUT_DELAY);

const alertText = await page.$eval('.ons-js-exclusive-alert', (node) => node.textContent);
expect(alertText).toBe('No central heating deselected.');
Expand Down Expand Up @@ -166,7 +168,7 @@ describe('script: mutually-exclusive', () => {
});

it('then the aria-live message should say nothing', async () => {
await page.waitForTimeout(SCREEN_READER_TIMEOUT_DELAY);
await setTimeout(SCREEN_READER_TIMEOUT_DELAY);

const alertText = await page.$eval('.ons-js-exclusive-alert', (node) => node.textContent);
expect(alertText).toBe('');
Expand All @@ -192,7 +194,7 @@ describe('script: mutually-exclusive', () => {
});

it('then the aria-live message should say nothing', async () => {
await page.waitForTimeout(SCREEN_READER_TIMEOUT_DELAY);
await setTimeout(SCREEN_READER_TIMEOUT_DELAY);

const alertText = await page.$eval('.ons-js-exclusive-alert', (node) => node.textContent);
expect(alertText).toBe('');
Expand Down
Loading

0 comments on commit f64203e

Please sign in to comment.