node.js - 即使响应正确,使用 supertest 和 jest 测试 API 错误也会失败
问题描述
我正在使用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}`
}));
}
...
当我运行 jest 时,测试失败,控制台的输出是这样的:
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)
因此,查看对象 jest 打印似乎该路由正在返回正确的 HTTP 状态和消息,但是不是超测试处理它,而是实际测试本身失败了。我使用相同的响应格式和测试技术来测试其他 API 错误,但这不会发生。我试过更改request
参数、错误代码和其他各种东西,但无济于事。
解决方案
我在将参数传递给 Done() 时遇到了问题,导致了类似的问题。
尝试改变你的
.then(done)
至
.then(() => { done() })
看看是否可以为您解决问题。
推荐阅读
- string - 在 Scala 中将 IndexedSequence[Map[String, Map[String, Int]]] 转换为 Map[String, Map[String, Int]]
- python - python tkinter treeview 将焦点设置为新插入的项目
- .net-core - 登录成功后如何将用户重定向到请求的资源
- oracle - 列列表中select的join方法
- python - 具有可变上限的循环
- css - 如何在离子框架 v4 和 Angular 7 中调整图标大小
- websocket - Error: Error when readinrror: Error when reading 'bin/main.dart': 系统找不到指定的路径
- python - 在 MultiIndex DataFrame 的较低级别更改多个值
- sql - 如何从两个不同的表中获取记录
- r - 使用 C 外部指针的 R 内存泄漏