diff options
author | Matteo Collina <hello@matteocollina.com> | 2018-03-26 13:35:08 +0100 |
---|---|---|
committer | Matteo Collina <hello@matteocollina.com> | 2018-03-30 12:13:59 +0200 |
commit | d37e59fa6aee7f5b38696726b0145741ef3eb95b (patch) | |
tree | c5696463dd3675d4f26d973da0f626e1dd61280f /test | |
parent | 6c5144f4b1963ba2be7f9fde28d66aa3b9db729f (diff) | |
download | android-node-v8-d37e59fa6aee7f5b38696726b0145741ef3eb95b.tar.gz android-node-v8-d37e59fa6aee7f5b38696726b0145741ef3eb95b.tar.bz2 android-node-v8-d37e59fa6aee7f5b38696726b0145741ef3eb95b.zip |
stream: fix backpressure when multiple sync
PR-URL: https://github.com/nodejs/node/pull/19613
Fixes: https://github.com/nodejs/node/issues/19601
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Trivikram Kamat <trivikr.dev@gmail.com>
Reviewed-By: Anna Henningsen <anna@addaleax.net>
Diffstat (limited to 'test')
-rw-r--r-- | test/parallel/test-stream-backpressure.js | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/test/parallel/test-stream-backpressure.js b/test/parallel/test-stream-backpressure.js new file mode 100644 index 0000000000..03bcc233c8 --- /dev/null +++ b/test/parallel/test-stream-backpressure.js @@ -0,0 +1,39 @@ +'use strict'; + +const common = require('../common'); +const assert = require('assert'); +const stream = require('stream'); + +let pushes = 0; +const total = 65500 + 40 * 1024; +const rs = new stream.Readable({ + read: common.mustCall(function() { + if (pushes++ === 10) { + this.push(null); + return; + } + + const length = this._readableState.length; + + // We are at most doing two full runs of _reads + // before stopping, because Readable is greedy + // to keep its buffer full + assert(length <= total); + + this.push(Buffer.alloc(65500)); + for (let i = 0; i < 40; i++) { + this.push(Buffer.alloc(1024)); + } + + // We will be over highWaterMark at this point + // but a new call to _read is scheduled anyway. + }, 11) +}); + +const ws = stream.Writable({ + write: common.mustCall(function(data, enc, cb) { + setImmediate(cb); + }, 41 * 10) +}); + +rs.pipe(ws); |