Skip to content

Commit 2568ac9

Browse files
ronagdanielleadams
authored andcommitted
stream: add isErrored helper
Refs: nodejs/undici#1134 PR-URL: #41121 Reviewed-By: Matteo Collina <[email protected]> Reviewed-By: Minwoo Jung <[email protected]>
1 parent a2c4fa8 commit 2568ac9

File tree

7 files changed

+106
-4
lines changed

7 files changed

+106
-4
lines changed

doc/api/stream.md

Lines changed: 51 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2166,6 +2166,57 @@ added: v16.8.0
21662166

21672167
Returns whether the stream has been read from or cancelled.
21682168

2169+
### `stream.isErrored(stream)`
2170+
2171+
<!-- YAML
2172+
added: REPLACEME
2173+
-->
2174+
2175+
> Stability: 1 - Experimental
2176+
2177+
* `stream` {Readable|Writable|Duplex|WritableStream|ReadableStream}
2178+
* Returns: {boolean}
2179+
2180+
Returns whether the stream has encountered an error.
2181+
2182+
### `stream.Readable.toWeb(streamReadable)`
2183+
2184+
<!-- YAML
2185+
added: v17.0.0
2186+
-->
2187+
2188+
> Stability: 1 - Experimental
2189+
2190+
* `streamReadable` {stream.Readable}
2191+
* Returns: {ReadableStream}
2192+
2193+
### `stream.Writable.fromWeb(writableStream[, options])`
2194+
2195+
<!-- YAML
2196+
added: v17.0.0
2197+
-->
2198+
2199+
> Stability: 1 - Experimental
2200+
2201+
* `writableStream` {WritableStream}
2202+
* `options` {Object}
2203+
* `decodeStrings` {boolean}
2204+
* `highWaterMark` {number}
2205+
* `objectMode` {boolean}
2206+
* `signal` {AbortSignal}
2207+
* Returns: {stream.Writable}
2208+
2209+
### `stream.Writable.toWeb(streamWritable)`
2210+
2211+
<!-- YAML
2212+
added: v17.0.0
2213+
-->
2214+
2215+
> Stability: 1 - Experimental
2216+
2217+
* `streamWritable` {stream.Writable}
2218+
* Returns: {WritableStream}
2219+
21692220
### `stream.Duplex.from(src)`
21702221

21712222
<!-- YAML

lib/internal/streams/utils.js

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -6,6 +6,7 @@ const {
66
SymbolIterator,
77
} = primordials;
88

9+
const kIsErrored = Symbol('kIsErrored');
910
const kIsDisturbed = Symbol('kIsDisturbed');
1011

1112
function isReadableNodeStream(obj) {
@@ -212,10 +213,30 @@ function willEmitClose(stream) {
212213
);
213214
}
214215

216+
function isDisturbed(stream) {
217+
return !!(stream && (
218+
stream[kIsDisturbed] ??
219+
(stream.readableDidRead || stream.readableAborted)
220+
));
221+
}
222+
223+
function isErrored(stream) {
224+
return !!(stream && (
225+
stream[kIsErrored] ??
226+
stream.readableErrored ??
227+
stream.writableErrored ??
228+
stream._readableState?.errorEmitted ??
229+
stream._writableState?.errorEmitted ??
230+
stream._readableState?.errored ??
231+
stream._writableState?.errored
232+
));
233+
}
215234

216235
module.exports = {
217236
isDisturbed,
237+
isErrored,
218238
kIsDisturbed,
239+
kIsErrored,
219240
isClosed,
220241
isDestroyed,
221242
isDuplexNodeStream,

lib/internal/webstreams/readablestream.js

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -82,6 +82,7 @@ const {
8282

8383
const {
8484
kIsDisturbed,
85+
kIsErrored,
8586
} = require('internal/streams/utils');
8687

8788
const {
@@ -241,6 +242,10 @@ class ReadableStream {
241242
return this[kState].disturbed;
242243
}
243244

245+
get [kIsErrored]() {
246+
return this[kState].state === 'errored';
247+
}
248+
244249
/**
245250
* @readonly
246251
* @type {boolean}

lib/stream.js

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -36,9 +36,11 @@ const eos = require('internal/streams/end-of-stream');
3636
const internalBuffer = require('internal/buffer');
3737

3838
const promises = require('stream/promises');
39+
const utils = require('internal/streams/utils');
3940

4041
const Stream = module.exports = require('internal/streams/legacy').Stream;
41-
Stream.isDisturbed = require('internal/streams/utils').isDisturbed;
42+
Stream.isDisturbed = utils.isDisturbed;
43+
Stream.isErrored = utils.isErrored;
4244
Stream.Readable = require('internal/streams/readable');
4345
Stream.Writable = require('internal/streams/writable');
4446
Stream.Duplex = require('internal/streams/duplex');

test/parallel/test-stream-readable-didRead.js

Lines changed: 5 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,15 +1,18 @@
11
'use strict';
22
const common = require('../common');
33
const assert = require('assert');
4-
const { isDisturbed, Readable } = require('stream');
4+
const { isDisturbed, isErrored, Readable } = require('stream');
55

66
function noop() {}
77

88
function check(readable, data, fn) {
99
assert.strictEqual(readable.readableDidRead, false);
1010
assert.strictEqual(isDisturbed(readable), false);
11+
assert.strictEqual(isErrored(readable), false);
1112
if (data === -1) {
12-
readable.on('error', common.mustCall());
13+
readable.on('error', common.mustCall(() => {
14+
assert.strictEqual(isErrored(readable), true);
15+
}));
1316
readable.on('data', common.mustNotCall());
1417
readable.on('end', common.mustNotCall());
1518
} else {

test/parallel/test-whatwg-readablestream.js

Lines changed: 17 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
'use strict';
33

44
const common = require('../common');
5-
const { isDisturbed } = require('stream');
5+
const { isDisturbed, isErrored } = require('stream');
66
const assert = require('assert');
77
const {
88
isPromise,
@@ -1572,3 +1572,19 @@ class Source {
15721572
isDisturbed(stream, true);
15731573
})().then(common.mustCall());
15741574
}
1575+
1576+
1577+
{
1578+
const stream = new ReadableStream({
1579+
pull: common.mustCall((controller) => {
1580+
controller.error(new Error());
1581+
}),
1582+
});
1583+
1584+
const reader = stream.getReader();
1585+
(async () => {
1586+
isErrored(stream, false);
1587+
await reader.read().catch(common.mustCall());
1588+
isErrored(stream, true);
1589+
})().then(common.mustCall());
1590+
}

tools/doc/type-parser.mjs

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -206,6 +206,10 @@ const customTypesMap = {
206206
'stream.Readable': 'stream.html#class-streamreadable',
207207
'stream.Transform': 'stream.html#class-streamtransform',
208208
'stream.Writable': 'stream.html#class-streamwritable',
209+
'Duplex': 'stream.html#class-streamduplex',
210+
'Readable': 'stream.html#class-streamreadable',
211+
'Transform': 'stream.html#class-streamtransform',
212+
'Writable': 'stream.html#class-streamwritable',
209213

210214
'Immediate': 'timers.html#class-immediate',
211215
'Timeout': 'timers.html#class-timeout',

0 commit comments

Comments
 (0)