由于未解决的承诺,Jest 中的异步测试失败
Async test in Jest failing due to unresolved promise
我正在学习 Jest 并且 运行 遇到了一个问题,试图模拟 returns fetch
承诺的异步函数。
在他们的文档中,有这样的内容:
“如果一个承诺根本没有解决,这个错误可能会被抛出:
- 错误:超时 - 未在 jasmine.DEFAULT_TIMEOUT_INTERVAL.
指定的超时内调用异步回调
最常见的是,这是由冲突的 Promise 实现引起的。考虑用您自己的实现替换全局承诺实现,例如 global.Promise = require.requireActual('promise');
and/or 将使用的 Promise 库合并为一个。"
这可能是问题所在,但我不清楚如何解决我的问题或确定 Promise
哪里出了问题。
也许我对 Jest 中模拟的理解有误?我尝试使用他们的示例,当然效果很好。 (https://facebook.github.io/jest/docs/tutorial-async.html#content)
这是我在控制台中得到的:
● endpoint can receive form data › can parse and fulfill a promise
Timeout - Async callback was not invoked within timeout specified by jasmine.DEFAULT_TIMEOUT_INTERVAL.
这是我的模块和测试:
// myModule/index.js
import { OK } from 'http-status-codes';
import request from './request';
import parseForm from '../../../../modules/parseMultiPart';
export default (req, res, next) => parseForm(req)
.then(body => request(body, req)
.then(result => result.text())
.then(result => res.status(OK).send(result)))
.catch(next);
// myModule/request.js
import fetch from 'node-fetch';
export default (body, req) => fetch('http://url', {
method: 'POST',
body: JSON.stringify(body.fields),
headers: {
'Content-Type': 'application/json',
'X-Request-Id': req.id
}
});
// myModule/__tests__/myModule.test.js
import MockReq from 'mock-req';
import MockRes from 'mock-res';
import myModule from '../';
jest.mock('../request');
describe('endpoint can receive form data', () => {
const response = new MockRes();
const request = new MockReq({
method: 'POST',
url: '/webhook',
headers: {
'Content-Disposition': 'form-data; name="file"; filename="plain.txt"',
'Content-Type': 'multipart/form-data; custom=stuff; boundary=----TLV0SrKD4z1TRxRhAPUvZ',
'Content-Length': 213
}
});
it('can parse and fulfill a promise', () => myModule(request, response)
.then(text => expect(text).toEqual('API Event Received'))
);
});
// myModule/__mocks__/request.js
export default function request() {
return new Promise((resolve) => {
process.nextTick(
() => resolve('API Event Received')
);
});
}
我嘲笑错了。在这种情况下需要模拟函数,而不是数据:
jest.mock('../parseMultiPart');
jest.mock('../request');
我的请求不正确,Promise 永远不会返回。
我正在学习 Jest 并且 运行 遇到了一个问题,试图模拟 returns fetch
承诺的异步函数。
在他们的文档中,有这样的内容:
“如果一个承诺根本没有解决,这个错误可能会被抛出:
- 错误:超时 - 未在 jasmine.DEFAULT_TIMEOUT_INTERVAL.
指定的超时内调用异步回调
最常见的是,这是由冲突的 Promise 实现引起的。考虑用您自己的实现替换全局承诺实现,例如 global.Promise = require.requireActual('promise');
and/or 将使用的 Promise 库合并为一个。"
这可能是问题所在,但我不清楚如何解决我的问题或确定 Promise
哪里出了问题。
也许我对 Jest 中模拟的理解有误?我尝试使用他们的示例,当然效果很好。 (https://facebook.github.io/jest/docs/tutorial-async.html#content)
这是我在控制台中得到的:
● endpoint can receive form data › can parse and fulfill a promise
Timeout - Async callback was not invoked within timeout specified by jasmine.DEFAULT_TIMEOUT_INTERVAL.
这是我的模块和测试:
// myModule/index.js
import { OK } from 'http-status-codes';
import request from './request';
import parseForm from '../../../../modules/parseMultiPart';
export default (req, res, next) => parseForm(req)
.then(body => request(body, req)
.then(result => result.text())
.then(result => res.status(OK).send(result)))
.catch(next);
// myModule/request.js
import fetch from 'node-fetch';
export default (body, req) => fetch('http://url', {
method: 'POST',
body: JSON.stringify(body.fields),
headers: {
'Content-Type': 'application/json',
'X-Request-Id': req.id
}
});
// myModule/__tests__/myModule.test.js
import MockReq from 'mock-req';
import MockRes from 'mock-res';
import myModule from '../';
jest.mock('../request');
describe('endpoint can receive form data', () => {
const response = new MockRes();
const request = new MockReq({
method: 'POST',
url: '/webhook',
headers: {
'Content-Disposition': 'form-data; name="file"; filename="plain.txt"',
'Content-Type': 'multipart/form-data; custom=stuff; boundary=----TLV0SrKD4z1TRxRhAPUvZ',
'Content-Length': 213
}
});
it('can parse and fulfill a promise', () => myModule(request, response)
.then(text => expect(text).toEqual('API Event Received'))
);
});
// myModule/__mocks__/request.js
export default function request() {
return new Promise((resolve) => {
process.nextTick(
() => resolve('API Event Received')
);
});
}
我嘲笑错了。在这种情况下需要模拟函数,而不是数据:
jest.mock('../parseMultiPart');
jest.mock('../request');
我的请求不正确,Promise 永远不会返回。