Skip to content
This repository has been archived by the owner on May 5, 2023. It is now read-only.

Commit

Permalink
close free sockets
Browse files Browse the repository at this point in the history
  • Loading branch information
tareksha committed Jul 4, 2018
1 parent f5fcafd commit d55865c
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 0 deletions.
5 changes: 5 additions & 0 deletions index.js
Original file line number Diff line number Diff line change
Expand Up @@ -133,6 +133,11 @@ Agent.prototype.addRequest = function addRequest(req, _opts) {
// responsibility for this `req` to the Agent from here on
socket.addRequest(req, opts);
} else if (socket) {
function onfree() {
// TODO reuse sockets
socket.destroy();
}
socket.on('free', onfree);
req.onSocket(socket);
} else {
const err = new Error(
Expand Down
24 changes: 24 additions & 0 deletions test/test.js
Original file line number Diff line number Diff line change
Expand Up @@ -398,6 +398,30 @@ describe('"http" module', function() {
});
});

it('should free sockets after use', function(done) {
var agent = new Agent(function(req, opts, fn) {
var socket = net.connect(opts);
fn(null, socket);
});

// add HTTP server "request" listener
var gotReq = false;
server.once('request', function(req, res) {
gotReq = true;
res.end();
});

var info = url.parse('http://127.0.0.1:' + port + '/foo');
info.agent = agent;
http.get(info, function(res) {
res.socket.emit('free');
assert.equal(true, res.socket.destroyed);
assert(gotReq);
done();
});
});


describe('PassthroughAgent', function() {
it('should pass through to `http.globalAgent`', function(done) {
// add HTTP server "request" listener
Expand Down

0 comments on commit d55865c

Please sign in to comment.