Skip to content

kantega/playwright-for-uu

Repository files navigation

Example project for a11y testing with Playwright

Goal is to show how simple it can be to set up a simple accessibility testing for any web page. With just two targeted tests, we aim to address many of the common a11y pitfalls in web app development also ensuring that developers prioritize accessibility in every stage of the development process. The Aria snapshot ensures correct structure on the page while Axe analyze checks common problems

Running the app

npm install
npm start

Running tests

npm ci
npm run uitest

If you get en error Error: browserType.launch: Executable doesn't exist, run

npx playwright install

to install Playwright's browsers on your machine (this needs to be done only once).

Aria snapshots

To create new aria snapshot use npm run uitest-codegen, then navigate to your page and use "Assert snapshot" from the top toolbar. It will generate a test script that you can copy-paste. (read more about Playwright's Codegen here)

To update all snapshot use npx playwright test --update-snapshots

Read more about aria snapshots in docs

A11y testing

Check 'should not have any automatically detectable accessibility issues' test to see how to run simple Axe analyze and discover any violations. Read more in docs

Other

This project was bootstrapped with Create React App.

Note

Some accessibility issues Playwright did not detect (but the Chrome extension Wave did)

  • The search field is missing a label
  • Label-elements are used (below the images) without being associated with an input field
  • All the images are using the same alt-text

Example of what neither tools detected

  • The lang attribute is set to "en," but the language of the page is Norwegian. This is especially important for screen readers to ensure correct interpretation.

About

Eksempelside for oppsett av Playwright for testing av Universell Utforming.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published