From f0a5218f802b584d6728e231cd0899ba72e6a096 Mon Sep 17 00:00:00 2001 From: MrJithil Date: Sun, 30 Jan 2022 11:08:24 +0530 Subject: [PATCH] lib: throw invalid arg type from End Of Stream --- lib/internal/streams/end-of-stream.js | 6 +++--- test/parallel/test-stream-end-of-streams.js | 23 +++++++++++++++++++++ 2 files changed, 26 insertions(+), 3 deletions(-) create mode 100644 test/parallel/test-stream-end-of-streams.js diff --git a/lib/internal/streams/end-of-stream.js b/lib/internal/streams/end-of-stream.js index 2fe69207c6a841..59e32fa30ab8fc 100644 --- a/lib/internal/streams/end-of-stream.js +++ b/lib/internal/streams/end-of-stream.js @@ -8,7 +8,8 @@ const { codes, } = require('internal/errors'); const { - ERR_STREAM_PREMATURE_CLOSE + ERR_STREAM_PREMATURE_CLOSE, + ERR_INVALID_ARG_TYPE } = codes; const { once } = require('internal/util'); const { @@ -55,8 +56,7 @@ function eos(stream, options, callback) { const writable = options.writable ?? isWritableNodeStream(stream); if (!isNodeStream(stream)) { - // TODO: Webstreams. - // TODO: Throw INVALID_ARG_TYPE. + throw new ERR_INVALID_ARG_TYPE('stream', 'stream.Stream', stream); } const wState = stream._writableState; diff --git a/test/parallel/test-stream-end-of-streams.js b/test/parallel/test-stream-end-of-streams.js new file mode 100644 index 00000000000000..8b3e6aba1d46fd --- /dev/null +++ b/test/parallel/test-stream-end-of-streams.js @@ -0,0 +1,23 @@ +'use strict'; +const assert = require('assert'); + +const { Duplex, finished } = require('stream'); + +assert.throws( + () => { + // Passing empty object to mock invalid stream + // should throw error + finished({}, () => {}); + }, + { + code: 'ERR_INVALID_ARG_TYPE', + name: 'TypeError', + message: /stream/, + } +); + +const streamObj = new Duplex(); +streamObj.end(); +// Below code should not throw any errors as the +// streamObj is `Stream` +finished(streamObj, () => {});