Guidepup is a screen reader driver for test automation.
It enables testing for VoiceOver on MacOS and NVDA on Windows with a single API.
- Full Control - If a screen reader has a keyboard command, then Guidepup supports it.
- Mirrors Real User Experience - Assert on what users really do and hear when using screen readers.
- Framework Agnostic - Run with Jest, with Playwright, as an independent script, no vendor lock-in.
Set up your environment for screen reader automation with @guidepup/setup
:
npx @guidepup/setup
Install Guidepup to your project:
npm install @guidepup/guidepup
And get cracking with your first screen reader automation code!
Head over to the Guidepup Website for guides, real world examples, environment setup, and complete API documentation with examples.
You can also check out these awesome examples to learn how you could use Guidepup in your projects.
Alternatively check out this project which runs several thousand tests to assert screen reader compatibility against W3C ARIA-AT test suite.
import { voiceOver } from "@guidepup/guidepup";
(async () => {
await voiceOver.start();
await voiceOver.next();
console.log(await voiceOver.spokenPhraseLog());
await voiceOver.stop();
})();
import { nvda } from "@guidepup/guidepup";
(async () => {
await nvda.start();
await nvda.next();
console.log(await nvda.spokenPhraseLog());
await nvda.stop();
})();
import { voiceOver } from "@guidepup/guidepup";
(async () => {
await voiceOver.start();
await voiceOver.perform(voiceOver.keyboardCommands.findNextHeading);
console.log(await voiceOver.itemText());
await voiceOver.perform(voiceOver.keyboardCommands.findNextControl);
console.log(await voiceOver.lastSpokenPhrase());
await voiceOver.stop();
})();
import { nvda } from "@guidepup/guidepup";
(async () => {
await nvda.start();
await nvda.perform(nvda.keyboardCommands.moveToNextHeading);
console.log(await nvda.itemText());
await nvda.perform(nvda.keyboardCommands.moveToNextFormField);
console.log(await nvda.lastSpokenPhrase());
await nvda.stop();
})();
Check out some of the other Guidepup modules:
@guidepup/setup
- Set up your local or CI environment for screen reader test automation.@guidepup/playwright
- Seemless integration of Guidepup with Playwright.@guidepup/virtual-screen-reader
- Reliable unit testing for your screen reader a11y workflows.@guidepup/jest
- Jest matchers for reliable unit testing of your screen reader a11y workflows.
If you are using GitHub Actions, check out the dedicated guidepup/setup-action
to set up your CI ready for screen reader automation:
- name: Set Up Environment For Screen Reader Automation
uses: guidepup/setup-action
Here are some similar unaffiliated projects: