即使响应正确,使用supertest和jest测试API错误也会失败

时间:2018-06-26 14:18:09

标签: node.js http testing jestjs supertest

我正在使用jest 23.1.0supertest 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参数,错误代码和其他各种方法,但无济于事。

1 个答案:

答案 0 :(得分:3)

我在将参数传递到Done()中时遇到了问题,导致了类似的问题。

尝试更改您的

.then(done)

.then(() => { done() })

看看是否能为您解决问题。