mirror of https://github.com/lukechilds/node.git
Browse Source
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>v4.x
Italo A. Casas
8 years ago
committed by
Myles Borins
1 changed files with 67 additions and 0 deletions
@ -0,0 +1,67 @@ |
|||||
|
'use strict'; |
||||
|
const common = require('../common'); |
||||
|
|
||||
|
// Testing Readable Stream resumeScheduled state
|
||||
|
|
||||
|
const assert = require('assert'); |
||||
|
const stream = require('stream'); |
||||
|
const Readable = stream.Readable; |
||||
|
const Writable = stream.Writable; |
||||
|
|
||||
|
{ |
||||
|
// 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…
Reference in new issue