如何解决使用 Jest 和 Typescript 在 Node.js 中模拟和取消模拟“node-fetch”模块的正确方法是什么?
测试功能
import fetch from 'node-fetch';
class Services () {
someFunc() {
const data = await fetch(dummy url);
// business logic
}
anotherFunc() {
const data = await fetch(dummy url);
// business logic
}
}
export default new Service();
实际测试
import fetch from 'node-fetch';
jest.mock('node-fetch',() => jest.fn());
beforeEach(() => {
mocked(fetch).mockClear();
})
describe('test first method',() => {
it('should fetch some data without mock fetch',async () => {
const data = await service.someFunc();
expect(data).toHaveProperty('items');
})
})
describe('test second method',() => {
it('should return data with mock fetch',async () => {
mocked(fetch).mockImplementationOnce(() => Promise.reject());
const data = await service.anotherFunc();
expect(data).toHaveProperty('items');
})
})
此时我在第一个描述情况下的获取函数有问题,并得到 “TypeError:无法读取未定义的属性 'then'”。所以我只在第二种描述情况下需要一个模拟版本的 fetch 。在第一个描述情况下,它应该使用 fetch 而不使用模拟函数替换。
我该如何解决?将不胜感激协助。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。