From 36af0b10ec8c1c1da03dfb1ca602fdb5232f8af3 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 24d0b037567e14..9f88e25e153a63 100644 --- a/lib/internal/streams/pipeline.js +++ b/lib/internal/streams/pipeline.js @@ -204,7 +204,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 5525fffa46d6d0..339c4c2290b84a 100644 --- a/test/parallel/test-stream-pipeline.js +++ b/test/parallel/test-stream-pipeline.js @@ -1331,12 +1331,13 @@ const tsp = require('timers/promises'); { 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); } } }()); @@ -1349,6 +1350,7 @@ const tsp = require('timers/promises'); }); 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);