From 676427312708851c0425d36f9b3d8667fa45e14b Mon Sep 17 00:00:00 2001 From: Marvin ROGER Date: Tue, 22 Oct 2024 18:14:02 +0200 Subject: [PATCH] stream: propagate AbortSignal reason PR-URL: https://github.com/nodejs/node/pull/55473 Reviewed-By: Yagiz Nizipli Reviewed-By: Benjamin Gruenbaum Reviewed-By: Robert Nagy Reviewed-By: James M Snell Reviewed-By: LiviaMedeiros Reviewed-By: Matteo Collina Reviewed-By: Jake Yuesong Li --- lib/internal/streams/pipeline.js | 2 +- test/parallel/test-stream-pipeline.js | 4 +++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/lib/internal/streams/pipeline.js b/lib/internal/streams/pipeline.js index 247a557686474e..60d050d54e5cdb 100644 --- a/lib/internal/streams/pipeline.js +++ b/lib/internal/streams/pipeline.js @@ -203,7 +203,7 @@ function pipelineImpl(streams, callback, opts) { validateAbortSignal(outerSignal, 'options.signal'); function abort() { - finishImpl(new AbortError()); + finishImpl(new AbortError(undefined, { cause: outerSignal?.reason })); } addAbortListener ??= require('internal/events/abort_listener').addAbortListener; diff --git a/test/parallel/test-stream-pipeline.js b/test/parallel/test-stream-pipeline.js index fc721c3a562b9e..2ee323a934606e 100644 --- a/test/parallel/test-stream-pipeline.js +++ b/test/parallel/test-stream-pipeline.js @@ -1344,12 +1344,13 @@ tmpdir.refresh(); { const ac = new AbortController(); + const reason = new Error('Reason'); const r = Readable.from(async function* () { for (let i = 0; i < 10; i++) { await Promise.resolve(); yield String(i); if (i === 5) { - ac.abort(); + ac.abort(reason); } } }()); @@ -1362,6 +1363,7 @@ tmpdir.refresh(); }); const cb = common.mustCall((err) => { assert.strictEqual(err.name, 'AbortError'); + assert.strictEqual(err.cause, reason); assert.strictEqual(res, '012345'); assert.strictEqual(w.destroyed, true); assert.strictEqual(r.destroyed, true);