mirror of
https://github.com/nodejs/node.git
synced 2024-11-30 07:27:22 +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>
56 lines
1.2 KiB
JavaScript
56 lines
1.2 KiB
JavaScript
'use strict';
|
|
require('../common');
|
|
var assert = require('assert');
|
|
var http = require('http');
|
|
var Agent = http.Agent;
|
|
|
|
var server = http.createServer(function(req, res) {
|
|
res.end('hello world');
|
|
});
|
|
|
|
server.listen(0, function() {
|
|
var agent = new Agent({
|
|
keepAlive: true,
|
|
});
|
|
|
|
var requestParams = {
|
|
host: 'localhost',
|
|
port: this.address().port,
|
|
agent: agent,
|
|
path: '/'
|
|
};
|
|
|
|
var socketKey = agent.getName(requestParams);
|
|
|
|
get(function(res) {
|
|
assert.equal(res.statusCode, 200);
|
|
res.resume();
|
|
res.on('end', function() {
|
|
process.nextTick(function() {
|
|
var freeSockets = agent.freeSockets[socketKey];
|
|
assert.equal(freeSockets.length, 1,
|
|
'expect a free socket on ' + socketKey);
|
|
|
|
//generate a random error on the free socket
|
|
var freeSocket = freeSockets[0];
|
|
freeSocket.emit('error', new Error('ECONNRESET: test'));
|
|
|
|
get(done);
|
|
});
|
|
});
|
|
});
|
|
|
|
function get(callback) {
|
|
return http.get(requestParams, callback);
|
|
}
|
|
|
|
function done() {
|
|
assert.equal(Object.keys(agent.freeSockets).length, 0,
|
|
'expect the freeSockets pool to be empty');
|
|
|
|
agent.destroy();
|
|
server.close();
|
|
process.exit(0);
|
|
}
|
|
});
|