如何在 React 中使用 Jest 测试 useEffect Fetch
2021-12-26
3743
如何在 React 中使用 Jest 测试 useEffect Fetch?我尝试寻找答案,并找到了一个我复制来尝试的代码,但仍然无法通过测试。我以前没有使用过 Jest,目前正在尝试在我正在编写的代码中实现它。
这是我在 test.js 文件中的测试:
it('Displays days from 1 to 31', async () => {
expect(useEffectTest).toBe([{ day: 1 }]);
});
这是另一个名为 calendar.jsx 的组件中的 useEffect:
const useEffectTest = () => {
const [daysData, setDaysData] = useState([]);
useEffect(() => {
fetch('http://localhost:5001/chocolates')
.then((resp) => resp.json())
.then((data) => setDaysData(data));
}, []);
console.log(daysData);
};
我想测试获取的 api 是否从对象数组中获取此数据:
{ day: 1, status: 'empty' || 'open' }
提前感谢任何帮助。
1个回答
首先,您需要更新单元测试以调用您的函数,如下所示:
it('Displays days from 1 to 31', async () => {
expect(useEffectTest()).toBe([{ day: 1 }]);
});
这是因为
expect
需要将从
useEffectTest
函数返回的数据传递给它。
但是,这仍然会失败,因为您的函数没有返回任何内容。因此,我们需要更新
useEffectTest
以返回
daysData
,如下所示:
const useEffectTest = () => {
const [daysData, setDaysData] = useState([]);
useEffect(() => {
fetch('http://localhost:5001/chocolates')
.then((resp) => resp.json())
.then((data) => setDaysData(data));
}, []);
return daysData;
};
接下来,我们通常不想从单元测试中发出网络请求。这是因为网络请求会使单元测试变慢且脆弱。例如,如果您的 API 服务器出现故障,我们仍然希望单元测试通过。为了解决这些问题,我们需要模拟获取请求。模拟获取请求的一种流行方法是使用 jest-fetch-mock 库。
BitSteven
2021-12-27