mirror of
https://github.com/nodejs/node.git
synced 2025-12-28 07:50:41 +00:00
Some checks failed
Coverage Windows / coverage-windows (push) Waiting to run
Test and upload documentation to artifacts / build-docs (push) Waiting to run
Linters / lint-addon-docs (push) Waiting to run
Linters / lint-cpp (push) Waiting to run
Linters / format-cpp (push) Waiting to run
Linters / lint-js-and-md (push) Waiting to run
Linters / lint-nix (push) Waiting to run
Linters / lint-py (push) Waiting to run
Linters / lint-yaml (push) Waiting to run
Linters / lint-sh (push) Waiting to run
Linters / lint-codeowners (push) Waiting to run
Linters / lint-pr-url (push) Waiting to run
Linters / lint-readme (push) Waiting to run
Notify on Push / Notify on Force Push on `main` (push) Waiting to run
Notify on Push / Notify on Push on `main` with invalid message (push) Waiting to run
Scorecard supply-chain security / Scorecard analysis (push) Waiting to run
Coverage Linux (without intl) / coverage-linux-without-intl (push) Has been cancelled
Coverage Linux / coverage-linux (push) Has been cancelled
PR-URL: https://github.com/nodejs/node/pull/60907 Fixes: https://github.com/nodejs/node/issues/55203 Reviewed-By: Raz Luvaton <rluvaton@gmail.com> Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
154 lines
3.6 KiB
JavaScript
154 lines
3.6 KiB
JavaScript
'use strict';
|
|
|
|
const common = require('../common');
|
|
const {
|
|
PassThrough,
|
|
Readable,
|
|
Transform,
|
|
} = require('stream');
|
|
const assert = require('assert');
|
|
|
|
{
|
|
// with async generator
|
|
const stream = Readable.from(['a', 'b', 'c', 'd']).compose(async function *(stream) {
|
|
let str = '';
|
|
for await (const chunk of stream) {
|
|
str += chunk;
|
|
|
|
if (str.length === 2) {
|
|
yield str;
|
|
str = '';
|
|
}
|
|
}
|
|
});
|
|
assert.strictEqual(stream.readable, true);
|
|
assert.strictEqual(stream.writable, false);
|
|
const result = ['ab', 'cd'];
|
|
(async () => {
|
|
for await (const item of stream) {
|
|
assert.strictEqual(item, result.shift());
|
|
}
|
|
})().then(common.mustCall());
|
|
}
|
|
|
|
{
|
|
// With Transformer
|
|
const stream = Readable.from(['a', 'b', 'c', 'd']).compose(new Transform({
|
|
objectMode: true,
|
|
transform: common.mustCall((chunk, encoding, callback) => {
|
|
callback(null, chunk);
|
|
}, 4)
|
|
}));
|
|
assert.strictEqual(stream.readable, true);
|
|
assert.strictEqual(stream.writable, false);
|
|
const result = ['a', 'b', 'c', 'd'];
|
|
(async () => {
|
|
for await (const item of stream) {
|
|
assert.strictEqual(item, result.shift());
|
|
}
|
|
})().then(common.mustCall());
|
|
}
|
|
|
|
{
|
|
// With Duplex stream as `this`, ensuring writes to the composed stream
|
|
// are passed to the head of the pipeline
|
|
const pt = new PassThrough({ objectMode: true });
|
|
const composed = pt.compose(async function *(stream) {
|
|
for await (const chunk of stream) {
|
|
yield chunk * 2;
|
|
}
|
|
});
|
|
assert.strictEqual(composed.readable, true);
|
|
assert.strictEqual(composed.writable, true);
|
|
pt.on('data', common.mustCall((chunk) => {
|
|
assert.strictEqual(chunk, 123);
|
|
}));
|
|
composed.on('data', common.mustCall((chunk) => {
|
|
assert.strictEqual(chunk, 246);
|
|
}));
|
|
composed.end(123);
|
|
}
|
|
|
|
{
|
|
// Throwing an error during `compose` (before waiting for data)
|
|
const stream = Readable.from([1, 2, 3, 4, 5]).compose(async function *(stream) { // eslint-disable-line require-yield
|
|
|
|
throw new Error('boom');
|
|
});
|
|
|
|
assert.rejects(async () => {
|
|
for await (const item of stream) {
|
|
assert.fail('should not reach here, got ' + item);
|
|
}
|
|
}, /boom/).then(common.mustCall());
|
|
}
|
|
|
|
{
|
|
// Throwing an error during `compose` (when waiting for data)
|
|
const stream = Readable.from([1, 2, 3, 4, 5]).compose(async function *(stream) {
|
|
for await (const chunk of stream) {
|
|
if (chunk === 3) {
|
|
throw new Error('boom');
|
|
}
|
|
yield chunk;
|
|
}
|
|
});
|
|
|
|
assert.rejects(
|
|
stream.toArray(),
|
|
/boom/,
|
|
).then(common.mustCall());
|
|
}
|
|
|
|
{
|
|
// Throwing an error during `compose` (after finishing all readable data)
|
|
const stream = Readable.from([1, 2, 3, 4, 5]).compose(async function *(stream) { // eslint-disable-line require-yield
|
|
|
|
// eslint-disable-next-line no-unused-vars,no-empty
|
|
for await (const chunk of stream) {
|
|
}
|
|
|
|
throw new Error('boom');
|
|
});
|
|
assert.rejects(
|
|
stream.toArray(),
|
|
/boom/,
|
|
).then(common.mustCall());
|
|
}
|
|
|
|
{
|
|
// AbortSignal
|
|
const ac = new AbortController();
|
|
const stream = Readable.from([1, 2, 3, 4, 5])
|
|
.compose(async function *(source) {
|
|
// Should not reach here
|
|
for await (const chunk of source) {
|
|
yield chunk;
|
|
}
|
|
}, { signal: ac.signal });
|
|
|
|
ac.abort();
|
|
|
|
assert.rejects(async () => {
|
|
for await (const item of stream) {
|
|
assert.fail('should not reach here, got ' + item);
|
|
}
|
|
}, {
|
|
name: 'AbortError',
|
|
}).then(common.mustCall());
|
|
}
|
|
|
|
{
|
|
assert.throws(
|
|
() => Readable.from(['a']).compose(Readable.from(['b'])),
|
|
{ code: 'ERR_INVALID_ARG_VALUE' }
|
|
);
|
|
}
|
|
|
|
{
|
|
assert.throws(
|
|
() => Readable.from(['a']).compose(),
|
|
{ code: 'ERR_INVALID_ARG_TYPE' }
|
|
);
|
|
}
|