Skip to content

Commit

Permalink
stream: stricter isReadableNodeStream
Browse files Browse the repository at this point in the history
Fixes: #40938
  • Loading branch information
ronag committed Nov 23, 2021
1 parent 7ad052d commit 0b3bdd7
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 3 deletions.
5 changes: 3 additions & 2 deletions lib/internal/streams/end-of-stream.js
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ const {
isNodeStream,
willEmitClose: _willEmitClose,
} = require('internal/streams/utils');
const console = require('console');

function isRequest(stream) {
return stream.setHeader && typeof stream.abort === 'function';
Expand All @@ -52,7 +53,7 @@ function eos(stream, options, callback) {
callback = once(callback);

const readable = options.readable ||
(options.readable !== false && isReadableNodeStream(stream));
(options.readable !== false && isReadableNodeStream(stream, true));
const writable = options.writable ||
(options.writable !== false && isWritableNodeStream(stream));

Expand All @@ -75,7 +76,7 @@ function eos(stream, options, callback) {
// this generic check.
let willEmitClose = (
_willEmitClose(stream) &&
isReadableNodeStream(stream) === readable &&
isReadableNodeStream(stream, true) === readable &&
isWritableNodeStream(stream) === writable
);

Expand Down
7 changes: 6 additions & 1 deletion lib/internal/streams/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,11 +9,16 @@ const {
const kDestroyed = Symbol('kDestroyed');
const kIsDisturbed = Symbol('kIsDisturbed');

function isReadableNodeStream(obj) {
function isReadableNodeStream(obj, strict = false) {
return !!(
obj &&
typeof obj.pipe === 'function' &&
typeof obj.on === 'function' &&
(
!strict ||
typeof obj.read === 'function' ||
(typeof obj.pause === 'function' && typeof obj.resume === 'function')
) &&
(!obj._writableState || obj._readableState?.readable !== false) && // Duplex
(!obj._writableState || obj._readableState) // Writable has .pipe.
);
Expand Down
16 changes: 16 additions & 0 deletions test/parallel/test-stream-finished.js
Original file line number Diff line number Diff line change
Expand Up @@ -643,3 +643,19 @@ testClosed((opts) => new Writable({ write() {}, ...opts }));
const s = new Stream();
finished(s, common.mustNotCall());
}

{
const server = http.createServer(common.mustCall(function (req, res) {
fs.createReadStream(__filename).pipe(res)
finished(res, common.mustCall(function (err) {
if (err) {
throw err
}
}))
})).listen(0, function () {
http.request({ method: 'GET', port: this.address().port }, common.mustCall(function (res) {
res.resume()
server.close()
})).end()
})
}

0 comments on commit 0b3bdd7

Please sign in to comment.