node/test/parallel/test-stream-writable-needdrain-state.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

26 lines
613 B
JavaScript

'use strict';
const common = require('../common');
const stream = require('stream');
const assert = require('assert');
const transform = new stream.Transform({
transform: _transform,
highWaterMark: 1
});
function _transform(chunk, encoding, cb) {
process.nextTick(() => {
assert.strictEqual(transform._writableState.needDrain, true);
cb();
});
}
assert.strictEqual(transform._writableState.needDrain, false);
transform.write('asdasd', common.mustCall(() => {
assert.strictEqual(transform._writableState.needDrain, false);
}));
assert.strictEqual(transform._writableState.needDrain, true);