1. eslint-plugin-jest-dom
ESLint plugin to follow best practices and anticipate common mistakes when writing tests with jest-dom
eslint-plugin-jest-dom
Package: eslint-plugin-jest-dom
Created by: testing-library
Last modified: Fri, 19 Apr 2024 23:56:05 GMT
Version: 5.4.0
License: MIT
Downloads: 4,071,301
Repository: https://github.com/testing-library/eslint-plugin-jest-dom

Install

npm install eslint-plugin-jest-dom
yarn add eslint-plugin-jest-dom

eslint-plugin-jest-dom

ESLint plugin to follow best practices and anticipate common mistakes when writing tests with jest-dom.


Build Status
Code Coverage
version
downloads
MIT License
All Contributors
PRs Welcome
Code of Conduct

Table of Contents

Installation

This module is distributed via npm which is bundled with node and
should be installed as one of your project's devDependencies:

npm install --save-dev eslint-plugin-jest-dom

This library has a required peerDependencies listing for ESLint.

Usage

[!NOTE]

eslint.config.js is supported, though most of the plugin documentation still
currently uses .eslintrc syntax; compatible versions of configs are available
prefixed with flat/ and may be subject to small breaking changes while ESLint
v9 is being finalized.

Refer to the
ESLint documentation on the new configuration file format
for more.

Add jest-dom to the plugins section of your .eslintrc.js configuration file.
You can omit the eslint-plugin- prefix:

 module.exports = {
  plugins: ["jest-dom"],
  rules: {
    // your configuration
  },
};

Then configure the rules you want to use under the rules section.

 module.exports = {
  rules: {
    "jest-dom/prefer-checked": "error",
    "jest-dom/prefer-enabled-disabled": "error",
    "jest-dom/prefer-required": "error",
    "jest-dom/prefer-to-have-attribute": "error",
  },
};

This plugin exports a recommended configuration that enforces good jest-dom
practices (you can find more info about enabled rules in
Supported Rules section)
.

To enable this configuration with .eslintrc, use the extends property:

 module.exports = {
  extends: "plugin:jest-dom/recommended",
  rules: {
    // your configuration
  },
};

To enable this configuration with eslint.config.js, use
jestDom.configs['flat/recommended']:

 module.exports = [
  {
    files: [
      /* glob matching your test files */
    ],
    ...require("eslint-plugin-jest-dom").configs["flat/recommended"],
  },
];

Supported Rules

๐Ÿ’ผ Configurations enabled in.
โœ… Set in the recommended configuration.
๐Ÿ”ง Automatically fixable by the --fix CLI option.
๐Ÿ’ก Manually fixable by editor suggestions.

Name Description ๐Ÿ’ผ ๐Ÿ”ง ๐Ÿ’ก
prefer-checked prefer toBeChecked over checking attributes โœ… ๐Ÿ”ง
prefer-empty Prefer toBeEmpty over checking innerHTML โœ… ๐Ÿ”ง
prefer-enabled-disabled prefer toBeDisabled or toBeEnabled over checking attributes โœ… ๐Ÿ”ง
prefer-focus prefer toHaveFocus over checking document.activeElement โœ… ๐Ÿ”ง
prefer-in-document Prefer .toBeInTheDocument() for asserting the existence of a DOM node โœ… ๐Ÿ”ง ๐Ÿ’ก
prefer-required prefer toBeRequired over checking properties โœ… ๐Ÿ”ง
prefer-to-have-attribute prefer toHaveAttribute over checking getAttribute/hasAttribute โœ… ๐Ÿ”ง
prefer-to-have-class prefer toHaveClass over checking element className โœ… ๐Ÿ”ง
prefer-to-have-style prefer toHaveStyle over checking element style โœ… ๐Ÿ”ง
prefer-to-have-text-content Prefer toHaveTextContent over checking element.textContent โœ… ๐Ÿ”ง
prefer-to-have-value prefer toHaveValue over checking element.value โœ… ๐Ÿ”ง

Issues

Looking to contribute? Look for the Good First Issue
label.

๐Ÿ› Bugs

Please file an issue for bugs, missing documentation, or unexpected behavior.

See Bugs

๐Ÿ’ก Feature Requests

Please file an issue to suggest new features. Vote on feature requests by adding
a ๐Ÿ‘. This helps maintainers prioritize what to work on.

See Feature Requests

Contributors โœจ

Thanks goes to these people (emoji key):


Ben Monro

๐Ÿ“– ๐Ÿ’ป ๐Ÿ’ก โš ๏ธ

Nick McCurdy

๐Ÿ’ป ๐Ÿ“– โš ๏ธ

Ernesto Garcรญa

๐Ÿ“–

Chris Colborne

๐Ÿ’ป โš ๏ธ

Michaรซl De Boey

๐Ÿ’ป

Gerrit Alex

๐Ÿ’ป โš ๏ธ ๐Ÿ“– ๐Ÿ›

Andrey Los

๐Ÿ›

Spencer Miskoviak

๐Ÿ’ป โš ๏ธ

Aleksei Tsikov

๐Ÿ›

Mario Beltrรกn Alarcรณn

๐Ÿ“–

Ari Perkkiรถ

๐Ÿ› ๐Ÿ’ป โš ๏ธ

Anton Niklasson

๐Ÿ’ป โš ๏ธ ๐Ÿ“–

Juzer Zarif

๐Ÿ’ป โš ๏ธ ๐Ÿ›

Julien Wajsberg

๐Ÿ’ป โš ๏ธ

Gareth Jones

โš ๏ธ ๐Ÿ’ป ๐Ÿ›

Huyen Nguyen

๐Ÿ“–

Matthew

๐Ÿ› ๐Ÿ’ป

This project follows the all-contributors specification.
Contributions of any kind welcome!

LICENSE

MIT

RELATED POST

10 Must-Know Windows Shortcuts That Will Save You Time

10 Must-Know Windows Shortcuts That Will Save You Time

Arrays vs Linked Lists: Which is Better for Memory Management in Data Structures?

Arrays vs Linked Lists: Which is Better for Memory Management in Data Structures?

Navigating AWS Networking: Essential Hacks for Smooth Operation

Navigating AWS Networking: Essential Hacks for Smooth Operation

Achieving Stunning Visuals with Unity's Global Illumination

Achieving Stunning Visuals with Unity's Global Illumination

Nim's Hidden Gems: Lesser-known Features for Writing Efficient Code

Nim's Hidden Gems: Lesser-known Features for Writing Efficient Code