我不知道其他答案是否对您的问题有帮助,但您不需要测试 componentWillMount。React 应该已经为你做了那个测试。
与您的测试更相关的是测试您在该方法中为您的组件放置的功能或操作。
如果您要进行一些 API 调用、运行基于 props 的函数或其他任何东西,这就是您应该测试的内容。模拟componentWillMount
触发的函数/动作/代码,并对其进行断言和期望。
例子:
零件:
class YourComponent extends Component {
componentWillMount() {
/*this fetch function is actually what you want to test*/
this.props.fetch('data')
}
render() {
/* whatever your component renders*/
}
}
测试:
test('should call fetch when mounted', () => {
let mockFetch = jest.fn()
const wrapper = mount(<SomeComponent fetch={mockFetch}/>);
expect(wrapper).toBeDefined();
expect(mockFetch).toHaveBeenCalled();
expect(mockFetch.mock.calls[0]).toEqual(['data'])
});