Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@sa11y/jest

Package Overview
Dependencies
Maintainers
1
Versions
85
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@sa11y/jest

Accessibility testing libraries integration with Jest

  • 0.1.1-alpha
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
12K
increased by2.16%
Maintainers
1
Weekly downloads
 
Created
Source

jest

Accessibility matcher for Jest

Setup

The accessibility matcher helper APIs need to be registered with Jest before they can be used in tests.

Project level

You can set up the a11y matchers once at the project level to make it available to all the Jest tests in the project. For an example look at the Integration tests.

  • Add a Jest setup file (e.g. jest-setup.js) and add the following code that registers the a11y matchers
const { registerSa11yMatcher } = require('@sa11y/jest');
registerSa11yMatcher();
  • Add/Modify Jest config at project root to invoke the Jest setup file as setup above. In the jest.config.js at the root of your project, add:
module.exports = {
    setupFilesAfterEnv: ['<rootDir>/jest-setup.js'],
};

Test module level

Invoke registerSa11yMatcher before using the accessibility matchers in the tests e.g.

import { registerSa11yMatcher } from '@sa11y/jest';

beforeAll(() => {
    registerSa11yMatcher();
});

Usage

  • WARNING: toBeAccessible must be invoked with await or the equivalent supported async method in your env.
    • Not invoking it async would result in incorrect results
    • e.g. no assertions even when page is not accessible
  • toBeAccessible jest matcher can be invoked on a document (JSDOM) or an HTML element to check for accessibility
import { recommended } from '@sa11y/preset-rules';
import { registerSa11yMatcher } from '@sa11y/jest';

beforeAll(() => {
    registerSa11yMatcher();
});

it('should be accessible', async () => {
    // Setup DOM to be tested for accessibility
    //...

    // assert that DOM is accessible (using extended preset-rule)
    await expect(document).toBeAccessible();

    // Can be used to test accessibility of a specific HTML element
    const elem = document.getElementById('foo');
    await expect(elem).toBeAccessible();

    // use recommended preset-rule
    await expect(document).toBeAccessible(recommended);
});

Keywords

FAQs

Package last updated on 03 Jun 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc