0
0
mirror of https://github.com/nodejs/node.git synced 2024-11-24 12:10:08 +01:00
nodejs/test/parallel/test-stream-catch-rejections.js
Robert Nagy 003fb53c9a stream: avoid drain for sync streams
Previously a sync writable receiving chunks
larger than highwatermark would unecessarily
ping pong needDrain.

PR-URL: https://github.com/nodejs/node/pull/32887
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
2020-04-25 18:45:50 +02:00

52 lines
920 B
JavaScript

'use strict';
const common = require('../common');
const stream = require('stream');
const assert = require('assert');
{
const r = new stream.Readable({
captureRejections: true,
read() {
}
});
r.push('hello');
r.push('world');
const err = new Error('kaboom');
r.on('error', common.mustCall((_err) => {
assert.strictEqual(err, _err);
assert.strictEqual(r.destroyed, true);
}));
r.on('data', async () => {
throw err;
});
}
{
const w = new stream.Writable({
captureRejections: true,
highWaterMark: 1,
write(chunk, enc, cb) {
process.nextTick(cb);
}
});
const err = new Error('kaboom');
w.write('hello', () => {
w.write('world');
});
w.on('error', common.mustCall((_err) => {
assert.strictEqual(err, _err);
assert.strictEqual(w.destroyed, true);
}));
w.on('drain', common.mustCall(async () => {
throw err;
}, 2));
}