test: stream readable resumeScheduled state
PR-URL: https://github.com/nodejs/node/pull/10299 Ref: https://github.com/nodejs/node/issues/8683 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
This commit is contained in:
parent
7a0fe9f471
commit
613798335c
65
test/parallel/test-stream-readable-resumeScheduled.js
Normal file
65
test/parallel/test-stream-readable-resumeScheduled.js
Normal file
@ -0,0 +1,65 @@
|
||||
'use strict';
|
||||
const common = require('../common');
|
||||
|
||||
// Testing Readable Stream resumeScheduled state
|
||||
|
||||
const assert = require('assert');
|
||||
const { Readable, Writable } = require('stream');
|
||||
|
||||
{
|
||||
// pipe() test case
|
||||
const r = new Readable({ read() {} });
|
||||
const w = new Writable();
|
||||
|
||||
// resumeScheduled should start = `false`.
|
||||
assert.strictEqual(r._readableState.resumeScheduled, false);
|
||||
|
||||
// calling pipe() should change the state value = true.
|
||||
r.pipe(w);
|
||||
assert.strictEqual(r._readableState.resumeScheduled, true);
|
||||
|
||||
process.nextTick(common.mustCall(() => {
|
||||
assert.strictEqual(r._readableState.resumeScheduled, false);
|
||||
}));
|
||||
}
|
||||
|
||||
{
|
||||
// 'data' listener test case
|
||||
const r = new Readable({ read() {} });
|
||||
|
||||
// resumeScheduled should start = `false`.
|
||||
assert.strictEqual(r._readableState.resumeScheduled, false);
|
||||
|
||||
r.push(Buffer.from([1, 2, 3]));
|
||||
|
||||
// adding 'data' listener should change the state value
|
||||
r.on('data', common.mustCall(() => {
|
||||
assert.strictEqual(r._readableState.resumeScheduled, false);
|
||||
}));
|
||||
assert.strictEqual(r._readableState.resumeScheduled, true);
|
||||
|
||||
process.nextTick(common.mustCall(() => {
|
||||
assert.strictEqual(r._readableState.resumeScheduled, false);
|
||||
}));
|
||||
}
|
||||
|
||||
{
|
||||
// resume() test case
|
||||
const r = new Readable({ read() {} });
|
||||
|
||||
// resumeScheduled should start = `false`.
|
||||
assert.strictEqual(r._readableState.resumeScheduled, false);
|
||||
|
||||
// Calling resume() should change the state value.
|
||||
r.resume();
|
||||
assert.strictEqual(r._readableState.resumeScheduled, true);
|
||||
|
||||
r.on('resume', common.mustCall(() => {
|
||||
// The state value should be `false` again
|
||||
assert.strictEqual(r._readableState.resumeScheduled, false);
|
||||
}));
|
||||
|
||||
process.nextTick(common.mustCall(() => {
|
||||
assert.strictEqual(r._readableState.resumeScheduled, false);
|
||||
}));
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user