为了账号安全,请及时绑定邮箱和手机立即绑定

如何通过模拟来测试 axios 本身?

如何通过模拟来测试 axios 本身?

森林海 2022-10-13 15:43:30
我刚刚开始学习反应单元测试,整个模拟的东西让我感到困惑,我无法理解。我正在使用 axios 来获取数据并将其显示在应用程序组件中:const [ data, setData ] = React.useState(null);    useEffect(        () => {            const url = '/url';            axios.get(url).then((res) => setData(res.data)).catch((err) => {                console.log('error happened' + err);            });        },        [ data ]    );    return (        <div>            {data ? <p data-testid="name">{data.name}</p> : <p data-testid="loading">Loading...</p>}        </div>    );我在 app.test.js 中测试了整个加载和命名:afterEach(cleanup);describe('App', () => {    test('Render app', async () => {        render(<App />);        expect(screen.getByTestId('loading')).toBeInTheDocument();        const name = await waitForElement(() => screen.getByTestId('name'));        expect(name).toBeInTheDocument();        expect(screen.queryByTestId('loading')).toBeNull();    });});所有这些测试都成功通过。我想要实现的是如何通过在 app.test.js 中以最简单的方式模拟它来测试 axios 本身?
查看完整描述

1 回答

?
LEATH

TA贡献1936条经验 获得超7个赞

您可以针对您的请求尝试两种方案,其中它失败和成功并相应地有一些断言。至于涉及 axios 的测试工作流程,这个答案很好地描述了它,而不使用任何额外的库:stackoverflow.com/a/51654713/7040146



查看完整回答
反对 回复 2022-10-13
  • 1 回答
  • 0 关注
  • 104 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号