Skip to content

Commit

Permalink
test: improve http test reliability
Browse files Browse the repository at this point in the history
Fake the socket handle to ensure an immediate error is returned
uniformly across all platforms.

PR-URL: #13693
Reviewed-By: James M Snell <[email protected]>
  • Loading branch information
mscdex authored and addaleax committed Jun 20, 2017
1 parent b8271a4 commit 8ec6881
Showing 1 changed file with 31 additions and 3 deletions.
34 changes: 31 additions & 3 deletions test/parallel/test-http-client-immediate-error.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,36 @@

const common = require('../common');
const assert = require('assert');
const net = require('net');
const http = require('http');
const req = http.get({ host: '127.0.0.1', port: 1 });
req.on('error', common.mustCall((err) => {
assert.strictEqual(err.code, 'ECONNREFUSED');
const uv = process.binding('uv');
const { async_id_symbol } = process.binding('async_wrap');
const { newUid } = require('async_hooks');

const agent = new http.Agent();
agent.createConnection = common.mustCall((cfg) => {
const sock = new net.Socket();

// Fake the handle so we can enforce returning an immediate error
sock._handle = {
connect: common.mustCall((req, addr, port) => {
return uv.UV_ENETUNREACH;
}),
readStart() {},
close() {}
};

// Simulate just enough socket handle initialization
sock[async_id_symbol] = newUid();

sock.connect(cfg);
return sock;
});

http.get({
host: '127.0.0.1',
port: 1,
agent
}).on('error', common.mustCall((err) => {
assert.strictEqual(err.code, 'ENETUNREACH');
}));

0 comments on commit 8ec6881

Please sign in to comment.