Javascript 无法使用fetch mock模拟节点获取
我正在尝试对一个简单函数进行单元测试,该函数发送一个get请求,接收一个响应,然后返回一个带有成功或失败消息的promise对象。功能如下:Javascript 无法使用fetch mock模拟节点获取,javascript,node.js,sinon-chai,fetch-mock,Javascript,Node.js,Sinon Chai,Fetch Mock,我正在尝试对一个简单函数进行单元测试,该函数发送一个get请求,接收一个响应,然后返回一个带有成功或失败消息的promise对象。功能如下: module.exports.hello = async (event, context) => { return new Promise((resolve, reject) => { fetch("https://httpstat.us/429", { headers: { 'Content-Type': 'application
module.exports.hello = async (event, context) => {
return new Promise((resolve, reject) => {
fetch("https://httpstat.us/429", { headers: { 'Content-Type': 'application/json' } }).then(response => {
console.log(response);
if (response.status == 200) {
return response;
} else {
throw Error(response.status + ": " + response.statusText);
}
}).then(tokenData => {
resolve({ status: 200, body: JSON.stringify({ statusText: 'Success' }) });
}).catch(error => {
reject(error.message);
});
});
};
在单元测试时,我使用fetchmock来模拟对api的调用,并有一个自定义响应。代码如下:
it('hello returns failure message', (done) => {
fetchMock.get('*', {
status: 429,
statusText: "Too Many Nothings",
headers: { 'Content-type': 'application/json' }
});
edx.hello(null, null).catch(error => {
expect(error).to.equal('429: Too Many Requests');
}).then(() => {
done();
}).catch(error => {
done(error);
});
});
但这段代码并不是在模拟fetch请求,因为当我打印响应文本时,它是API作为响应发送的“太多请求”,而不是模拟的“太多虚无”。我对NodeJS是新手。请告诉我我做错了什么。如果您使用
节点获取
包,它在node.js的全局范围内不可用。为了使fetch mock
工作,您必须将fetch分配给global
对象(例如,通过import“node fetch”;
而不是import fetch from“node fetch”;
),或者将fetch注入到您的测试方法中
发件人:
全局或非全局
fetch可由您的代码全局或本地使用。重要的是
确定哪一个应用于您的代码库,因为它将影响您的工作方式
使用fetchmock
全局提取
在以下场景中,fetch将是全局的
- 在浏览器中使用本机获取(或多边形填充)时
- 在node.js进程中将node fetch分配给global时(有时在同构代码库中使用的模式)
- 在node.js中使用节点获取而不分配给全局
- 在浏览器中使用fetch ponyfill
- 使用在内部使用fetch-ponyfill的库
- 某些构建设置会导致非全局获取,尽管情况并非总是如此
const fetchMock = require('fetch-mock'); const myMock =
fetchMock.sandbox().mock('/home', 200); // pass myMock in to your
application code, instead of fetch, run it, then...
expect(myMock.called('/home')).to.be.true;
如果使用
node fetch
package,则它在node.js的全局范围内不可用。为了使fetch mock
工作,您必须将fetch分配给global
对象(例如,通过import“node fetch”;
而不是import fetch from“node fetch”;
),或者将fetch注入到您的测试方法中
发件人:
全局或非全局
fetch可由您的代码全局或本地使用。重要的是
确定哪一个应用于您的代码库,因为它将影响您的工作方式
使用fetchmock
全局提取
在以下场景中,fetch将是全局的
- 在浏览器中使用本机获取(或多边形填充)时
- 在node.js进程中将node fetch分配给global时(有时在同构代码库中使用的模式)
- 在node.js中使用节点获取而不分配给全局
- 在浏览器中使用fetch ponyfill
- 使用在内部使用fetch-ponyfill的库
- 某些构建设置会导致非全局获取,尽管情况并非总是如此
const fetchMock = require('fetch-mock'); const myMock =
fetchMock.sandbox().mock('/home', 200); // pass myMock in to your
application code, instead of fetch, run it, then...
expect(myMock.called('/home')).to.be.true;