[英]Jest wait for promise to resolve before finding an element
这是我的 React 示例代码(实际代码与此非常相似,但太长,无法放在这里):
class Test extends Component {
state = {
show: false
}
render() {
return (
<>
{this.state.show && <div>Hello</div>}
<button
onClick={() => {
//an ajax call to fetch data from server
new Promise((resolve) => resolve(null)).then(() => {
this.setState({show: true})
})
}}
/>
</>
)
}
}
开玩笑的测试如下:
it('test', () => {
const component = mount(< Test />);
expect(component.find('div').length).toEqual(0); //passes
component.find('button').prop<Function>('onClick')();
expect(component.find('div').length).toEqual(1); //unstable response
})
现在我面临的问题是,当我运行这种测试时,在哪里找到组件取决于 promise 解析,测试不稳定。 有时它们会通过,有时却找不到组件。
我尝试过的事情:
1-使用此睡眠 function:
const sleep = (milliseconds: number) => {
return new Promise<number>(resolve => setTimeout(resolve, milliseconds));
};
然后在触发 promise 后使用await sleep(1)
2-使用此刷新承诺 function:
const flushPromises = () => {
return new Promise(resolve => setImmediate(resolve));
}
但我无法找到我想要的稳定性。 这导致的另一件事是,如果存在链式 Promise,则测试(大部分但并非总是因此不稳定)在所有 Promise 解决之前退出(这显然会导致测试失败)。 我试图增加超时( it
的第三个参数)并使用完成回调,但没有用。
有人可以解释我在这里做错了什么以及 promise 解析如何在jest
的测试环境中工作。
也许你可以以不同的方式测试 div。 通过设置 state 来测试是否存在 div DOM。
component.setState({ show: true }); expect(component.find("div").length).toEqual(1);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.