我正在使用jest 23.1.0
和supertest 3.1.0
。我正在为后端编写一些测试,并且一切正常,但是对于特定路由的特定情况,即使响应对象似乎包含正确的信息,该测试也会失败。测试是检查参数是否为有效的JSON,并且是这样的:
describe('GET /graph', () => {
it('invalid JSON', (done) => {
request(app)
.get('/graph')
.set('Accept', 'application/json')
.expect('Content-Type', /json/)
.expect(415)
.then(done);
});
});
在这种情况下,我实际上根本没有发送任何参数,但是即使我确实发送了一些无效的JSON,问题也一样。无论如何,这两种情况都会触发相同的后端检查,即:
module.exports = (req, res, next) => {
let dataParameters;
try {
dataParameters = JSON.parse(req.query.dataParameters);
}
catch(error) {
return(res.status(415).send({
message: "Request parameters are not a valid JSON object",
other: `${error.name} - ${error.message}`
}));
}
...
当我开玩笑时,测试失败,并且控制台的输出如下:
GET /graph
✕ invalid JSON (6ms)
● GET /graph › invalid JSON
Failed: Object {
"header": Object {
"connection": "close",
"content-length": "125",
"content-type": "application/json; charset=utf-8",
"date": "Tue, 26 Jun 2018 13:58:48 GMT",
"etag": "W/\"7d-GGhtZ8CfzWfmANZW28JTNC5bNjU\"",
"x-powered-by": "Express",
},
"req": Object {
"data": undefined,
"headers": [Object],
"method": "GET",
"url": "http://127.0.0.1:35875/graph",
},
"status": 415,
"text": "{\"message\":\"Request parameters are not a valid JSON object\",\"other\":\"SyntaxError - Unexpected token u in JSON at position 0\"}",
}
at Env.fail (node_modules/jest-jasmine2/build/jasmine/Env.js:537:34)
因此,查看对象的笑话会显示出路由似乎正在返回正确的HTTP状态和消息,但是实际测试本身并未通过超级测试来处理。我使用相同的响应格式和测试技术来测试其他API错误,但这不会发生。我尝试更改request
参数,错误代码和其他各种方法,但无济于事。
答案 0 :(得分:3)
我在将参数传递到Done()中时遇到了问题,导致了类似的问题。
尝试更改您的
.then(done)
到
.then(() => { done() })
看看是否能为您解决问题。