在 nodejs 中等待来自 POST 请求的 JSON 响应数据(mocha 测试)

Wait for JSON response data from POST request in nodejs (mocha test)

我知道有几个问题与我的相关,但我没有发现任何有用的问题:

那么,我认为这是一个合理的问题。我实际上是通过 post 请求在我的服务器(节点中的快速路由)中执行一些加密:

app.post('/encrypt', encrypt);

加密正在做:

function encrypt(req,res) {
    if(req.body.key && req.body.message) {
        var encryptedMessage = Encrypter.encrypt(req.body.key,req.body.message);

        return res.status(200).json({ message: encryptedMessage });
     }

     res.status(409).json({ message: 'the message could not be encrypted, no key found' });
    }
}

因此,我通过 console.log 对此进行了测试,它正在运行。当服务器收到请求时,正在生成加密消息。

同时,我正在用 mocha 测试我的东西,我是这样做的:

describe('# Here is where the fun starts ', function () {
  /**
   * Start and stop the server
   */
  before(function () {
    server.listen(port);
  });

  after(function () {
    server.close();
  });

  it('Requesting an encrypted message', function(done) {
    var postData = querystring.stringify({
      key : key,
      message : message
    });

    var options = {
      hostname: hostname,
      port: port,
      path: '/encrypt',
      method: 'POST',
      headers: {
        'Content-Type': 'application/x-www-form-urlencoded',
        'Content-Length': postData.length
      }
    };

    var req = http.request(options, function(res) {
      res.statusCode.should.equal(200);
      var encryptedMessage = res.message;
      encryptedMessage.should.not.equal(message);
      done();
    });

    req.on('error', function(e) {
      //I'm aware should.fail doesn't work like this
      should.fail('problem with request: ' + e.message);
    });

    req.write(postData);
    req.end();
  });
});

因此,每当我执行测试时,它都会失败并返回 Uncaught TypeError: Cannot read property 'should' of undefined,因为 res.message 不存在。

res.on 的

None(数据、结束、事件正在运行,所以我想数据应该可以从那里获得。首先我有这个:

var req = http.request(options, function(res) {
  res.statusCode.should.equal(200);
  var encryptedMessage;

  res.on('data', function (chunk) {
    console.log('BODY: ' + chunk);
    encryptedMessage = chunk.message;
  });

  encryptedMessage.should.not.equal(message);
  done();
});

但是 res.on 从未被访问过(console.log 没有显示任何内容)。因此,我有点被困在这里。我肯定做错了一些基本的事情,但我没有线索,而且我发现的许多问题似乎并不适用于我的情况。

很奇怪,如果我启动一个测试服务器然后卷曲它 curl --data "key=secret&message=veryimportantstuffiabsolutellyneedtoprotect" localhost:2409/encrypt

Curl 永远等待。

实际上我一开始做得很好,问题确实和 中的一样,我实际上是 "clearing" 我在 post 之前使用 done() 的上下文数据到了。解决方案是:

  var req = http.request(options, function(res) {
    res.statusCode.should.equal(200);

    res.on('data', function(data) {
      encryptedMessage = JSON.parse(data).message;
      encryptedMessage.should.not.equal(message);
      done();
    });
  });

只有在数据受到威胁时才会调用 done()。否则,mocha不会等待答案。