Skip to content

This is an experiment based on Accessibility Object Model (AOM). It tries to demonstrate that it is theoretically possible (in a certain way) to predict what the screen reader will say by focusing on semantic and non semantic elements with a bit of automated testing, thus reducing the need for manual testing.

License

Notifications You must be signed in to change notification settings

jonathanlinat/accessible-name-automation-proof-of-concept

Repository files navigation

Accessible Name Automation (Proof of Concept)

Netlify Status

This is an experiment based on set of changes to HTML and related standards called Accessibility Object Model (AOM).

It mainly uses the experimental global method window.getComputedAccessibleNode(node).

Such project tries to demonstrate that it is theoretically possible (in a certain way) to predict what the screen reader will say by focusing on semantic and non semantic elements with a bit of automated testing, thus reducing the need for manual testing.

Check out the demo website!

Motivation

To get more details about this experiment and its principles, please check the file called EXPLAINER.pdf located at the root of the current repository.

Details

This project includes, among others, the following:

  • React
  • Babel
  • ESLint
  • Styled Components
  • Styled Reset
  • Jest
  • Jest Puppeteer
  • Pa11y CI
  • Webpack

Tests are declared into ./src/app/wrapper/app.accessiblename.spec.js.

Prerequisites

  • Node v12.16.3
  • NPM v6.14.8
  • Git

First steps

Clone locally the repository.

cd <path/to/your/desired/folder/>
git clone [email protected]:jonathanlinat/accessible-name-automation-proof-of-concept.git

Install the dependencies.

cd accessible-name-automation-proof-of-concept/
npm install

Specific commands

Start a local demo.

npm run start:dev

Execute Accessible name tests (semantics) (getComputedAccessibleNode()).

npm run test:a11y:accessiblename

Execute Accessibility violation tests (axe-core).

npm run test:a11y:violations

Review generated test report.

npm run review:report

Compile the project.

npm run build

About

This is an experiment based on Accessibility Object Model (AOM). It tries to demonstrate that it is theoretically possible (in a certain way) to predict what the screen reader will say by focusing on semantic and non semantic elements with a bit of automated testing, thus reducing the need for manual testing.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published