📍참고
https://jestjs.io/docs/using-matchers
Using Matchers · Jest
Jest uses "matchers" to let you test values in different ways. This document will introduce some commonly used matchers. For the full list, see the expect API doc.
jestjs.io
📍Matcher 란?
✅Jest에서 값을 다양한 방법으로 테스트하기 위해 사용
- a > b, a = b, a < b 등..
- 2 + 2 = 4 인지 평가하는 예시
test('two plus two is four', () => {
expect(2 + 2).toBe(4); // 값이 같은지 평가
});
📍Matchers from Jest
✅Jest의 matcher는 A, B 두 값을 비교하는데 쓰인다
- expect(A) .matcher(B) 형태로, A 와 B 를 비교한다
- 예시
expect(["A", "B"]).toHaveLength(2) // 검사할 값이 array이고, 특정 길이인지 확인
expect(5).toEqual(5) // 검사할 값이 특정 값인지 확인
expect(["A", "B", "C"]).toContain("B") // array, string이 특정 값을 포함하는지 확인
expect(fn).toThrow() // 함수를 호출하면 에러가 발생하는지 확인
expect(mock).toHaveBeenCalled() // 목업 함수가 호출되는지 확인
📍Matchers from RTL(jest-DOM)
✅RTL의 matcher는 값이 아닌 DOM을 검사하는데 쓰인다
- 엄밀히 따지면, jest-dom 라이브러리의 matcher가 제공된다
- 예시
expect(element).toBeInTheDocument() // element가 현재 페이지에 있는지 확인
expect(element).toBeEnabled() // element가 사용 가능한 상태인지 확인
expect(element).toHaveClass() // element가 특정 클래스를 갖고 있는지 확인
expect(element).toHaveTextContent() // element가 특정 콘텐츠(텍스트)를 가졌는지 확인
expect(element).toHaveValue() // input, select, textarea 등이 value를 가졌는지 확인