From d6b50c66ccd4db36a4c167c2109d15c8243e6242 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() noop at end Originally discovered and resolved by @szmarczak. PR-URL: /~https://github.com/nodejs/node/pull/25536 Fixes: /~https://github.com/nodejs/node/issues/25499 Reviewed-By: James M Snell Reviewed-By: Luigi Pinca --- 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 cbc406f5e8b8d0..603d37de9b19a6 100644 --- a/lib/_http_client.js +++ b/lib/_http_client.js @@ -733,6 +733,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; + }); +});