From 131514be0a06a31dee6827da31056e02e880f38a Mon Sep 17 00:00:00 2001 From: Tim De Pauw Date: Wed, 16 Jan 2019 14:31:33 +0100 Subject: [PATCH] http: make ClientRequest#setTimeout() a no-op after end Fixes: https://github.com/nodejs/node/issues/25499 Originally discovered and resolved by @szmarczak. --- lib/_http_client.js | 4 +++ .../test-http-client-set-timeout-after-end.js | 33 +++++++++++++++++++ 2 files changed, 37 insertions(+) create mode 100644 test/parallel/test-http-client-set-timeout-after-end.js diff --git a/lib/_http_client.js b/lib/_http_client.js index 95488bc5e7049d..943441f1a1db33 100644 --- a/lib/_http_client.js +++ b/lib/_http_client.js @@ -731,6 +731,10 @@ function _deferToConnect(method, arguments_, cb) { } ClientRequest.prototype.setTimeout = function setTimeout(msecs, callback) { + if (this._ended) { + return this; + } + listenSocketTimeout(this); msecs = validateTimerDuration(msecs); if (callback) this.once('timeout', callback); diff --git a/test/parallel/test-http-client-set-timeout-after-end.js b/test/parallel/test-http-client-set-timeout-after-end.js new file mode 100644 index 00000000000000..99bbf3dd1bc766 --- /dev/null +++ b/test/parallel/test-http-client-set-timeout-after-end.js @@ -0,0 +1,33 @@ +'use strict'; + +// Test https://github.com/nodejs/node/issues/25499 fix. + +const { mustCall } = require('../common'); + +const { Agent, createServer, get } = require('http'); +const { strictEqual } = require('assert'); + +const server = createServer(mustCall((req, res) => { + res.end(); +})); + +server.listen(0, () => { + const agent = new Agent({ keepAlive: true, maxSockets: 1 }); + const port = server.address().port; + + let socket; + + const req = get({ agent, port }, (res) => { + res.on('end', () => { + strictEqual(req.setTimeout(0), req); + strictEqual(socket.listenerCount('timeout'), 0); + agent.destroy(); + server.close(); + }); + res.resume(); + }); + + req.on('socket', (sock) => { + socket = sock; + }); +});