From 96f93cc5004a5aff1e503aaf0435779671a48a19 Mon Sep 17 00:00:00 2001 From: Matteo Collina Date: Tue, 2 May 2023 22:02:17 +0200 Subject: [PATCH] http: remove internal error in assignSocket MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Change ServerResponse.assignSocket to not throw an internal error, but an error with its own code. Signed-off-by: Matteo Collina PR-URL: https://github.com/nodejs/node/pull/47723 Reviewed-By: Marco Ippolito Reviewed-By: Robert Nagy Reviewed-By: Luigi Pinca Reviewed-By: Tobias Nießen --- doc/api/errors.md | 7 +++++++ lib/_http_server.js | 5 ++++- lib/internal/errors.js | 2 ++ test/parallel/test-http-server-response-standalone.js | 6 ++++++ 4 files changed, 19 insertions(+), 1 deletion(-) diff --git a/doc/api/errors.md b/doc/api/errors.md index 2336274e7000f3..992ab1e7a21932 100644 --- a/doc/api/errors.md +++ b/doc/api/errors.md @@ -1438,6 +1438,12 @@ Status code was outside the regular status code range (100-999). The client has not sent the entire request within the allowed time. + + +### `ERR_HTTP_SOCKET_ASSIGNED` + +The given [`ServerResponse`][] was already assigned a socket. + ### `ERR_HTTP_SOCKET_ENCODING` @@ -3590,6 +3596,7 @@ The native call from `process.cpuUsage` could not be processed. [`Object.getPrototypeOf`]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/getPrototypeOf [`Object.setPrototypeOf`]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/setPrototypeOf [`REPL`]: repl.md +[`ServerResponse`]: http.md#class-httpserverresponse [`Writable`]: stream.md#class-streamwritable [`child_process`]: child_process.md [`cipher.getAuthTag()`]: crypto.md#ciphergetauthtag diff --git a/lib/_http_server.js b/lib/_http_server.js index e6e592451b3230..774bdc368f4564 100644 --- a/lib/_http_server.js +++ b/lib/_http_server.js @@ -75,6 +75,7 @@ const { ERR_HTTP_HEADERS_SENT, ERR_HTTP_INVALID_STATUS_CODE, ERR_HTTP_SOCKET_ENCODING, + ERR_HTTP_SOCKET_ASSIGNED, ERR_INVALID_ARG_VALUE, ERR_INVALID_CHAR, } = codes; @@ -276,7 +277,9 @@ function onServerResponseClose() { } ServerResponse.prototype.assignSocket = function assignSocket(socket) { - assert(!socket._httpMessage); + if (socket._httpMessage) { + throw new ERR_HTTP_SOCKET_ASSIGNED(); + } socket._httpMessage = this; socket.on('close', onServerResponseClose); this.socket = socket; diff --git a/lib/internal/errors.js b/lib/internal/errors.js index aa4a149b189699..254f2c0279b47e 100644 --- a/lib/internal/errors.js +++ b/lib/internal/errors.js @@ -1167,6 +1167,8 @@ E('ERR_HTTP_INVALID_HEADER_VALUE', 'Invalid value "%s" for header "%s"', TypeError); E('ERR_HTTP_INVALID_STATUS_CODE', 'Invalid status code: %s', RangeError); E('ERR_HTTP_REQUEST_TIMEOUT', 'Request timeout', Error); +E('ERR_HTTP_SOCKET_ASSIGNED', + 'ServerResponse has an already assigned socket', Error); E('ERR_HTTP_SOCKET_ENCODING', 'Changing the socket encoding is not allowed per RFC7230 Section 3.', Error); E('ERR_HTTP_TRAILER_INVALID', diff --git a/test/parallel/test-http-server-response-standalone.js b/test/parallel/test-http-server-response-standalone.js index ec6d1e89e38525..bc7ca56f894bde 100644 --- a/test/parallel/test-http-server-response-standalone.js +++ b/test/parallel/test-http-server-response-standalone.js @@ -31,4 +31,10 @@ const ws = new Writable({ res.assignSocket(ws); +assert.throws(function() { + res.assignSocket(ws); +}, { + code: 'ERR_HTTP_SOCKET_ASSIGNED' +}); + res.end('hello world');