【发布时间】:2020-07-10 00:59:10
【问题描述】:
我有这个自定义钩子:
import React from 'react';
import { useMessageError } from 'components/Message/UseMessage';
export interface Country {
code: string;
name: string;
}
export default function useCountry(): Array<Country> {
const [countries, setCountries] = React.useState<Country[]>([]);
const { showErrorMessage } = useMessageError();
React.useEffect(() => {
fetch('/api/countries', {
method: 'GET',
})
.then(data => data.json())
.then(function(data) {
// ..
})
.catch(() => showErrorMessage());
}, []);
return countries;
}
如果会有无效响应,我想测试捕获错误。这样,由于showErrorMessage(),应该会出现错误消息。我有这个测试:
const showErrorMessage = jest.fn();
jest.mock('components/Message/UseMessage', () => ({
useMessageError: () => ({
showErrorMessage: showErrorMessage,
}),
}));
import useCountry from 'components/Country/useCountry';
import { renderHook } from '@testing-library/react-hooks';
import { enableFetchMocks } from 'jest-fetch-mock';
enableFetchMocks();
describe('The useCountry hook', () => {
it('should show error message', async () => {
jest.spyOn(global, 'fetch').mockImplementation(() =>
Promise.resolve({
json: () => Promise.reject(),
} as Response),
);
const { result, waitForNextUpdate } = renderHook(() => useCountry());
await waitForNextUpdate();
expect(fetch).toHaveBeenCalled();
expect(showErrorMessage).toHaveBeenCalled();
expect(result.current).toEqual([]);
});
});
但是,我得到一个错误:
超时 - 在 jest.setTimeout.Timeout 指定的 5000 毫秒超时内未调用异步回调。在 jest.setTimeout.Error 指定的 5000 毫秒超时内未调用异步回调
我在这里做错了什么?我认为它与await waitForNextUpdate(); 有某种关系,但我真的不确定以及如何管理它。
【问题讨论】:
-
这肯定与卡在
await waitForNextUpdate();的进程有某种关系你试过调试它吗?如果您在 Webstorm 上,只需右键单击测试并使用“调试”并逐步前进。
标签: javascript typescript jestjs jest-fetch-mock react-hooks-testing-library