如何正确模拟多个 useSelector 钩子

时间:2021-01-28 21:57:06

标签: reactjs unit-testing react-testing-library

我的组件有多个选择器:

import { useSelector } from 'react-redux'
...
const data1 = useSelector(xxxxx)
const data2 = useSelector(yyyyy)

如何正确模拟测试文件中的每一个?

import { useSelector } from 'react-redux'
jest.mock('react-redux', () => ({
    useSelector: jest.fn()
}))
....
useSelector.mockImplementation(() => ({
   dataready: true
}))

在这种情况下它真正嘲笑的是哪个选择器?

2 个答案:

答案 0 :(得分:3)

不要嘲笑选择器。您想测试 Redux 和 React 组件之间的集成,而不是选择器的 Redux 实现。如果您使用 react-testing-library,那么劫持 render() 方法并使用 Redux Provider 组件实现您的商店非常简单。以下是 testing Connected Components 的文档。

这是您在考虑用户的情况下重新编写的测试:

import { render } from '../../test-utils' // <-- Hijacked render

it('displays data when ready', { // <-- behavior explanation
  const {getByTestId} = render(<YourComponent />, { 
    initialState: {
      dataready: true // <-- Pass data for selector
    }
  })
  expect(getByTestId('some-testId')).toBeTruthy(); // <-- Check that something shows based on selector
})

答案 1 :(得分:0)

您可以对要模拟的每个调用使用 mockImplementationOnce

import { useSelector } from 'react-redux'

jest.mock('react-redux', () => ({
    useSelector: jest.fn()
}))

// ...

useSelector
    .mockImplementationOnce(() => ({ dataready: true }))  // Mocks first call
    .mockImplementationOnce(() => ({ dataready: false })) // Mocks second call