Browse Source

test: fix `http-upgrade-client` flakiness

It's not guaranteed that the socket data is received in the same chunk
as the upgrade response. Listen for the `data` event to make sure all
the data is received.

PR-URL: https://github.com/nodejs/node/pull/4602
Reviewed-By: Brian White <mscdex@mscdex.net>
Reviewed-By: James M Snell <jasnell@gmail.com>
v5.x
Santiago Gimeno 9 years ago
committed by Rod Vagg
parent
commit
8f0cf38f89
  1. 11
      test/parallel/test-http-upgrade-client.js

11
test/parallel/test-http-upgrade-client.js

@ -34,9 +34,14 @@ srv.listen(common.PORT, '127.0.0.1', function() {
var req = http.get({ port: common.PORT }); var req = http.get({ port: common.PORT });
req.on('upgrade', function(res, socket, upgradeHead) { req.on('upgrade', function(res, socket, upgradeHead) {
// XXX: This test isn't fantastic, as it assumes that the entire response var recvData = upgradeHead;
// from the server will arrive in a single data callback socket.on('data', function(d) {
assert.equal(upgradeHead, 'nurtzo'); recvData += d;
});
socket.on('close', common.mustCall(function() {
assert.equal(recvData, 'nurtzo');
}));
console.log(res.headers); console.log(res.headers);
var expectedHeaders = {'hello': 'world', var expectedHeaders = {'hello': 'world',

Loading…
Cancel
Save