mirror of
https://github.com/nodejs/node.git
synced 2025-04-28 21:46:48 +00:00

If writable/readable has been explicitly disabled then using a Duplex as writable/readable should fail. Fixes: https://github.com/nodejs/node/issues/34374 PR-URL: https://github.com/nodejs/node/pull/34385 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com> Reviewed-By: Anna Henningsen <anna@addaleax.net>
47 lines
1.1 KiB
JavaScript
47 lines
1.1 KiB
JavaScript
'use strict';
|
|
|
|
const common = require('../common');
|
|
const { Duplex } = require('stream');
|
|
const assert = require('assert');
|
|
|
|
{
|
|
const duplex = new Duplex({
|
|
readable: false
|
|
});
|
|
assert.strictEqual(duplex.readable, false);
|
|
duplex.push('asd');
|
|
duplex.on('error', common.mustCall((err) => {
|
|
assert.strictEqual(err.code, 'ERR_STREAM_PUSH_AFTER_EOF');
|
|
}));
|
|
duplex.on('data', common.mustNotCall());
|
|
duplex.on('end', common.mustNotCall());
|
|
}
|
|
|
|
{
|
|
const duplex = new Duplex({
|
|
writable: false,
|
|
write: common.mustNotCall()
|
|
});
|
|
assert.strictEqual(duplex.writable, false);
|
|
duplex.write('asd');
|
|
duplex.on('error', common.mustCall((err) => {
|
|
assert.strictEqual(err.code, 'ERR_STREAM_WRITE_AFTER_END');
|
|
}));
|
|
duplex.on('finish', common.mustNotCall());
|
|
}
|
|
|
|
{
|
|
const duplex = new Duplex({
|
|
readable: false
|
|
});
|
|
assert.strictEqual(duplex.readable, false);
|
|
duplex.on('data', common.mustNotCall());
|
|
duplex.on('end', common.mustNotCall());
|
|
async function run() {
|
|
for await (const chunk of duplex) {
|
|
assert(false, chunk);
|
|
}
|
|
}
|
|
run().then(common.mustCall());
|
|
}
|