'use strict'; var common = require('../common'); var assert = require('assert'); var http = require('http'); var serverSockets = []; var server = http.createServer(function(req, res) { if (serverSockets.indexOf(req.socket) === -1) { serverSockets.push(req.socket); } res.end(req.url); }); server.listen(common.PORT); var agent = http.Agent({ keepAlive: true, maxSockets: 5, maxFreeSockets: 2 }); // make 10 requests in parallel, // then 10 more when they all finish. function makeReqs(n, cb) { for (var i = 0; i < n; i++) makeReq(i, then); function then(er) { if (er) return cb(er); else if (--n === 0) setTimeout(cb, 100); } } function makeReq(i, cb) { http.request({ port: common.PORT, path: '/' + i, agent: agent }, function(res) { var data = ''; res.setEncoding('ascii'); res.on('data', function(c) { data += c; }); res.on('end', function() { assert.equal(data, '/' + i); cb(); }); }).end(); } var closed = false; makeReqs(10, function(er) { assert.ifError(er); assert.equal(count(agent.freeSockets), 2); assert.equal(count(agent.sockets), 0); assert.equal(serverSockets.length, 5); // now make 10 more reqs. // should use the 2 free reqs from the pool first. makeReqs(10, function(er) { assert.ifError(er); assert.equal(count(agent.freeSockets), 2); assert.equal(count(agent.sockets), 0); assert.equal(serverSockets.length, 8); agent.destroy(); server.close(function() { closed = true; }); }); }); function count(sockets) { return Object.keys(sockets).reduce(function(n, name) { return n + sockets[name].length; }, 0); } process.on('exit', function() { assert(closed); console.log('ok'); });