From 5a95fa4aeb71b86fe0775cd7f6a704c63f2e7650 Mon Sep 17 00:00:00 2001 From: Robert Nagy Date: Sat, 11 Jan 2020 17:26:49 +0100 Subject: [PATCH] stream: normalize async iterator stream destroy PR-URL: https://github.com/nodejs/node/pull/31316 Reviewed-By: Anna Henningsen Reviewed-By: Matteo Collina Reviewed-By: Rich Trott Reviewed-By: Minwoo Jung --- lib/internal/streams/async_iterator.js | 17 +++++++++++------ .../test-stream-readable-async-iterators.js | 19 +++++++++++++++++++ 2 files changed, 30 insertions(+), 6 deletions(-) diff --git a/lib/internal/streams/async_iterator.js b/lib/internal/streams/async_iterator.js index 93b676ff02892b..5eefba517b97d2 100644 --- a/lib/internal/streams/async_iterator.js +++ b/lib/internal/streams/async_iterator.js @@ -22,6 +22,15 @@ const kStream = Symbol('stream'); let Readable; +function destroy(stream, err) { + // request.destroy just do .end - .abort is what we want + if (typeof stream.abort === 'function') return stream.abort(); + if (stream.req && + typeof stream.req.abort === 'function') return stream.req.abort(); + if (typeof stream.destroy === 'function') return stream.destroy(err); + if (typeof stream.close === 'function') return stream.close(); +} + function createIterResult(value, done) { return { value, done }; } @@ -141,7 +150,7 @@ const ReadableStreamAsyncIteratorPrototype = ObjectSetPrototypeOf({ resolve(createIterResult(undefined, true)); } }); - stream.destroy(); + destroy(stream); }); }, }, AsyncIteratorPrototype); @@ -156,11 +165,7 @@ const createReadableStreamAsyncIterator = (stream) => { const src = stream; stream = new Readable({ objectMode: true }).wrap(src); - finished(stream, (err) => { - if (typeof src.destroy === 'function') { - src.destroy(err); - } - }); + finished(stream, (err) => destroy(src, err)); } const iterator = ObjectCreate(ReadableStreamAsyncIteratorPrototype, { diff --git a/test/parallel/test-stream-readable-async-iterators.js b/test/parallel/test-stream-readable-async-iterators.js index 26482fa717ef74..b783b5f2ee8440 100644 --- a/test/parallel/test-stream-readable-async-iterators.js +++ b/test/parallel/test-stream-readable-async-iterators.js @@ -56,6 +56,25 @@ async function tests() { })); } + { + // Non standard stream cleanup + + const readable = new Readable({ autoDestroy: false, read() {} }); + readable.push('asd'); + readable.push('asd'); + readable.destroy = null; + readable.close = common.mustCall(() => { + readable.emit('close'); + }); + + await (async () => { + for await (const d of readable) { + d; + return; + } + })(); + } + { const readable = new Readable({ objectMode: true, read() {} }); readable.push(0);