mirror of
https://github.com/nodejs/node.git
synced 2025-05-05 15:32:15 +00:00

A number of test files use IIFEs to separate distinct tests from each other in the same file. The project has been moving toward using block scopes and let/const in favor of IIFEs. This commit moves IIFE tests to block scopes. Some additional cleanup such as use of strictEqual() and common.mustCall() is also included. PR-URL: https://github.com/nodejs/node/pull/7694 Reviewed-By: Santiago Gimeno <santiago.gimeno@gmail.com>
65 lines
1.5 KiB
JavaScript
65 lines
1.5 KiB
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
|
|
const Readable = require('stream').Readable;
|
|
|
|
{
|
|
// First test, not reading when the readable is added.
|
|
// make sure that on('readable', ...) triggers a readable event.
|
|
const r = new Readable({
|
|
highWaterMark: 3
|
|
});
|
|
|
|
r._read = common.fail;
|
|
|
|
// This triggers a 'readable' event, which is lost.
|
|
r.push(Buffer.from('blerg'));
|
|
|
|
setTimeout(function() {
|
|
// we're testing what we think we are
|
|
assert(!r._readableState.reading);
|
|
r.on('readable', common.mustCall(function() {}));
|
|
});
|
|
}
|
|
|
|
{
|
|
// second test, make sure that readable is re-emitted if there's
|
|
// already a length, while it IS reading.
|
|
|
|
const r = new Readable({
|
|
highWaterMark: 3
|
|
});
|
|
|
|
r._read = common.mustCall(function(n) {});
|
|
|
|
// This triggers a 'readable' event, which is lost.
|
|
r.push(Buffer.from('bl'));
|
|
|
|
setTimeout(function() {
|
|
// assert we're testing what we think we are
|
|
assert(r._readableState.reading);
|
|
r.on('readable', common.mustCall(function() {}));
|
|
});
|
|
}
|
|
|
|
{
|
|
// Third test, not reading when the stream has not passed
|
|
// the highWaterMark but *has* reached EOF.
|
|
const r = new Readable({
|
|
highWaterMark: 30
|
|
});
|
|
|
|
r._read = common.fail;
|
|
|
|
// This triggers a 'readable' event, which is lost.
|
|
r.push(Buffer.from('blerg'));
|
|
r.push(null);
|
|
|
|
setTimeout(function() {
|
|
// assert we're testing what we think we are
|
|
assert(!r._readableState.reading);
|
|
r.on('readable', common.mustCall(function() {}));
|
|
});
|
|
}
|