From 8029a2473e032c5006d2dfc3044bdce1b221dee4 Mon Sep 17 00:00:00 2001 From: Robert Nagy Date: Tue, 8 May 2018 21:56:24 +0200 Subject: [PATCH] http: always emit close on req and res PR-URL: https://github.com/nodejs/node/pull/20611 Fixes: https://github.com/nodejs/node/issues/20600 Reviewed-By: James M Snell Reviewed-By: Trivikram Kamat --- lib/_http_server.js | 2 ++ test/parallel/test-http-req-res-close.js | 16 ++++++++++++++++ 2 files changed, 18 insertions(+) create mode 100644 test/parallel/test-http-req-res-close.js diff --git a/lib/_http_server.js b/lib/_http_server.js index 9c8b5cb8fbfe8e..928b57b3719684 100644 --- a/lib/_http_server.js +++ b/lib/_http_server.js @@ -561,6 +561,8 @@ function resOnFinish(req, res, socket, state, server) { req._dump(); res.detachSocket(socket); + req.emit('close'); + res.emit('close'); if (res._last) { if (typeof socket.destroySoon === 'function') { diff --git a/test/parallel/test-http-req-res-close.js b/test/parallel/test-http-req-res-close.js new file mode 100644 index 00000000000000..240134cb5d0902 --- /dev/null +++ b/test/parallel/test-http-req-res-close.js @@ -0,0 +1,16 @@ +'use strict'; + +const common = require('../common'); +const http = require('http'); + +const server = http.Server(common.mustCall((req, res) => { + res.end(); + res.on('finish', common.mustCall()); + res.on('close', common.mustCall()); + req.on('close', common.mustCall()); + res.socket.on('close', () => server.close()); +})); + +server.listen(0, common.mustCall(() => { + http.get({ port: server.address().port }, common.mustCall()); +}));