You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					1239 lines
				
				50 KiB
			
		
		
			
		
	
	
					1239 lines
				
				50 KiB
			| 
											5 years ago
										 | <div align="center"> | ||
|  | <h1>jest-dom</h1> | ||
|  | 
 | ||
|  | <a href="https://www.emojione.com/emoji/1f989"> | ||
|  |   <img | ||
|  |     height="80" | ||
|  |     width="80" | ||
|  |     alt="owl" | ||
|  |     src="https://raw.githubusercontent.com/testing-library/jest-dom/master/other/owl.png" | ||
|  |   /> | ||
|  | </a> | ||
|  | 
 | ||
|  | <p>Custom jest matchers to test the state of the DOM</p> | ||
|  | 
 | ||
|  | </div> | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | [![Build Status][build-badge]][build] | ||
|  | [![Code Coverage][coverage-badge]][coverage] | ||
|  | [![version][version-badge]][package] [![downloads][downloads-badge]][npmtrends] | ||
|  | [![MIT License][license-badge]][license] | ||
|  | 
 | ||
|  | [](#contributors-) | ||
|  | [![PRs Welcome][prs-badge]][prs] [![Code of Conduct][coc-badge]][coc] | ||
|  | 
 | ||
|  | [![Watch on GitHub][github-watch-badge]][github-watch] | ||
|  | [![Star on GitHub][github-star-badge]][github-star] | ||
|  | [![Tweet][twitter-badge]][twitter] | ||
|  | 
 | ||
|  | ## The problem
 | ||
|  | 
 | ||
|  | You want to use [jest][] to write tests that assert various things about the | ||
|  | state of a DOM. As part of that goal, you want to avoid all the repetitive | ||
|  | patterns that arise in doing so. Checking for an element's attributes, its text | ||
|  | content, its css classes, you name it. | ||
|  | 
 | ||
|  | ## This solution
 | ||
|  | 
 | ||
|  | The `@testing-library/jest-dom` library provides a set of custom jest matchers | ||
|  | that you can use to extend jest. These will make your tests more declarative, | ||
|  | clear to read and to maintain. | ||
|  | 
 | ||
|  | ## Table of Contents
 | ||
|  | 
 | ||
|  | <!-- START doctoc generated TOC please keep comment here to allow auto update --> | ||
|  | <!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE --> | ||
|  | 
 | ||
|  | - [Installation](#installation) | ||
|  | - [Usage](#usage) | ||
|  | - [Custom matchers](#custom-matchers) | ||
|  |   - [`toBeDisabled`](#tobedisabled) | ||
|  |   - [`toBeEnabled`](#tobeenabled) | ||
|  |   - [`toBeEmpty`](#tobeempty) | ||
|  |   - [`toBeInTheDocument`](#tobeinthedocument) | ||
|  |   - [`toBeInvalid`](#tobeinvalid) | ||
|  |   - [`toBeRequired`](#toberequired) | ||
|  |   - [`toBeValid`](#tobevalid) | ||
|  |   - [`toBeVisible`](#tobevisible) | ||
|  |   - [`toContainElement`](#tocontainelement) | ||
|  |   - [`toContainHTML`](#tocontainhtml) | ||
|  |   - [`toHaveAttribute`](#tohaveattribute) | ||
|  |   - [`toHaveClass`](#tohaveclass) | ||
|  |   - [`toHaveFocus`](#tohavefocus) | ||
|  |   - [`toHaveFormValues`](#tohaveformvalues) | ||
|  |   - [`toHaveStyle`](#tohavestyle) | ||
|  |   - [`toHaveTextContent`](#tohavetextcontent) | ||
|  |   - [`toHaveValue`](#tohavevalue) | ||
|  |   - [`toBeChecked`](#tobechecked) | ||
|  | - [Deprecated matchers](#deprecated-matchers) | ||
|  |   - [`toBeInTheDOM`](#tobeinthedom) | ||
|  | - [Inspiration](#inspiration) | ||
|  | - [Other Solutions](#other-solutions) | ||
|  | - [Guiding Principles](#guiding-principles) | ||
|  | - [Contributors](#contributors) | ||
|  | - [LICENSE](#license) | ||
|  | 
 | ||
|  | <!-- END doctoc generated TOC please keep comment here to allow auto update --> | ||
|  | 
 | ||
|  | ## Installation
 | ||
|  | 
 | ||
|  | This module is distributed via [npm][npm] which is bundled with [node][node] and | ||
|  | should be installed as one of your project's `devDependencies`: | ||
|  | 
 | ||
|  | ``` | ||
|  | npm install --save-dev @testing-library/jest-dom | ||
|  | ``` | ||
|  | 
 | ||
|  | > Note: We also recommend installing the jest-dom eslint plugin which provides auto-fixable lint rules 
 | ||
|  | > that prevent false positive tests and improve test readability by ensuring you are using the right
 | ||
|  | > matchers in your tests.  More details can be found at
 | ||
|  | > [eslint-plugin-jest-dom](https://github.com/testing-library/eslint-plugin-jest-dom).
 | ||
|  | 
 | ||
|  | ## Usage
 | ||
|  | 
 | ||
|  | Import `@testing-library/jest-dom/extend-expect` once (for instance in your | ||
|  | [tests setup file][]) and you're good to go: | ||
|  | 
 | ||
|  | [tests setup file]: | ||
|  |   https://jestjs.io/docs/en/configuration.html#setupfilesafterenv-array | ||
|  | 
 | ||
|  | ```javascript | ||
|  | import '@testing-library/jest-dom/extend-expect' | ||
|  | ``` | ||
|  | 
 | ||
|  | > Note: If you're using TypeScript, make sure your setup file is a `.ts` and not
 | ||
|  | > a `.js` to include the necessary types.
 | ||
|  | 
 | ||
|  | Alternatively, you can selectively import only the matchers you intend to use, | ||
|  | and extend jest's `expect` yourself: | ||
|  | 
 | ||
|  | ```javascript | ||
|  | import {toBeInTheDocument, toHaveClass} from '@testing-library/jest-dom' | ||
|  | 
 | ||
|  | expect.extend({toBeInTheDocument, toHaveClass}) | ||
|  | ``` | ||
|  | 
 | ||
|  | > Note: when using TypeScript, this way of importing matchers won't provide the
 | ||
|  | > necessary type definitions. More on this
 | ||
|  | > [here](https://github.com/testing-library/jest-dom/pull/11#issuecomment-387817459).
 | ||
|  | 
 | ||
|  | ## Custom matchers
 | ||
|  | 
 | ||
|  | `@testing-library/jest-dom` can work with any library or framework that returns | ||
|  | DOM elements from queries. The custom matcher examples below demonstrate using | ||
|  | `document.querySelector` and | ||
|  | [DOM Testing Library](https://github.com/testing-library/dom-testing-library) | ||
|  | for querying DOM elements. | ||
|  | 
 | ||
|  | ### `toBeDisabled`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toBeDisabled() | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to check whether an element is disabled from the user's | ||
|  | perspective. | ||
|  | 
 | ||
|  | It matches if the element is a form control and the `disabled` attribute is | ||
|  | specified on this element or the element is a descendant of a form element with | ||
|  | a `disabled` attribute. | ||
|  | 
 | ||
|  | According to the specification, the following elements can be | ||
|  | [actually disabled](https://html.spec.whatwg.org/multipage/semantics-other.html#disabled-elements): | ||
|  | `button`, `input`, `select`, `textarea`, `optgroup`, `option`, `fieldset`. | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <button data-testid="button" type="submit" disabled>submit</button> | ||
|  | <fieldset disabled><input type="text" data-testid="input" /></fieldset> | ||
|  | <a href="..." disabled>link</a> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect(document.querySelector('[data-testid="button"]')).toBeDisabled() | ||
|  | expect(document.querySelector('[data-testid="input"]')).toBeDisabled() | ||
|  | expect(document.querySelector('a')).not.toBeDisabled() | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect(getByTestId(container, 'button')).toBeDisabled() | ||
|  | expect(getByTestId(container, 'input')).toBeDisabled() | ||
|  | expect(getByText(container, 'link')).not.toBeDisabled() | ||
|  | ``` | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toBeEnabled`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toBeEnabled() | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to check whether an element is not disabled from the user's | ||
|  | perspective. | ||
|  | 
 | ||
|  | It works like `not.toBeDisabled()`. Use this matcher to avoid double negation in | ||
|  | your tests. | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toBeEmpty`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toBeEmpty() | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to assert whether an element has content or not. | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <span data-testid="not-empty"><span data-testid="empty"></span></span> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect(document.querySelector('[data-testid="empty"]').toBeEmpty() | ||
|  | expect(document.querySelector('[data-testid="not-empty"]').not.toBeEmpty() | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect(queryByTestId(container, 'empty')).toBeEmpty() | ||
|  | expect(queryByTestId(container, 'not-empty')).not.toBeEmpty() | ||
|  | ``` | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toBeInTheDocument`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toBeInTheDocument() | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to assert whether an element is present in the document or not. | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <span data-testid="html-element"><span>Html Element</span></span> | ||
|  | <svg data-testid="svg-element"></svg> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const htmlElement = document.querySelector('[data-testid="html-element"]') | ||
|  | const svgElement = document.querySelector('[data-testid="svg-element"]') | ||
|  | const nonExistantElement = document.querySelector('does-not-exist') | ||
|  | const detachedElement = document.createElement('div') | ||
|  | 
 | ||
|  | expect(htmlElement).toBeInTheDocument() | ||
|  | expect(svgElement).toBeInTheDocument() | ||
|  | expect(nonExistantElement).not.toBeInTheDocument() | ||
|  | expect(detachedElement).not.toBeInTheDocument() | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect( | ||
|  |   queryByTestId(document.documentElement, 'html-element'), | ||
|  | ).toBeInTheDocument() | ||
|  | expect( | ||
|  |   queryByTestId(document.documentElement, 'svg-element'), | ||
|  | ).toBeInTheDocument() | ||
|  | expect( | ||
|  |   queryByTestId(document.documentElement, 'does-not-exist'), | ||
|  | ).not.toBeInTheDocument() | ||
|  | ``` | ||
|  | 
 | ||
|  | > Note: This matcher does not find detached elements. The element must be added
 | ||
|  | > to the document to be found by toBeInTheDocument. If you desire to search in a
 | ||
|  | > detached element please use: [`toContainElement`](#tocontainelement)
 | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toBeInvalid`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toBeInvalid() | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to check if a form element, or the entire `form`, is currently | ||
|  | invalid. | ||
|  | 
 | ||
|  | An `input`, `select`, `textarea`, or `form` element is invalid if it has an | ||
|  | [`aria-invalid` attribute](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Techniques/Using_the_aria-invalid_attribute) | ||
|  | with no value or a value of `"true"`, or if the result of | ||
|  | [`checkValidity()`](https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/HTML5/Constraint_validation) | ||
|  | is `false`. | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <input data-testid="no-aria-invalid" /> | ||
|  | <input data-testid="aria-invalid" aria-invalid /> | ||
|  | <input data-testid="aria-invalid-value" aria-invalid="true" /> | ||
|  | <input data-testid="aria-invalid-false" aria-invalid="false" /> | ||
|  | 
 | ||
|  | <form data-testid="valid-form"> | ||
|  |   <input /> | ||
|  | </form> | ||
|  | 
 | ||
|  | <form data-testid="invalid-form"> | ||
|  |   <input required /> | ||
|  | </form> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect(queryByTestId('no-aria-invalid')).not.toBeInvalid() | ||
|  | expect(queryByTestId('aria-invalid')).toBeInvalid() | ||
|  | expect(queryByTestId('aria-invalid-value')).toBeInvalid() | ||
|  | expect(queryByTestId('aria-invalid-false')).not.toBeInvalid() | ||
|  | 
 | ||
|  | expect(queryByTestId('valid-form')).not.toBeInvalid() | ||
|  | expect(queryByTestId('invalid-form')).toBeInvalid() | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect(getByTestId(container, 'no-aria-invalid')).not.toBeInvalid() | ||
|  | expect(getByTestId(container, 'aria-invalid')).toBeInvalid() | ||
|  | expect(getByTestId(container, 'aria-invalid-value')).toBeInvalid() | ||
|  | expect(getByTestId(container, 'aria-invalid-false')).not.toBeInvalid() | ||
|  | 
 | ||
|  | expect(getByTestId(container, 'valid-form')).not.toBeInvalid() | ||
|  | expect(getByTestId(container, 'invalid-form')).toBeInvalid() | ||
|  | ``` | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toBeRequired`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toBeRequired() | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to check if an form element is currently required. | ||
|  | 
 | ||
|  | An element is required if it is having a `required` or `aria-required="true"` | ||
|  | attribute. | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <input data-testid="required-input" required /> | ||
|  | <input data-testid="aria-required-input" aria-required="true" /> | ||
|  | <input data-testid="conflicted-input" required aria-required="false" /> | ||
|  | <input data-testid="aria-not-required-input" aria-required="false" /> | ||
|  | <input data-testid="optional-input" /> | ||
|  | <input data-testid="unsupported-type" type="image" required /> | ||
|  | <select data-testid="select" required></select> | ||
|  | <textarea data-testid="textarea" required></textarea> | ||
|  | <div data-testid="supported-role" role="tree" required></div> | ||
|  | <div data-testid="supported-role-aria" role="tree" aria-required="true"></div> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect(document.querySelector('[data-testid="required-input"]')).toBeRequired() | ||
|  | expect( | ||
|  |   document.querySelector('[data-testid="aria-required-input"]'), | ||
|  | ).toBeRequired() | ||
|  | expect( | ||
|  |   document.querySelector('[data-testid="conflicted-input"]'), | ||
|  | ).toBeRequired() | ||
|  | expect( | ||
|  |   document.querySelector('[data-testid="aria-not-required-input"]'), | ||
|  | ).not.toBeRequired() | ||
|  | expect( | ||
|  |   document.querySelector('[data-testid="unsupported-type"]'), | ||
|  | ).not.toBeRequired() | ||
|  | expect(document.querySelector('[data-testid="select"]')).toBeRequired() | ||
|  | expect(document.querySelector('[data-testid="textarea"]')).toBeRequired() | ||
|  | expect( | ||
|  |   document.querySelector('[data-testid="supported-role"]'), | ||
|  | ).not.toBeRequired() | ||
|  | expect( | ||
|  |   document.querySelector('[data-testid="supported-role-aria"]'), | ||
|  | ).toBeRequired() | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect(getByTestId(container, 'required-input')).toBeRequired() | ||
|  | expect(getByTestId(container, 'aria-required-input')).toBeRequired() | ||
|  | expect(getByTestId(container, 'conflicted-input')).toBeRequired() | ||
|  | expect(getByTestId(container, 'aria-not-required-input')).not.toBeRequired() | ||
|  | expect(getByTestId(container, 'optional-input')).not.toBeRequired() | ||
|  | expect(getByTestId(container, 'unsupported-type')).not.toBeRequired() | ||
|  | expect(getByTestId(container, 'select')).toBeRequired() | ||
|  | expect(getByTestId(container, 'textarea')).toBeRequired() | ||
|  | expect(getByTestId(container, 'supported-role')).not.toBeRequired() | ||
|  | expect(getByTestId(container, 'supported-role-aria')).toBeRequired() | ||
|  | ``` | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toBeValid`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toBeValid() | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to check if the value of a form element, or the entire `form`, | ||
|  | is currently valid. | ||
|  | 
 | ||
|  | An `input`, `select`, `textarea`, or `form` element is valid if it has no | ||
|  | [`aria-invalid` attribute](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Techniques/Using_the_aria-invalid_attribute) | ||
|  | or an attribute value of `"false"`. The result of | ||
|  | [`checkValidity()`](https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/HTML5/Constraint_validation) | ||
|  | must also be `true`. | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <input data-testid="no-aria-invalid" /> | ||
|  | <input data-testid="aria-invalid" aria-invalid /> | ||
|  | <input data-testid="aria-invalid-value" aria-invalid="true" /> | ||
|  | <input data-testid="aria-invalid-false" aria-invalid="false" /> | ||
|  | 
 | ||
|  | <form data-testid="valid-form"> | ||
|  |   <input /> | ||
|  | </form> | ||
|  | 
 | ||
|  | <form data-testid="invalid-form"> | ||
|  |   <input required /> | ||
|  | </form> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect(queryByTestId('no-aria-invalid')).toBeValid() | ||
|  | expect(queryByTestId('aria-invalid')).not.toBeValid() | ||
|  | expect(queryByTestId('aria-invalid-value')).not.toBeValid() | ||
|  | expect(queryByTestId('aria-invalid-false')).toBeValid() | ||
|  | 
 | ||
|  | expect(queryByTestId('valid-form')).toBeValid() | ||
|  | expect(queryByTestId('invalid-form')).not.toBeValid() | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect(getByTestId(container, 'no-aria-invalid')).toBeValid() | ||
|  | expect(getByTestId(container, 'aria-invalid')).not.toBeValid() | ||
|  | expect(getByTestId(container, 'aria-invalid-value')).not.toBeValid() | ||
|  | expect(getByTestId(container, 'aria-invalid-false')).toBeValid() | ||
|  | 
 | ||
|  | expect(getByTestId(container, 'valid-form')).toBeValid() | ||
|  | expect(getByTestId(container, 'invalid-form')).not.toBeValid() | ||
|  | ``` | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toBeVisible`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toBeVisible() | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to check if an element is currently visible to the user. | ||
|  | 
 | ||
|  | An element is visible if **all** the following conditions are met: | ||
|  | 
 | ||
|  | - it does not have its css property `display` set to `none` | ||
|  | - it does not have its css property `visibility` set to either `hidden` or | ||
|  |   `collapse` | ||
|  | - it does not have its css property `opacity` set to `0` | ||
|  | - its parent element is also visible (and so on up to the top of the DOM tree) | ||
|  | - it does not have the | ||
|  |   [`hidden`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/hidden) | ||
|  |   attribute | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <div data-testid="zero-opacity" style="opacity: 0">Zero Opacity Example</div> | ||
|  | <div data-testid="visibility-hidden" style="visibility: hidden"> | ||
|  |   Visibility Hidden Example | ||
|  | </div> | ||
|  | <div data-testid="display-none" style="display: none">Display None Example</div> | ||
|  | <div style="opacity: 0"> | ||
|  |   <span data-testid="hidden-parent">Hidden Parent Example</span> | ||
|  | </div> | ||
|  | <div data-testid="visible">Visible Example</div> | ||
|  | <div data-testid="hidden-attribute" hidden>Hidden Attribute Example</div> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect(document.querySelector('[data-testid="zero-opacity"]')).not.toBeVisible() | ||
|  | expect( | ||
|  |   document.querySelector('[data-testid="visibility-hidden"]'), | ||
|  | ).not.toBeVisible() | ||
|  | expect(document.querySelector('[data-testid="display-none"]')).not.toBeVisible() | ||
|  | expect( | ||
|  |   document.querySelector('[data-testid="hidden-parent"]'), | ||
|  | ).not.toBeVisible() | ||
|  | expect(document.querySelector('[data-testid="visible"]')).toBeVisible() | ||
|  | expect( | ||
|  |   document.querySelector('[data-testid="hidden-attribute"]'), | ||
|  | ).not.toBeVisible() | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect(getByText(container, 'Zero Opacity Example')).not.toBeVisible() | ||
|  | expect(getByText(container, 'Visibility Hidden Example')).not.toBeVisible() | ||
|  | expect(getByText(container, 'Display None Example')).not.toBeVisible() | ||
|  | expect(getByText(container, 'Hidden Parent Example')).not.toBeVisible() | ||
|  | expect(getByText(container, 'Visible Example')).toBeVisible() | ||
|  | expect(getByText(container, 'Hidden Attribute Example')).not.toBeVisible() | ||
|  | ``` | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toContainElement`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toContainElement(element: HTMLElement | SVGElement | null) | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to assert whether an element contains another element as a | ||
|  | descendant or not. | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <span data-testid="ancestor"><span data-testid="descendant"></span></span> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const ancestor = document.querySelector('[data-testid="ancestor"]') | ||
|  | const descendant = document.querySelector('[data-testid="descendant"]') | ||
|  | const nonExistantElement = document.querySelector( | ||
|  |   '[data-testid="does-not-exist"]', | ||
|  | ) | ||
|  | 
 | ||
|  | expect(ancestor).toContainElement(descendant) | ||
|  | expect(descendant).not.toContainElement(ancestor) | ||
|  | expect(ancestor).not.toContainElement(nonExistantElement) | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const {queryByTestId} = render(/* Rendered HTML */) | ||
|  | 
 | ||
|  | const ancestor = queryByTestId(container, 'ancestor') | ||
|  | const descendant = queryByTestId(container, 'descendant') | ||
|  | const nonExistantElement = queryByTestId(container, 'does-not-exist') | ||
|  | 
 | ||
|  | expect(ancestor).toContainElement(descendant) | ||
|  | expect(descendant).not.toContainElement(ancestor) | ||
|  | expect(ancestor).not.toContainElement(nonExistantElement) | ||
|  | ``` | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toContainHTML`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toContainHTML(htmlText: string) | ||
|  | ``` | ||
|  | 
 | ||
|  | Assert whether a string representing a HTML element is contained in another | ||
|  | element: | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <span data-testid="parent"><span data-testid="child"></span></span> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect(document.querySelector('[data-testid="parent"]')).toContainHTML( | ||
|  |   '<span data-testid="child"></span>', | ||
|  | ) | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | expect(getByTestId(container, 'parent')).toContainHTML( | ||
|  |   '<span data-testid="child"></span>', | ||
|  | ) | ||
|  | ``` | ||
|  | 
 | ||
|  | > Chances are you probably do not need to use this matcher. We encourage testing
 | ||
|  | > from the perspective of how the user perceives the app in a browser. That's
 | ||
|  | > why testing against a specific DOM structure is not advised.
 | ||
|  | > | ||
|  | > It could be useful in situations where the code being tested renders html that
 | ||
|  | > was obtained from an external source, and you want to validate that that html
 | ||
|  | > code was used as intended.
 | ||
|  | > | ||
|  | > It should not be used to check DOM structure that you control. Please use
 | ||
|  | > [`toContainElement`](#tocontainelement) instead.
 | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toHaveAttribute`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toHaveAttribute(attr: string, value?: any) | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to check whether the given element has an attribute or not. You | ||
|  | can also optionally check that the attribute has a specific expected value or | ||
|  | partial match using | ||
|  | [expect.stringContaining](https://jestjs.io/docs/en/expect.html#expectnotstringcontainingstring)/[expect.stringMatching](https://jestjs.io/docs/en/expect.html#expectstringmatchingstring-regexp) | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <button data-testid="ok-button" type="submit" disabled>ok</button> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const button = document.querySelector('[data-testid="ok-button"]') | ||
|  | 
 | ||
|  | expect(button).toHaveAttribute('disabled') | ||
|  | expect(button).toHaveAttribute('type', 'submit') | ||
|  | expect(button).not.toHaveAttribute('type', 'button') | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const button = getByTestId(container, 'ok-button') | ||
|  | 
 | ||
|  | expect(button).toHaveAttribute('disabled') | ||
|  | expect(button).toHaveAttribute('type', 'submit') | ||
|  | expect(button).not.toHaveAttribute('type', 'button') | ||
|  | 
 | ||
|  | expect(button).toHaveAttribute('type', expect.stringContaining('sub')) | ||
|  | expect(button).toHaveAttribute('type', expect.not.stringContaining('but')) | ||
|  | ``` | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toHaveClass`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toHaveClass(...classNames: string[]) | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to check whether the given element has certain classes within | ||
|  | its `class` attribute. | ||
|  | 
 | ||
|  | You must provide at least one class, unless you are asserting that an element | ||
|  | does not have any classes. | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <button data-testid="delete-button" class="btn extra btn-danger"> | ||
|  |   Delete item | ||
|  | </button> | ||
|  | <button data-testid="no-classes">No Classes</button> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const deleteButton = document.querySelector('[data-testid="delete-button"]') | ||
|  | const noClasses = document.querySelector('[data-testid="no-classes"]') | ||
|  | 
 | ||
|  | expect(deleteButton).toHaveClass('extra') | ||
|  | expect(deleteButton).toHaveClass('btn-danger btn') | ||
|  | expect(deleteButton).toHaveClass('btn-danger', 'btn') | ||
|  | expect(deleteButton).not.toHaveClass('btn-link') | ||
|  | 
 | ||
|  | expect(noClasses).not.toHaveClass() | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const deleteButton = getByTestId(container, 'delete-button') | ||
|  | const noClasses = getByTestId(container, 'no-classes') | ||
|  | 
 | ||
|  | expect(deleteButton).toHaveClass('extra') | ||
|  | expect(deleteButton).toHaveClass('btn-danger btn') | ||
|  | expect(deleteButton).toHaveClass('btn-danger', 'btn') | ||
|  | expect(deleteButton).not.toHaveClass('btn-link') | ||
|  | 
 | ||
|  | expect(noClasses).not.toHaveClass() | ||
|  | ``` | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toHaveFocus`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toHaveFocus() | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to assert whether an element has focus or not. | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <div><input type="text" data-testid="element-to-focus" /></div> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const input = document.querySelector(['data-testid="element-to-focus"']) | ||
|  | 
 | ||
|  | input.focus() | ||
|  | expect(input).toHaveFocus() | ||
|  | 
 | ||
|  | input.blur() | ||
|  | expect(input).not.toHaveFocus() | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const input = queryByTestId(container, 'element-to-focus') | ||
|  | 
 | ||
|  | fireEvent.focus(input) | ||
|  | expect(input).toHaveFocus() | ||
|  | 
 | ||
|  | fireEvent.blur(input) | ||
|  | expect(input).not.toHaveFocus() | ||
|  | ``` | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toHaveFormValues`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toHaveFormValues(expectedValues: { | ||
|  |   [name: string]: any | ||
|  | }) | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to check if a form or fieldset contains form controls for each | ||
|  | given name, and having the specified value. | ||
|  | 
 | ||
|  | > It is important to stress that this matcher can only be invoked on a [form][]
 | ||
|  | > or a [fieldset][] element.
 | ||
|  | > | ||
|  | > This allows it to take advantage of the [.elements][] property in `form` and
 | ||
|  | > `fieldset` to reliably fetch all form controls within them.
 | ||
|  | > | ||
|  | > This also avoids the possibility that users provide a container that contains
 | ||
|  | > more than one `form`, thereby intermixing form controls that are not related,
 | ||
|  | > and could even conflict with one another.
 | ||
|  | 
 | ||
|  | This matcher abstracts away the particularities with which a form control value | ||
|  | is obtained depending on the type of form control. For instance, `<input>` | ||
|  | elements have a `value` attribute, but `<select>` elements do not. Here's a list | ||
|  | of all cases covered: | ||
|  | 
 | ||
|  | - `<input type="number">` elements return the value as a **number**, instead of | ||
|  |   a string. | ||
|  | - `<input type="checkbox">` elements: | ||
|  |   - if there's a single one with the given `name` attribute, it is treated as a | ||
|  |     **boolean**, returning `true` if the checkbox is checked, `false` if | ||
|  |     unchecked. | ||
|  |   - if there's more than one checkbox with the same `name` attribute, they are | ||
|  |     all treated collectively as a single form control, which returns the value | ||
|  |     as an **array** containing all the values of the selected checkboxes in the | ||
|  |     collection. | ||
|  | - `<input type="radio">` elements are all grouped by the `name` attribute, and | ||
|  |   such a group treated as a single form control. This form control returns the | ||
|  |   value as a **string** corresponding to the `value` attribute of the selected | ||
|  |   radio button within the group. | ||
|  | - `<input type="text">` elements return the value as a **string**. This also | ||
|  |   applies to `<input>` elements having any other possible `type` attribute | ||
|  |   that's not explicitly covered in different rules above (e.g. `search`, | ||
|  |   `email`, `date`, `password`, `hidden`, etc.) | ||
|  | - `<select>` elements without the `multiple` attribute return the value as a | ||
|  |   **string** corresponding to the `value` attribute of the selected `option`, or | ||
|  |   `undefined` if there's no selected option. | ||
|  | - `<select multiple>` elements return the value as an **array** containing all | ||
|  |   the values of the [selected options][]. | ||
|  | - `<textarea>` elements return their value as a **string**. The value | ||
|  |   corresponds to their node content. | ||
|  | 
 | ||
|  | The above rules make it easy, for instance, to switch from using a single select | ||
|  | control to using a group of radio buttons. Or to switch from a multi select | ||
|  | control, to using a group of checkboxes. The resulting set of form values used | ||
|  | by this matcher to compare against would be the same. | ||
|  | 
 | ||
|  | [selected options]: | ||
|  |   https://developer.mozilla.org/en-US/docs/Web/API/HTMLSelectElement/selectedOptions | ||
|  | [form]: https://developer.mozilla.org/en-US/docs/Web/API/HTMLFormElement | ||
|  | [fieldset]: https://developer.mozilla.org/en-US/docs/Web/API/HTMLFieldSetElement | ||
|  | [.elements]: | ||
|  |   https://developer.mozilla.org/en-US/docs/Web/API/HTMLFormElement/elements | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <form data-testid="login-form"> | ||
|  |   <input type="text" name="username" value="jane.doe" /> | ||
|  |   <input type="password" name="password" value="12345678" /> | ||
|  |   <input type="checkbox" name="rememberMe" checked /> | ||
|  |   <button type="submit">Sign in</button> | ||
|  | </form> | ||
|  | ``` | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const form = document.querySelector('[data-testid="login-form"]') | ||
|  | expect(form).toHaveFormValues({ | ||
|  |   username: 'jane.doe', | ||
|  |   rememberMe: true, | ||
|  | }) | ||
|  | ``` | ||
|  | 
 | ||
|  | ### `toHaveStyle`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toHaveStyle(css: string) | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to check if a certain element has some specific css properties | ||
|  | with specific values applied. It matches only if the element has _all_ the | ||
|  | expected properties applied, not just some of them. | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <button data-testid="delete-button" style="display: none; color: red"> | ||
|  |   Delete item | ||
|  | </button> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const button = document.querySelector(['data-testid="delete-button"']) | ||
|  | 
 | ||
|  | expect(button).toHaveStyle('display: none') | ||
|  | expect(button).toHaveStyle(` | ||
|  |   color: red; | ||
|  |   display: none; | ||
|  | `) | ||
|  | expect(button).not.toHaveStyle(` | ||
|  |   color: blue; | ||
|  |   display: none; | ||
|  | `) | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const button = getByTestId(container, 'delete-button') | ||
|  | 
 | ||
|  | expect(button).toHaveStyle('display: none') | ||
|  | expect(button).toHaveStyle(` | ||
|  |   color: red; | ||
|  |   display: none; | ||
|  | `) | ||
|  | expect(button).not.toHaveStyle(` | ||
|  |   color: blue; | ||
|  |   display: none; | ||
|  | `) | ||
|  | ``` | ||
|  | 
 | ||
|  | This also works with rules that are applied to the element via a class name for | ||
|  | which some rules are defined in a stylesheet currently active in the document. | ||
|  | The usual rules of css precedence apply. | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toHaveTextContent`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toHaveTextContent(text: string | RegExp, options?: {normalizeWhitespace: boolean}) | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to check whether the given element has a text content or not. | ||
|  | 
 | ||
|  | When a `string` argument is passed through, it will perform a partial | ||
|  | case-sensitive match to the element content. | ||
|  | 
 | ||
|  | To perform a case-insensitive match, you can use a `RegExp` with the `/i` | ||
|  | modifier. | ||
|  | 
 | ||
|  | If you want to match the whole content, you can use a `RegExp` to do it. | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <span data-testid="text-content">Text Content</span> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const element = document.querySelector('[data-testid="text-content"]') | ||
|  | 
 | ||
|  | expect(element).toHaveTextContent('Content') | ||
|  | expect(element).toHaveTextContent(/^Text Content$/) // to match the whole content | ||
|  | expect(element).toHaveTextContent(/content$/i) // to use case-insentive match | ||
|  | expect(element).not.toHaveTextContent('content') | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const element = getByTestId(container, 'text-content') | ||
|  | 
 | ||
|  | expect(element).toHaveTextContent('Content') | ||
|  | expect(element).toHaveTextContent(/^Text Content$/) // to match the whole content | ||
|  | expect(element).toHaveTextContent(/content$/i) // to use case-insentive match | ||
|  | expect(element).not.toHaveTextContent('content') | ||
|  | ``` | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toHaveValue`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toHaveValue(value: string | string[] | number) | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to check whether the given form element has the specified value. | ||
|  | It accepts `<input>`, `<select>` and `<textarea>` elements with the exception of | ||
|  | of `<input type="checkbox">` and `<input type="radio">`, which can be | ||
|  | meaningfully matched only using [`toBeChecked`](#tobechecked) or | ||
|  | [`toHaveFormValues`](#tohaveformvalues). | ||
|  | 
 | ||
|  | For all other form elements, the value is matched using the same algorithm as in | ||
|  | [`toHaveFormValues`](#tohaveformvalues) does. | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <input type="text" value="text" data-testid="input-text" /> | ||
|  | <input type="number" value="5" data-testid="input-number" /> | ||
|  | <input type="text" data-testid="input-empty" /> | ||
|  | <select data-testid="multiple" multiple data-testid="select-number"> | ||
|  |   <option value="first">First Value</option> | ||
|  |   <option value="second" selected>Second Value</option> | ||
|  |   <option value="third" selected>Third Value</option> | ||
|  | </select> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const textInput = document.querySelector('[data-testid="input-text"]') | ||
|  | const numberInput = document.querySelector('[data-testid="input-number"]') | ||
|  | const emptyInput = document.querySelector('[data-testid="input-empty"]') | ||
|  | const selectInput = document.querySelector('[data-testid="select-number"]') | ||
|  | 
 | ||
|  | expect(textInput).toHaveValue('text') | ||
|  | expect(numberInput).toHaveValue(5) | ||
|  | expect(emptyInput).not.toHaveValue() | ||
|  | expect(selectInput).not.toHaveValue(['second', 'third']) | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const {getByTestId} = render(/* Rendered HTML */) | ||
|  | 
 | ||
|  | const textInput = getByTestId('input-text') | ||
|  | const numberInput = getByTestId('input-number') | ||
|  | const emptyInput = getByTestId('input-empty') | ||
|  | const selectInput = getByTestId('select-number') | ||
|  | 
 | ||
|  | expect(textInput).toHaveValue('text') | ||
|  | expect(numberInput).toHaveValue(5) | ||
|  | expect(emptyInput).not.toHaveValue() | ||
|  | expect(selectInput).not.toHaveValue(['second', 'third']) | ||
|  | ``` | ||
|  | 
 | ||
|  | <hr /> | ||
|  | 
 | ||
|  | ### `toBeChecked`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toBeChecked() | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to check whether the given element is checked. It accepts an | ||
|  | `input` of type `checkbox` or `radio` and elements with a `role` of `checkbox` | ||
|  | or `radio` with a valid `aria-checked` attribute of `"true"` or `"false"`. | ||
|  | 
 | ||
|  | #### Examples
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <input type="checkbox" checked data-testid="input-checkbox-checked" /> | ||
|  | <input type="checkbox" data-testid="input-checkbox-unchecked" /> | ||
|  | <div role="checkbox" aria-checked="true" data-testid="aria-checkbox-checked" /> | ||
|  | <div | ||
|  |   role="checkbox" | ||
|  |   aria-checked="false" | ||
|  |   data-testid="aria-checkbox-unchecked" | ||
|  | /> | ||
|  | 
 | ||
|  | <input type="radio" checked value="foo" data-testid="input-radio-checked" /> | ||
|  | <input type="radio" value="foo" data-testid="input-radio-unchecked" /> | ||
|  | <div role="radio" aria-checked="true" data-testid="aria-radio-checked" /> | ||
|  | <div role="radio" aria-checked="false" data-testid="aria-radio-unchecked" /> | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using document.querySelector
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const inputCheckboxChecked = document.querySelector( | ||
|  |   '[data-testid="input-checkbox-checked"]', | ||
|  | ) | ||
|  | const inputCheckboxUnchecked = document.querySelector( | ||
|  |   '[data-testid="input-checkbox-unchecked"]', | ||
|  | ) | ||
|  | const ariaCheckboxChecked = document.querySelector( | ||
|  |   '[data-testid="aria-checkbox-checked"]', | ||
|  | ) | ||
|  | const ariaCheckboxUnchecked = document.querySelector( | ||
|  |   '[data-testid="aria-checkbox-unchecked"]', | ||
|  | ) | ||
|  | expect(inputCheckboxChecked).toBeChecked() | ||
|  | expect(inputCheckboxUnchecked).not.toBeChecked() | ||
|  | expect(ariaCheckboxChecked).toBeChecked() | ||
|  | expect(ariaCheckboxUnchecked).not.toBeChecked() | ||
|  | 
 | ||
|  | const inputRadioChecked = document.querySelector( | ||
|  |   '[data-testid="input-radio-checked"]', | ||
|  | ) | ||
|  | const inputRadioUnchecked = document.querySelector( | ||
|  |   '[data-testid="input-radio-unchecked"]', | ||
|  | ) | ||
|  | const ariaRadioChecked = document.querySelector( | ||
|  |   '[data-testid="aria-radio-checked"]', | ||
|  | ) | ||
|  | const ariaRadioUnchecked = document.querySelector( | ||
|  |   '[data-testid="aria-radio-unchecked"]', | ||
|  | ) | ||
|  | expect(inputRadioChecked).toBeChecked() | ||
|  | expect(inputRadioUnchecked).not.toBeChecked() | ||
|  | expect(ariaRadioChecked).toBeChecked() | ||
|  | expect(ariaRadioUnchecked).not.toBeChecked() | ||
|  | ``` | ||
|  | 
 | ||
|  | ##### Using DOM Testing Library
 | ||
|  | 
 | ||
|  | ```javascript | ||
|  | const {getByTestId} = render(/* Rendered HTML */) | ||
|  | 
 | ||
|  | const inputCheckboxChecked = getByTestId('input-checkbox-checked') | ||
|  | const inputCheckboxUnchecked = getByTestId('input-checkbox-unchecked') | ||
|  | const ariaCheckboxChecked = getByTestId('aria-checkbox-checked') | ||
|  | const ariaCheckboxUnchecked = getByTestId('aria-checkbox-unchecked') | ||
|  | expect(inputCheckboxChecked).toBeChecked() | ||
|  | expect(inputCheckboxUnchecked).not.toBeChecked() | ||
|  | expect(ariaCheckboxChecked).toBeChecked() | ||
|  | expect(ariaCheckboxUnchecked).not.toBeChecked() | ||
|  | 
 | ||
|  | const inputRadioChecked = getByTestId('input-radio-checked') | ||
|  | const inputRadioUnchecked = getByTestId('input-radio-unchecked') | ||
|  | const ariaRadioChecked = getByTestId('aria-radio-checked') | ||
|  | const ariaRadioUnchecked = getByTestId('aria-radio-unchecked') | ||
|  | expect(inputRadioChecked).toBeChecked() | ||
|  | expect(inputRadioUnchecked).not.toBeChecked() | ||
|  | expect(ariaRadioChecked).toBeChecked() | ||
|  | expect(ariaRadioUnchecked).not.toBeChecked() | ||
|  | ``` | ||
|  | 
 | ||
|  | ## Deprecated matchers
 | ||
|  | 
 | ||
|  | ### `toBeInTheDOM`
 | ||
|  | 
 | ||
|  | ```typescript | ||
|  | toBeInTheDOM() | ||
|  | ``` | ||
|  | 
 | ||
|  | This allows you to check whether a value is a DOM element, or not. | ||
|  | 
 | ||
|  | Contrary to what its name implies, this matcher only checks that you passed to | ||
|  | it a valid DOM element. It does not have a clear definition of that "the DOM" | ||
|  | is. Therefore, it does not check wether that element is contained anywhere. | ||
|  | 
 | ||
|  | This is the main reason why this matcher is deprecated, and will be removed in | ||
|  | the next major release. You can follow the discussion around this decision in | ||
|  | more detail [here](https://github.com/testing-library/jest-dom/issues/34). | ||
|  | 
 | ||
|  | As an alternative, you can use [`toBeInTheDocument`](#tobeinthedocument) or | ||
|  | [`toContainElement`](#tocontainelement). Or if you just want to check if a value | ||
|  | is indeed an `HTMLElement` you can always use some of | ||
|  | [jest's built-in matchers](https://jestjs.io/docs/en/expect#tobeinstanceofclass): | ||
|  | 
 | ||
|  | ```js | ||
|  | expect(document.querySelector('.ok-button')).toBeInstanceOf(HTMLElement) | ||
|  | expect(document.querySelector('.cancel-button')).toBeTruthy() | ||
|  | ``` | ||
|  | 
 | ||
|  | > Note: The differences between `toBeInTheDOM` and `toBeInTheDocument` are
 | ||
|  | > significant. Replacing all uses of `toBeInTheDOM` with `toBeInTheDocument`
 | ||
|  | > will likely cause unintended consequences in your tests. Please make sure when
 | ||
|  | > replacing `toBeInTheDOM` to read through the documentation of the proposed
 | ||
|  | > alternatives to see which use case works better for your needs.
 | ||
|  | 
 | ||
|  | 
 | ||
|  | ## Inspiration
 | ||
|  | 
 | ||
|  | This whole library was extracted out of Kent C. Dodds' [DOM Testing | ||
|  | Library][dom-testing-library], which was in turn extracted out of [React Testing | ||
|  | Library][react-testing-library]. | ||
|  | 
 | ||
|  | The intention is to make this available to be used independently of these other | ||
|  | libraries, and also to make it more clear that these other libraries are | ||
|  | independent from jest, and can be used with other tests runners as well. | ||
|  | 
 | ||
|  | ## Other Solutions
 | ||
|  | 
 | ||
|  | I'm not aware of any, if you are please [make a pull request][prs] and add it | ||
|  | here! | ||
|  | 
 | ||
|  | ## Guiding Principles
 | ||
|  | 
 | ||
|  | > [The more your tests resemble the way your software is used, the more
 | ||
|  | > confidence they can give you.][guiding-principle]
 | ||
|  | 
 | ||
|  | This library follows the same guiding principles as its mother library [DOM | ||
|  | Testing Library][dom-testing-library]. Go [check them out][guiding-principle] | ||
|  | for more details. | ||
|  | 
 | ||
|  | Additionally, with respect to custom DOM matchers, this library aims to maintain | ||
|  | a minimal but useful set of them, while avoiding bloating itself with merely | ||
|  | convenient ones that can be easily achieved with other APIs. In general, the | ||
|  | overall criteria for what is considered a useful custom matcher to add to this | ||
|  | library, is that doing the equivalent assertion on our own makes the test code | ||
|  | more verbose, less clear in its intent, and/or harder to read. | ||
|  | 
 | ||
|  | ## Contributors
 | ||
|  | 
 | ||
|  | Thanks goes to these people ([emoji key][emojis]): | ||
|  | 
 | ||
|  | <!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section --> | ||
|  | <!-- prettier-ignore --> | ||
|  | <table> | ||
|  |   <tr> | ||
|  |     <td align="center"><a href="https://kentcdodds.com"><img src="https://avatars.githubusercontent.com/u/1500684?v=3" width="100px;" alt="Kent C. Dodds"/><br /><sub><b>Kent C. Dodds</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=kentcdodds" title="Code">💻</a> <a href="https://github.com/testing-library/jest-dom/commits?author=kentcdodds" title="Documentation">📖</a> <a href="#infra-kentcdodds" title="Infrastructure (Hosting, Build-Tools, etc)">🚇</a> <a href="https://github.com/testing-library/jest-dom/commits?author=kentcdodds" title="Tests">⚠️</a></td> | ||
|  |     <td align="center"><a href="http://audiolion.github.io"><img src="https://avatars1.githubusercontent.com/u/2430381?v=4" width="100px;" alt="Ryan Castner"/><br /><sub><b>Ryan Castner</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=audiolion" title="Documentation">📖</a></td> | ||
|  |     <td align="center"><a href="https://www.dnlsandiego.com"><img src="https://avatars0.githubusercontent.com/u/8008023?v=4" width="100px;" alt="Daniel Sandiego"/><br /><sub><b>Daniel Sandiego</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=dnlsandiego" title="Code">💻</a></td> | ||
|  |     <td align="center"><a href="https://github.com/Miklet"><img src="https://avatars2.githubusercontent.com/u/12592677?v=4" width="100px;" alt="Paweł Mikołajczyk"/><br /><sub><b>Paweł Mikołajczyk</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=Miklet" title="Code">💻</a></td> | ||
|  |     <td align="center"><a href="http://co.linkedin.com/in/alejandronanez/"><img src="https://avatars3.githubusercontent.com/u/464978?v=4" width="100px;" alt="Alejandro Ñáñez Ortiz"/><br /><sub><b>Alejandro Ñáñez Ortiz</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=alejandronanez" title="Documentation">📖</a></td> | ||
|  |     <td align="center"><a href="https://github.com/pbomb"><img src="https://avatars0.githubusercontent.com/u/1402095?v=4" width="100px;" alt="Matt Parrish"/><br /><sub><b>Matt Parrish</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/issues?q=author%3Apbomb" title="Bug reports">🐛</a> <a href="https://github.com/testing-library/jest-dom/commits?author=pbomb" title="Code">💻</a> <a href="https://github.com/testing-library/jest-dom/commits?author=pbomb" title="Documentation">📖</a> <a href="https://github.com/testing-library/jest-dom/commits?author=pbomb" title="Tests">⚠️</a></td> | ||
|  |     <td align="center"><a href="https://github.com/wKovacs64"><img src="https://avatars1.githubusercontent.com/u/1288694?v=4" width="100px;" alt="Justin Hall"/><br /><sub><b>Justin Hall</b></sub></a><br /><a href="#platform-wKovacs64" title="Packaging/porting to new platform">📦</a></td> | ||
|  |   </tr> | ||
|  |   <tr> | ||
|  |     <td align="center"><a href="https://github.com/antoaravinth"><img src="https://avatars1.githubusercontent.com/u/1241511?s=460&v=4" width="100px;" alt="Anto Aravinth"/><br /><sub><b>Anto Aravinth</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=antoaravinth" title="Code">💻</a> <a href="https://github.com/testing-library/jest-dom/commits?author=antoaravinth" title="Tests">⚠️</a> <a href="https://github.com/testing-library/jest-dom/commits?author=antoaravinth" title="Documentation">📖</a></td> | ||
|  |     <td align="center"><a href="https://github.com/JonahMoses"><img src="https://avatars2.githubusercontent.com/u/3462296?v=4" width="100px;" alt="Jonah Moses"/><br /><sub><b>Jonah Moses</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=JonahMoses" title="Documentation">📖</a></td> | ||
|  |     <td align="center"><a href="http://team.thebrain.pro"><img src="https://avatars1.githubusercontent.com/u/4002543?v=4" width="100px;" alt="Łukasz Gandecki"/><br /><sub><b>Łukasz Gandecki</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=lgandecki" title="Code">💻</a> <a href="https://github.com/testing-library/jest-dom/commits?author=lgandecki" title="Tests">⚠️</a> <a href="https://github.com/testing-library/jest-dom/commits?author=lgandecki" title="Documentation">📖</a></td> | ||
|  |     <td align="center"><a href="https://sompylasar.github.io"><img src="https://avatars2.githubusercontent.com/u/498274?v=4" width="100px;" alt="Ivan Babak"/><br /><sub><b>Ivan Babak</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/issues?q=author%3Asompylasar" title="Bug reports">🐛</a> <a href="#ideas-sompylasar" title="Ideas, Planning, & Feedback">🤔</a></td> | ||
|  |     <td align="center"><a href="https://github.com/jday3"><img src="https://avatars3.githubusercontent.com/u/4439618?v=4" width="100px;" alt="Jesse Day"/><br /><sub><b>Jesse Day</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=jday3" title="Code">💻</a></td> | ||
|  |     <td align="center"><a href="http://gnapse.github.io"><img src="https://avatars0.githubusercontent.com/u/15199?v=4" width="100px;" alt="Ernesto García"/><br /><sub><b>Ernesto García</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=gnapse" title="Code">💻</a> <a href="https://github.com/testing-library/jest-dom/commits?author=gnapse" title="Documentation">📖</a> <a href="https://github.com/testing-library/jest-dom/commits?author=gnapse" title="Tests">⚠️</a></td> | ||
|  |     <td align="center"><a href="http://ociweb.com/mark/"><img src="https://avatars0.githubusercontent.com/u/79312?v=4" width="100px;" alt="Mark Volkmann"/><br /><sub><b>Mark Volkmann</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/issues?q=author%3Amvolkmann" title="Bug reports">🐛</a> <a href="https://github.com/testing-library/jest-dom/commits?author=mvolkmann" title="Code">💻</a></td> | ||
|  |   </tr> | ||
|  |   <tr> | ||
|  |     <td align="center"><a href="https://github.com/smacpherson64"><img src="https://avatars1.githubusercontent.com/u/1659099?v=4" width="100px;" alt="smacpherson64"/><br /><sub><b>smacpherson64</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=smacpherson64" title="Code">💻</a> <a href="https://github.com/testing-library/jest-dom/commits?author=smacpherson64" title="Documentation">📖</a> <a href="https://github.com/testing-library/jest-dom/commits?author=smacpherson64" title="Tests">⚠️</a></td> | ||
|  |     <td align="center"><a href="https://github.com/jgoz"><img src="https://avatars2.githubusercontent.com/u/132233?v=4" width="100px;" alt="John Gozde"/><br /><sub><b>John Gozde</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/issues?q=author%3Ajgoz" title="Bug reports">🐛</a> <a href="https://github.com/testing-library/jest-dom/commits?author=jgoz" title="Code">💻</a></td> | ||
|  |     <td align="center"><a href="https://github.com/callada"><img src="https://avatars2.githubusercontent.com/u/7830590?v=4" width="100px;" alt="Iwona"/><br /><sub><b>Iwona</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=callada" title="Code">💻</a> <a href="https://github.com/testing-library/jest-dom/commits?author=callada" title="Documentation">📖</a> <a href="https://github.com/testing-library/jest-dom/commits?author=callada" title="Tests">⚠️</a></td> | ||
|  |     <td align="center"><a href="https://github.com/6ewis"><img src="https://avatars0.githubusercontent.com/u/840609?v=4" width="100px;" alt="Lewis"/><br /><sub><b>Lewis</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=6ewis" title="Code">💻</a></td> | ||
|  |     <td align="center"><a href="https://blog.lourenci.com/"><img src="https://avatars3.githubusercontent.com/u/2339362?v=4" width="100px;" alt="Leandro Lourenci"/><br /><sub><b>Leandro Lourenci</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/issues?q=author%3Alourenci" title="Bug reports">🐛</a> <a href="https://github.com/testing-library/jest-dom/commits?author=lourenci" title="Documentation">📖</a> <a href="https://github.com/testing-library/jest-dom/commits?author=lourenci" title="Code">💻</a> <a href="https://github.com/testing-library/jest-dom/commits?author=lourenci" title="Tests">⚠️</a></td> | ||
|  |     <td align="center"><a href="https://github.com/mufasa71"><img src="https://avatars1.githubusercontent.com/u/626420?v=4" width="100px;" alt="Shukhrat Mukimov"/><br /><sub><b>Shukhrat Mukimov</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/issues?q=author%3Amufasa71" title="Bug reports">🐛</a></td> | ||
|  |     <td align="center"><a href="https://github.com/dreyks"><img src="https://avatars3.githubusercontent.com/u/1481264?v=4" width="100px;" alt="Roman Usherenko"/><br /><sub><b>Roman Usherenko</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=dreyks" title="Code">💻</a> <a href="https://github.com/testing-library/jest-dom/commits?author=dreyks" title="Tests">⚠️</a></td> | ||
|  |   </tr> | ||
|  |   <tr> | ||
|  |     <td align="center"><a href="http://josephhsu.com"><img src="https://avatars1.githubusercontent.com/u/648?v=4" width="100px;" alt="Joe Hsu"/><br /><sub><b>Joe Hsu</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=jhsu" title="Documentation">📖</a></td> | ||
|  |     <td align="center"><a href="https://twitter.com/diegohaz"><img src="https://avatars3.githubusercontent.com/u/3068563?v=4" width="100px;" alt="Haz"/><br /><sub><b>Haz</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/issues?q=author%3Adiegohaz" title="Bug reports">🐛</a> <a href="https://github.com/testing-library/jest-dom/commits?author=diegohaz" title="Code">💻</a></td> | ||
|  |     <td align="center"><a href="https://blog.revathskumar.com"><img src="https://avatars3.githubusercontent.com/u/463904?v=4" width="100px;" alt="Revath S Kumar"/><br /><sub><b>Revath S Kumar</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=revathskumar" title="Code">💻</a></td> | ||
|  |     <td align="center"><a href="https://raccoon.studio"><img src="https://avatars0.githubusercontent.com/u/4989733?v=4" width="100px;" alt="hiwelo."/><br /><sub><b>hiwelo.</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=hiwelo" title="Code">💻</a> <a href="#ideas-hiwelo" title="Ideas, Planning, & Feedback">🤔</a> <a href="https://github.com/testing-library/jest-dom/commits?author=hiwelo" title="Tests">⚠️</a></td> | ||
|  |     <td align="center"><a href="https://github.com/lukaszfiszer"><img src="https://avatars3.githubusercontent.com/u/1201711?v=4" width="100px;" alt="Łukasz Fiszer"/><br /><sub><b>Łukasz Fiszer</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=lukaszfiszer" title="Code">💻</a></td> | ||
|  |     <td align="center"><a href="https://github.com/jeanchung"><img src="https://avatars0.githubusercontent.com/u/10778036?v=4" width="100px;" alt="Jean Chung"/><br /><sub><b>Jean Chung</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=jeanchung" title="Code">💻</a> <a href="https://github.com/testing-library/jest-dom/commits?author=jeanchung" title="Tests">⚠️</a></td> | ||
|  |     <td align="center"><a href="https://github.com/CarlaTeo"><img src="https://avatars3.githubusercontent.com/u/9220147?v=4" width="100px;" alt="CarlaTeo"/><br /><sub><b>CarlaTeo</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=CarlaTeo" title="Code">💻</a> <a href="https://github.com/testing-library/jest-dom/commits?author=CarlaTeo" title="Tests">⚠️</a></td> | ||
|  |   </tr> | ||
|  |   <tr> | ||
|  |     <td align="center"><a href="https://github.com/YardenShoham"><img src="https://avatars3.githubusercontent.com/u/20454870?v=4" width="100px;" alt="Yarden Shoham"/><br /><sub><b>Yarden Shoham</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=YardenShoham" title="Documentation">📖</a></td> | ||
|  |     <td align="center"><a href="http://jagascript.com"><img src="https://avatars0.githubusercontent.com/u/4562878?v=4" width="100px;" alt="Jaga Santagostino"/><br /><sub><b>Jaga Santagostino</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/issues?q=author%3Akandros" title="Bug reports">🐛</a> <a href="https://github.com/testing-library/jest-dom/commits?author=kandros" title="Tests">⚠️</a> <a href="https://github.com/testing-library/jest-dom/commits?author=kandros" title="Documentation">📖</a></td> | ||
|  |     <td align="center"><a href="https://github.com/connormeredith"><img src="https://avatars0.githubusercontent.com/u/4907463?v=4" width="100px;" alt="Connor Meredith"/><br /><sub><b>Connor Meredith</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=connormeredith" title="Code">💻</a> <a href="https://github.com/testing-library/jest-dom/commits?author=connormeredith" title="Tests">⚠️</a> <a href="https://github.com/testing-library/jest-dom/commits?author=connormeredith" title="Documentation">📖</a></td> | ||
|  |     <td align="center"><a href="https://github.com/pwolaq"><img src="https://avatars3.githubusercontent.com/u/10261750?v=4" width="100px;" alt="Pawel Wolak"/><br /><sub><b>Pawel Wolak</b></sub></a><br /><a href="https://github.com/testing-library/jest-dom/commits?author=pwolaq" title="Tests">⚠️</a></td> | ||
|  |   </tr> | ||
|  | </table> | ||
|  | 
 | ||
|  | <!-- ALL-CONTRIBUTORS-LIST:END --> | ||
|  | 
 | ||
|  | This project follows the [all-contributors][all-contributors] specification. | ||
|  | Contributions of any kind welcome! | ||
|  | 
 | ||
|  | ## LICENSE
 | ||
|  | 
 | ||
|  | MIT | ||
|  | 
 | ||
|  | [jest]: https://facebook.github.io/jest/ | ||
|  | [dom-testing-library]: https://github.com/testing-library/dom-testing-library | ||
|  | [react-testing-library]: | ||
|  |   https://github.com/testing-library/react-testing-library | ||
|  | [npm]: https://www.npmjs.com/ | ||
|  | [node]: https://nodejs.org | ||
|  | [build-badge]: | ||
|  |   https://img.shields.io/travis/testing-library/jest-dom.svg?style=flat-square | ||
|  | [build]: https://travis-ci.org/testing-library/jest-dom | ||
|  | [coverage-badge]: | ||
|  |   https://img.shields.io/codecov/c/github/testing-library/jest-dom.svg?style=flat-square | ||
|  | [coverage]: https://codecov.io/github/testing-library/jest-dom | ||
|  | [version-badge]: | ||
|  |   https://img.shields.io/npm/v/@testing-library/jest-dom.svg?style=flat-square | ||
|  | [package]: https://www.npmjs.com/package/@testing-library/jest-dom | ||
|  | [downloads-badge]: | ||
|  |   https://img.shields.io/npm/dm/@testing-library/jest-dom.svg?style=flat-square | ||
|  | [npmtrends]: http://www.npmtrends.com/@testing-library/jest-dom | ||
|  | [license-badge]: | ||
|  |   https://img.shields.io/npm/l/@testing-library/jest-dom.svg?style=flat-square | ||
|  | [license]: https://github.com/testing-library/jest-dom/blob/master/LICENSE | ||
|  | [prs-badge]: | ||
|  |   https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square | ||
|  | [prs]: http://makeapullrequest.com | ||
|  | [coc-badge]: | ||
|  |   https://img.shields.io/badge/code%20of-conduct-ff69b4.svg?style=flat-square | ||
|  | [coc]: | ||
|  |   https://github.com/testing-library/jest-dom/blob/master/other/CODE_OF_CONDUCT.md | ||
|  | [github-watch-badge]: | ||
|  |   https://img.shields.io/github/watchers/testing-library/jest-dom.svg?style=social | ||
|  | [github-watch]: https://github.com/testing-library/jest-dom/watchers | ||
|  | [github-star-badge]: | ||
|  |   https://img.shields.io/github/stars/testing-library/jest-dom.svg?style=social | ||
|  | [github-star]: https://github.com/testing-library/jest-dom/stargazers | ||
|  | [twitter]: | ||
|  |   https://twitter.com/intent/tweet?text=Check%20out%20jest-dom%20by%20%40gnapse%20https%3A%2F%2Fgithub.com%2Ftesting-library%2Fjest-dom%20%F0%9F%91%8D | ||
|  | [twitter-badge]: | ||
|  |   https://img.shields.io/twitter/url/https/github.com/testing-library/jest-dom.svg?style=social | ||
|  | [emojis]: https://allcontributors.org/docs/en/emoji-key | ||
|  | [all-contributors]: https://github.com/all-contributors/all-contributors | ||
|  | [guiding-principle]: https://testing-library.com/docs/guiding-principles |