mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 10:59:27 +00:00
06cde5c902
PR-URL: https://github.com/nodejs/node/pull/50786 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Rafael Gonzaga <rafael.nunu@hotmail.com> Reviewed-By: Luigi Pinca <luigipinca@gmail.com>
96 lines
2.7 KiB
JavaScript
96 lines
2.7 KiB
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
|
|
const { Readable, Writable } = require('stream');
|
|
|
|
const source = Readable({ read: () => {} });
|
|
const dest1 = Writable({ write: () => {} });
|
|
const dest2 = Writable({ write: () => {} });
|
|
|
|
source.pipe(dest1);
|
|
source.pipe(dest2);
|
|
|
|
dest1.on('unpipe', common.mustCall());
|
|
dest2.on('unpipe', common.mustCall());
|
|
|
|
assert.strictEqual(source._readableState.pipes[0], dest1);
|
|
assert.strictEqual(source._readableState.pipes[1], dest2);
|
|
assert.strictEqual(source._readableState.pipes.length, 2);
|
|
|
|
// Should be able to unpipe them in the reverse order that they were piped.
|
|
|
|
source.unpipe(dest2);
|
|
|
|
assert.deepStrictEqual(source._readableState.pipes, [dest1]);
|
|
assert.notStrictEqual(source._readableState.pipes, dest2);
|
|
|
|
dest2.on('unpipe', common.mustNotCall());
|
|
source.unpipe(dest2);
|
|
|
|
source.unpipe(dest1);
|
|
|
|
assert.strictEqual(source._readableState.pipes.length, 0);
|
|
|
|
{
|
|
// Test `cleanup()` if we unpipe all streams.
|
|
const source = Readable({ read: () => {} });
|
|
const dest1 = Writable({ write: () => {} });
|
|
const dest2 = Writable({ write: () => {} });
|
|
|
|
let destCount = 0;
|
|
const srcCheckEventNames = ['end', 'data'];
|
|
const destCheckEventNames = ['close', 'finish', 'drain', 'error', 'unpipe'];
|
|
|
|
const checkSrcCleanup = common.mustCall(() => {
|
|
assert.strictEqual(source._readableState.pipes.length, 0);
|
|
assert.strictEqual(source._readableState.flowing, false);
|
|
for (const eventName of srcCheckEventNames) {
|
|
assert.strictEqual(
|
|
source.listenerCount(eventName), 0,
|
|
`source's '${eventName}' event listeners not removed`
|
|
);
|
|
}
|
|
});
|
|
|
|
function checkDestCleanup(dest) {
|
|
const currentDestId = ++destCount;
|
|
source.pipe(dest);
|
|
|
|
const unpipeChecker = common.mustCall(() => {
|
|
assert.deepStrictEqual(
|
|
dest.listeners('unpipe'), [unpipeChecker],
|
|
`destination{${currentDestId}} should have a 'unpipe' event ` +
|
|
'listener which is `unpipeChecker`'
|
|
);
|
|
dest.removeListener('unpipe', unpipeChecker);
|
|
for (const eventName of destCheckEventNames) {
|
|
assert.strictEqual(
|
|
dest.listenerCount(eventName), 0,
|
|
`destination{${currentDestId}}'s '${eventName}' event ` +
|
|
'listeners not removed'
|
|
);
|
|
}
|
|
|
|
if (--destCount === 0)
|
|
checkSrcCleanup();
|
|
});
|
|
|
|
dest.on('unpipe', unpipeChecker);
|
|
}
|
|
|
|
checkDestCleanup(dest1);
|
|
checkDestCleanup(dest2);
|
|
source.unpipe();
|
|
}
|
|
|
|
{
|
|
const src = Readable({ read: () => {} });
|
|
const dst = Writable({ write: () => {} });
|
|
src.pipe(dst);
|
|
src.on('resume', common.mustCall(() => {
|
|
src.on('pause', common.mustCall());
|
|
src.unpipe(dst);
|
|
}));
|
|
}
|