Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/salesforce/sa11y
Salesforce Automated Accessibility Testing Libraries
https://github.com/salesforce/sa11y
accessibility accessibility-automation accessibility-testing automation axe javascript salesforce test
Last synced: 4 days ago
JSON representation
Salesforce Automated Accessibility Testing Libraries
- Host: GitHub
- URL: https://github.com/salesforce/sa11y
- Owner: salesforce
- License: bsd-3-clause
- Created: 2020-03-12T12:34:10.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2025-02-03T10:17:19.000Z (17 days ago)
- Last Synced: 2025-02-08T02:35:55.196Z (12 days ago)
- Topics: accessibility, accessibility-automation, accessibility-testing, automation, axe, javascript, salesforce, test
- Language: TypeScript
- Homepage: https://www.npmjs.com/org/sa11y
- Size: 6.55 MB
- Stars: 92
- Watchers: 12
- Forks: 23
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
- Code of conduct: CODE_OF_CONDUCT.md
- Codeowners: .github/CODEOWNERS
- Security: SECURITY.md
Awesome Lists containing this project
README
# Salesforce Accessibility Automation Libraries
Automated Accessibility Testing Libraries and Tools ([@sa11y packages](https://www.npmjs.com/org/sa11y)) based on [axe-core][axe] providing support for [Jest](#jest-integration) unit tests, [WebdriverIO](#wdio-integration) component/integration tests used by teams in Salesforce. However, they are not specific to Salesforce and can be used to test any UI [supported by axe-core](https://github.com/dequelabs/axe-core#supported-browsers) for accessibility. These libraries are designed to be flexible, customizable and reusable to support automated accessibility testing in different testing workflows from unit to integration tests.
data:image/s3,"s3://crabby-images/1929b/1929b26c3964f332029d52fe76468620f36a7c1b" alt="Sa11y"
[data:image/s3,"s3://crabby-images/5fd17/5fd1736c8d459958108ca8ffc7f5da3d9cd16072" alt="Code Coverage"](https://codecov.io/gh/salesforce/sa11y)
[data:image/s3,"s3://crabby-images/5ad30/5ad308df04a8d14c06ea614239e737a78785caf6" alt="semantic-release"](https://github.com/semantic-release/semantic-release)
[data:image/s3,"s3://crabby-images/ebe41/ebe418be415980ce19d4fb4bfc51f918acf14a92" alt="License"](./LICENSE.txt)
[data:image/s3,"s3://crabby-images/3f3e4/3f3e421e5daaa8c44c3f385e70994bfaff25eb73" alt="NPM downloads per month of @sa11y/common package"](https://www.npmtrends.com/@sa11y/common)
[data:image/s3,"s3://crabby-images/74ad2/74ad2b1c3827308ed2810a0b9c4533c8cc935de0" alt="Known Vulnerabilities"](https://snyk.io/test/github/salesforce/sa11y?targetFile=package.json)
[data:image/s3,"s3://crabby-images/6becc/6becccb3675952eb8d8740cbddd1fc496254329a" alt="OpenSSF Scorecard"](https://api.securityscorecards.dev/projects/github.com/salesforce/sa11y)- [Docs](#docs)
- [References](#references)
- [Packages](#packages)
- [Jest integration](#jest-integration)
- [WDIO integration](#wdio-integration)
- [assertAccessible API](#assertaccessible-api)
- [a11y results formatter](#a11y-results-formatter)
- [Preset accessibility rules](#preset-accessibility-rules)
- [Minified bundle for testing in browser](#minified-bundle-for-testing-in-browser)
- [Internal packages](#internal-packages)
- [Test utilities](#test-utilities)
- [Integration Tests](#integration-tests)
- [Common](#common)
- [Dependency graph](#dependency-graph)
- [Epilogue](#epilogue)## Docs
- [Developer Guidelines](./CONTRIBUTING.md)
- Refer to [Quick start](./CONTRIBUTING.md#quick-start) instructions to get started, if you are a developer looking to Contribute
- [Code of Conduct](./CODE_OF_CONDUCT.md)
- [Changelog](./CHANGELOG.md)
- [LICENSE](./LICENSE.txt)### References
- [Automated Accessibility Tests with sa11y | Developer Quick Takes - YouTube](https://www.youtube.com/watch?v=ScqZisOBbUM&list=PLgIMQe2PKPSJdFGHjGpjd1FbCsOqq5H8t&index=21)
- [Automated Accessibility Testing with sa11y | Salesforce Developers Blog](https://developer.salesforce.com/blogs/2020/10/automated-accessibility-testing-with-sa11y.html)
- [Get Started with Web Accessibility | Salesforce Trailhead](https://trailhead.salesforce.com/en/content/learn/trails/get-started-with-web-accessibility)
- [Accessibility Overview - Lightning Design System](https://www.lightningdesignsystem.com/accessibility/overview/)
- [LWC Accessibility guide](https://lwc.dev/guide/accessibility)## Packages
This repo contains the following packages for automated accessibility testing:
### [Jest integration](./packages/jest/README.md)
[data:image/s3,"s3://crabby-images/987cc/987cca9175f582086a6933d29dae61ca0d08df28" alt="published npm version of @sa11y/jest"](https://www.npmjs.com/package/@sa11y/jest)
data:image/s3,"s3://crabby-images/1dad9/1dad9fa12b486ae5126a6ce931440bb6a4ab4e97" alt="node-current (scoped)"- Provides a `toBeAccessible()` accessibility matcher for Jest
- integrates the [assertAccessible API](./packages/assert/README.md) with the [Jest assertion API](https://jestjs.io/docs/en/using-matchers)
- Provides an option to set up the sa11y API to be invoked automatically at the end of each test
- To add accessibility testing to your Jest tests use this packagedata:image/s3,"s3://crabby-images/063de/063dee2c99d98513286c3781dfc7229025caf30a" alt="Screenshot showing Sa11y Jest API usage and a11y errors showing up in VSCode"
### [WDIO integration](./packages/wdio/README.md)
[data:image/s3,"s3://crabby-images/89125/89125cfc12d489028eb93d77b2bf9b47a43a36aa" alt="published npm version of @sa11y/wdio"](https://www.npmjs.com/package/@sa11y/wdio)
data:image/s3,"s3://crabby-images/62358/6235812127ecfe231a16f9b350dc63924afe0414" alt="node-current (scoped)"- Provides `assertAccessible()`, `assertAccessibleSync()` APIs that can be used with [WebdriverIO](https://webdriver.io/) to check accessibility of web pages rendered in browsers
data:image/s3,"s3://crabby-images/ad330/ad330b712b02d388da6d291030f75e39b332dc11" alt="Screenshot showing a11y errors from a test using Sa11y WDIO in a terminal"
### [assertAccessible API](./packages/assert/README.md)
[data:image/s3,"s3://crabby-images/81a23/81a2374eb8422335be8c252c136b598dab370b74" alt="published npm version of @sa11y/assert"](https://www.npmjs.com/package/@sa11y/assert)
data:image/s3,"s3://crabby-images/1c95d/1c95d90b788a47ca436eaa145c4d7b4af52bee68" alt="node-current (scoped)"- Checks DOM or HTML Element for accessibility issues and throws an error if a11y issues are found
- To add accessibility testing to your Javascript unit tests _not_ using Jest, use this package### [a11y results formatter](./packages/format/README.md)
[data:image/s3,"s3://crabby-images/66ab3/66ab3b1e9b65185e04c2bf602ef0de8cbae29acb" alt="published npm version of @sa11y/format"](https://www.npmjs.com/package/@sa11y/format)
data:image/s3,"s3://crabby-images/5f663/5f663351da4346673d7c0e61eb4c23e64b3e2b4c" alt="node-current (scoped)"- Formats raw JSON output of a11y issues from [axe] into an easy to consume format by consolidating and cross-referencing
- Used by assert Accessible API and Jest a11y matcher
- To use axe directly and want to format the results from `axe.run` use this package
- A new formatter `groupViolationResultsProcessor` also made available to group the a11y violations per jest test case as the existing formatter would generate test failures for each violation### [Preset accessibility rules](./packages/preset-rules/README.md)
[data:image/s3,"s3://crabby-images/24773/24773e86459f099c62b19300432046d74b2710ce" alt="published npm version of @sa11y/preset-rules"](https://www.npmjs.com/package/@sa11y/preset-rules)
data:image/s3,"s3://crabby-images/95d81/95d81121be521d9cd6ad52157b26208f6b7f5fc1" alt="node-current (scoped)"- Provides Base, Extended, Full accessibility preset rules as [axe] configuration
- The Base preset rule is used by default in the Jest a11y matcher and assert Accessible APIs
- The APIs can be overridden to use the Extended or Full ruleset as necessary### [Minified bundle for testing in browser](./packages/browser-lib/README.md)
[data:image/s3,"s3://crabby-images/a063d/a063d836a10d6dfe62bd3c6812599666525468ed" alt="published npm version of @sa11y/browser-lib"](https://www.npmjs.com/package/@sa11y/browser-lib)
data:image/s3,"s3://crabby-images/5cf9f/5cf9ffd29a58436ad3953ddbe610512340f1c0a5" alt="node-current (scoped)"- Provides a minified version of selected `@sa11y` libraries to be injected into a browser (using webdriver) and executed from integration testing workflows.
- Gives WCAG SC for rulesets in addition with [axe] tags### Internal packages
#### [Test utilities](./packages/test-utils/README.md)
- Private package providing test utilities for `@sa11y` packages
#### [Integration Tests](./packages/test-integration/README.md)
- Private package providing integration tests for `@sa11y` packages
#### [Common](./packages/common/README.md)
- Common utilities, constants, error messages for `@sa11y` packages
### Dependency graph
data:image/s3,"s3://crabby-images/eabe4/eabe4b60063f79b689efd88a2eb3b913c33c5ebb" alt="Dependency graph of sa11y packages"
---
### Epilogue
A wise person once said…
_"Don't talk to me until I've had coffee and you've run axe"_
data:image/s3,"s3://crabby-images/d3612/d3612962c1f22991dd3de2c9b8bc22c4b05a2848" alt="Embroidery that says "Don't talk to me until I've had coffee and you've run axe" in a hoop"
(Image courtesy: [@shleewhite](https://github.com/shleewhite), [@jorycunningham](https://github.com/jorycunningham))
[axe]: https://github.com/dequelabs/axe-core