mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
2bc7841d0f
This helps to prevent issues where a failed test can keep a bound socket open long enough to cause other tests to fail with EADDRINUSE because the same port number is used. PR-URL: https://github.com/nodejs/node/pull/7045 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Rod Vagg <rod@vagg.org>
47 lines
1.1 KiB
JavaScript
47 lines
1.1 KiB
JavaScript
'use strict';
|
|
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
const http = require('http');
|
|
|
|
var requests = 0;
|
|
|
|
http.createServer(function(req, res) {
|
|
res.writeHead(200);
|
|
res.end('ok');
|
|
|
|
requests++;
|
|
}).listen(0, function() {
|
|
var agent = new http.Agent();
|
|
agent.defaultPort = this.address().port;
|
|
|
|
// options marked as explicitly undefined for readability
|
|
// in this test, they should STAY undefined as options should not
|
|
// be mutable / modified
|
|
var options = {
|
|
host: undefined,
|
|
hostname: common.localhostIPv4,
|
|
port: undefined,
|
|
defaultPort: undefined,
|
|
path: undefined,
|
|
method: undefined,
|
|
agent: agent
|
|
};
|
|
|
|
http.request(options, function(res) {
|
|
res.resume();
|
|
}).end();
|
|
|
|
process.on('exit', function() {
|
|
assert.equal(requests, 1);
|
|
|
|
assert.strictEqual(options.host, undefined);
|
|
assert.strictEqual(options.hostname, common.localhostIPv4);
|
|
assert.strictEqual(options.port, undefined);
|
|
assert.strictEqual(options.defaultPort, undefined);
|
|
assert.strictEqual(options.path, undefined);
|
|
assert.strictEqual(options.method, undefined);
|
|
});
|
|
}).unref();
|
|
|