From 2114fa472bafc93188ee2455a4123eaccc4e30d0 Mon Sep 17 00:00:00 2001 From: Zach Bjornson Date: Sun, 26 Mar 2023 13:30:05 -0700 Subject: [PATCH] doc: clarify http error events after calling destroy() PR-URL: https://github.com/nodejs/node/pull/46903 Reviewed-By: Paolo Insogna Reviewed-By: Matteo Collina Reviewed-By: Luigi Pinca --- doc/api/http.md | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/doc/api/http.md b/doc/api/http.md index 0b8c7e7ab1f206..70ae8c04297792 100644 --- a/doc/api/http.md +++ b/doc/api/http.md @@ -3606,7 +3606,7 @@ the following events will be emitted in the following order: * (connection closed here) * `'aborted'` on the `res` object * `'error'` on the `res` object with an error with message - `'Error: aborted'` and code `'ECONNRESET'`. + `'Error: aborted'` and code `'ECONNRESET'` * `'close'` * `'close'` on the `res` object @@ -3615,7 +3615,7 @@ events will be emitted in the following order: * (`req.destroy()` called here) * `'error'` with an error with message `'Error: socket hang up'` and code - `'ECONNRESET'` + `'ECONNRESET'`, or the error with which `req.destroy()` was called * `'close'` If `req.destroy()` is called before the connection succeeds, the following @@ -3624,7 +3624,7 @@ events will be emitted in the following order: * `'socket'` * (`req.destroy()` called here) * `'error'` with an error with message `'Error: socket hang up'` and code - `'ECONNRESET'` + `'ECONNRESET'`, or the error with which `req.destroy()` was called * `'close'` If `req.destroy()` is called after the response is received, the following @@ -3635,8 +3635,8 @@ events will be emitted in the following order: * `'data'` any number of times, on the `res` object * (`req.destroy()` called here) * `'aborted'` on the `res` object -* `'error'` on the `res` object with an error with message - `'Error: aborted'` and code `'ECONNRESET'`. +* `'error'` on the `res` object with an error with message `'Error: aborted'` + and code `'ECONNRESET'`, or the error with which `req.destroy()` was called * `'close'` * `'close'` on the `res` object @@ -3674,9 +3674,11 @@ events will be emitted in the following order: Setting the `timeout` option or using the `setTimeout()` function will not abort the request or do anything besides add a `'timeout'` event. -Passing an `AbortSignal` and then calling `abort` on the corresponding +Passing an `AbortSignal` and then calling `abort()` on the corresponding `AbortController` will behave the same way as calling `.destroy()` on the -request itself. +request. Specifically, the `'error'` event will be emitted with an error with +the message `'AbortError: The operation was aborted'`, the code `'ABORT_ERR'` +and the `cause`, if one was provided. ## `http.validateHeaderName(name[, label])`