gpt4 book ai didi

javascript - `react-apollo` `MockedProvider` 需要超时?

转载 作者:行者123 更新时间:2023-11-30 11:19:48 25 4
gpt4 key购买 nike

我正在使用 jest与 react-apollo 的 MockedProvider我遇到了麻烦,因为 MockedProvider似乎是异步行为。

给定以下简单组件:

const Component = () => <Query query={query}>(({loading, data }) => if(loading) return 'loading' else if (data) return 'data' else return 'nothing'</Query>

这个测试:

it('', done => {
const renderer = TestRenderer.create(
<MockedProvider mocks={myMock} >
<Component/>
</MockedProvider>
)

expect(renderer.toJSON()).toMatchSnapshot()

显示快照:loading

但是如果我添加一个简单的 1 毫秒超时:

  it('', done => {
const renderer = TestRenderer.create(
<MockedProvider mocks={myMock} >
<Component/>
</MockedProvider>
)

setTimeout(() => {
expect(renderer.toJSON()).toMatchSnapshot()
done()
}, 1);

我得到了一个快照:data

有没有更优雅的方法来解决这个问题?

最佳答案

您可以使用 waait 库,如 docs 所示

it('',async () => {
const renderer = TestRenderer.create(
<MockedProvider mocks={myMock} >
<Component/>
</MockedProvider>
)
await wait(0);
expect(renderer.toJSON()).toMatchSnapshot();

关于javascript - `react-apollo` `MockedProvider` 需要超时?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50224714/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com