-
Notifications
You must be signed in to change notification settings - Fork 55
Accessibility Auditing
Accessibility is a primary concern in keeping SimpleReport available and delightful to all users. SimpleReport uses a combination of methods to ensure the application satisfies accessibility requirements. These include:
- Manual audits with a variety of tools
- Lighthouse page testing
- Automated user flow tests, utilizing cypress axe
Manual audits are a good way to confirm that automated testing is catching errors properly, and to test accessibility implementation locally. This can be done with the official Axe toolkit from Deque, which can be run manually as a browser dev tools extension or utilized to run automated guided tests as well.
Other useful browser extensions for local testing:
Lighthouse is an open-source tool developed by google to improve the quality of web apps. While there are 5 categories that can be audited with Lighthouse testing, SimpleReport utilizes only the accessibility and performance categories. Lighthouse audits run on a provided url (or list of urls), and return results for the specified page. The accessibility results do not seem to be as granular as Axe tests, but provide an easy way to catch egregious regressions in the app.
Note that Lighthouse provides two tools for running Lighthouse tests, lighthouse, which is a CLI tool, and lighthouse-ci (aka lhci), which is another CLI tool optimized for CI configuration. SimpleReport utlilizes lighthouse-ci for testing in CI/CD pipelines. See SimpleReport's Github action and configuration for Lighthouse.
- lighthouse-ci configuration
- lighthouse cli options, which can be added to settings in lighthouse-ci configuration
SimpleReport utilizes the cypress-axe and axe-core npm packages to configure accessibility testing in cypress e2e tests. The axe tests reliably catch errors and produce few to no false positives. These tests are run on each PR in the CI/CD pipeline, and can also be run locally. See the Cypress wiki page.
To test the accessibility on a page, after visting a page with cy.visit()
, simply inject axe and check accessibility, like so:
cy.injectAxe();
cy.checkA11y();
The Deque blog has a good blog post for setting up axe in cypress.
It is possible, though generally not recommended, to exclude components or set rules to ignore certain errors. See the official GitHub repo docs and this helpful blog.
Gotchas - When adding accessibility checks in cypress, it's best to wait to call cy.checkA11y()
until you confirm the page has loaded, otherwise the check may fail in unexpected and incorrect ways. They are most reliable directly after an assertion like .get
or .contains
that does not do an action (like a .click
) that changes the page.
Also worth noting, because cypress will retry a test if it fails, note that when it re-runs after an accessibility failure, the second run will fail for a different reason.
For the future... There are a variety of other ways to implement automated accessibility testing. This article outlines a few options for GitHub actions.
- Getting Started
- [Setup] Docker and docker compose development
- [Setup] IntelliJ run configurations
- [Setup] Running DB outside of Docker (optional)
- [Setup] Running nginx locally (optional)
- [Setup] Running outside of docker
- Accessing and testing weird parts of the app on local dev
- Accessing patient experience in local dev
- API Testing with Insomnia
- Cypress
- How to run e2e locally for development
- E2E tests
- Database maintenance
- MailHog
- Running tests
- SendGrid
- Setting up okta
- Sonar
- Storybook and Chromatic
- Twilio
- User roles
- Wiremock
- CSV Uploader
- Log local DB queries
- Code review and PR conventions
- SimpleReport Style Guide
- How to Review and Test Pull Requests for Dependabot
- How to Review and Test Pull Requests with Terraform Changes
- SimpleReport Deployment Process
- Adding a Developer
- Removing a developer
- Non-deterministic test tracker
- Alert Response - When You Know What is Wrong
- What to Do When You Have No Idea What is Wrong
- Main Branch Status
- Maintenance Mode
- Swapping Slots
- Monitoring
- Container Debugging
- Debugging the ReportStream Uploader
- Renew Azure Service Principal Credentials
- Releasing Changelog Locks
- Muting Alerts
- Architectural Decision Records
- Backend Stack Overview
- Frontend Overview
- Cloud Architecture
- Cloud Environments
- Database ERD
- External IDs
- GraphQL Flow
- Hibernate Lazy fetching and nested models
- Identity Verification (Experian)
- Spring Profile Management
- SR Result bulk uploader device validation logic
- Test Metadata and how we store it
- TestOrder vs TestEvent
- ReportStream Integration
- Feature Flag Setup
- FHIR Resources
- FHIR Conversions
- Okta E2E Integration
- Deploy Application Action
- Slack notifications for support escalations
- Creating a New Environment Within a Resource Group
- How to Add and Use Environment Variables in Azure
- Web Application Firewall (WAF) Troubleshooting and Maintenance
- How to Review and Test Pull Requests with Terraform Changes