From 508581368808b0ff47e932f32212be419e007329 Mon Sep 17 00:00:00 2001 From: Rafael Silva Date: Sun, 6 Feb 2022 06:28:55 -0300 Subject: [PATCH] doc: add stream pipelining note on Http usage PR-URL: https://github.com/nodejs/node/pull/41796 Reviewed-By: Robert Nagy Reviewed-By: Matteo Collina Reviewed-By: Mary Marchini Reviewed-By: James M Snell --- doc/api/stream.md | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/doc/api/stream.md b/doc/api/stream.md index 0b4fba8db96eac..efc263ccffedc8 100644 --- a/doc/api/stream.md +++ b/doc/api/stream.md @@ -2463,6 +2463,28 @@ run().catch(console.error); after the `callback` has been invoked. In the case of reuse of streams after failure, this can cause event listener leaks and swallowed errors. +`stream.pipeline()` closes all the streams when an error is raised. +The `IncomingRequest` usage with `pipeline` could lead to an unexpected behavior +once it would destroy the socket without sending the expected response. +See the example below: + +```js +const fs = require('fs'); +const http = require('http'); +const { pipeline } = require('stream'); + +const server = http.createServer((req, res) => { + const fileStream = fs.createReadStream('./fileNotExist.txt'); + pipeline(fileStream, res, (err) => { + if (err) { + console.log(err); // No such file + // this message can't be sent once `pipeline` already destroyed the socket + return res.end('error!!!'); + } + }); +}); +``` + ### `stream.compose(...streams)`