summaryrefslogtreecommitdiff
path: root/test/parallel/test-stream-pipe-await-drain-push-while-write.js
blob: adefad70adc20c3d9e46db16fe7aff06824a2f61 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
'use strict';
const common = require('../common');
const stream = require('stream');
const assert = require('assert');

const awaitDrainStates = [
  1, // after first chunk before callback
  1, // after second chunk before callback
  0 // resolving chunk pushed after first chunk, awaitDrain is decreased
];

// A writable stream which pushes data onto the stream which pipes into it,
// but only the first time it's written to. Since it's not paused at this time,
// a second write will occur. If the pipe increases awaitDrain twice, we'll
// never get subsequent chunks because 'drain' is only emitted once.
const writable = new stream.Writable({
  write: common.mustCall(function(chunk, encoding, cb) {
    if (chunk.length === 32 * 1024) { // first chunk
      const beforePush = readable._readableState.awaitDrain;
      readable.push(Buffer.alloc(34 * 1024)); // above hwm
      // We should check if awaitDrain counter is increased.
      const afterPush = readable._readableState.awaitDrain;
      assert.strictEqual(afterPush - beforePush, 1,
                         'Counter is not increased for awaitDrain');
    }

    assert.strictEqual(
      awaitDrainStates.shift(),
      readable._readableState.awaitDrain,
      'State variable awaitDrain is not correct.'
    );
    cb();
  }, 3)
});

// A readable stream which produces two buffers.
const bufs = [Buffer.alloc(32 * 1024), Buffer.alloc(33 * 1024)]; // above hwm
const readable = new stream.Readable({
  read: function() {
    while (bufs.length > 0) {
      this.push(bufs.shift());
    }
  }
});

readable.pipe(writable);