使用 React 测试库测试输入搜索框

mee*_*eez 10 unit-testing reactjs jestjs react-testing-library

我有一个搜索框组件:

    function SearchBox({ search, setSearch }) {
      return (
        <div>
          <div>
            <input onChange={e => setSearch(e.target.value)} type="text" placeholder="Search..." value={search} />
          </div>
        </div>
      )
    }
Run Code Online (Sandbox Code Playgroud)

我尝试了以下方法:

    describe('Input value', () => {
      it('updates on change', () => {
        const { queryByPlaceholderText } = render(<SearchBox />)
    
        const searchInput = queryByPlaceholderText('Search...')
    
        fireEvent.change(searchInput, { target: { value: 'test' } })
    
        expect(searchInput.value).toBe('test')
      })
    })
Run Code Online (Sandbox Code Playgroud)

但后来我得到一个错误:

错误:未捕获 [TypeError:setSearch 不是函数]

我可以如何测试此 SearchBox 组件以及测试什么内容?

eco*_*eer 13

问题是setSearch没有提供道具。

setSearch可以通过 jest mock 函数提供。

const setSearch = jest.fn((value) => {})
const { queryByPlaceholderText } = render(<SearchBox setSearch={setSearch}/>)
Run Code Online (Sandbox Code Playgroud)

完整测试代码片段:

import React from 'react'
import { render, fireEvent } from '@testing-library/react'
import SearchBox from './SearchBox'
import '@testing-library/jest-dom/extend-expect'

describe('Input value', () => {
    it('updates on change', () => {
      const setSearch = jest.fn((value) => {})
      
      const { queryByPlaceholderText } = render(<SearchBox setSearch={setSearch}/>)
  
      const searchInput = queryByPlaceholderText('Search...')
  
      fireEvent.change(searchInput, { target: { value: 'test' } })
  
      expect(searchInput.value).toBe('test') // OR
      expect(setSearch).toHaveBeenCalledWith('test')
    })
  })
Run Code Online (Sandbox Code Playgroud)