Browse Source

test: refactor test-stream2-readable-wrap.js

Use common.mustCall() where appropriate, var to const/let,
assert.equal() -> assert.strictEqual(), explicit time provided to
setTimeout()

PR-URL: https://github.com/nodejs/node/pull/10551
Reviewed-By: Rich Trott <rtrott@gmail.com>
Reviewed-By: Gibson Fahnestock <gibfahn@gmail.com>
v7.x
David Goussev 8 years ago
committed by Italo A. Casas
parent
commit
a06419b045
No known key found for this signature in database GPG Key ID: 23EFEFE93C4CFFFE
  1. 63
      test/parallel/test-stream2-readable-wrap.js

63
test/parallel/test-stream2-readable-wrap.js

@ -1,77 +1,63 @@
'use strict'; 'use strict';
require('../common'); const common = require('../common');
var assert = require('assert'); const assert = require('assert');
const Readable = require('_stream_readable');
const Writable = require('_stream_writable');
const EE = require('events').EventEmitter;
var Readable = require('_stream_readable');
var Writable = require('_stream_writable');
var EE = require('events').EventEmitter;
var testRuns = 0, completedRuns = 0;
function runTest(highWaterMark, objectMode, produce) { function runTest(highWaterMark, objectMode, produce) {
testRuns++;
var old = new EE(); const old = new EE();
var r = new Readable({ highWaterMark: highWaterMark, const r = new Readable({ highWaterMark: highWaterMark,
objectMode: objectMode }); objectMode: objectMode });
assert.equal(r, r.wrap(old)); assert.strictEqual(r, r.wrap(old));
var ended = false; r.on('end', common.mustCall(function() {}));
r.on('end', function() {
ended = true;
});
old.pause = function() { old.pause = function() {
console.error('old.pause()');
old.emit('pause'); old.emit('pause');
flowing = false; flowing = false;
}; };
old.resume = function() { old.resume = function() {
console.error('old.resume()');
old.emit('resume'); old.emit('resume');
flow(); flow();
}; };
var flowing; let flowing;
var chunks = 10; let chunks = 10;
var oldEnded = false; let oldEnded = false;
var expected = []; const expected = [];
function flow() { function flow() {
flowing = true; flowing = true;
while (flowing && chunks-- > 0) { while (flowing && chunks-- > 0) {
var item = produce(); const item = produce();
expected.push(item); expected.push(item);
console.log('old.emit', chunks, flowing);
old.emit('data', item); old.emit('data', item);
console.log('after emit', chunks, flowing);
} }
if (chunks <= 0) { if (chunks <= 0) {
oldEnded = true; oldEnded = true;
console.log('old end', chunks, flowing);
old.emit('end'); old.emit('end');
} }
} }
var w = new Writable({ highWaterMark: highWaterMark * 2, const w = new Writable({ highWaterMark: highWaterMark * 2,
objectMode: objectMode }); objectMode: objectMode });
var written = []; const written = [];
w._write = function(chunk, encoding, cb) { w._write = function(chunk, encoding, cb) {
console.log('_write', chunk);
written.push(chunk); written.push(chunk);
setTimeout(cb); setTimeout(cb, 1);
}; };
w.on('finish', function() { w.on('finish', common.mustCall(function() {
completedRuns++;
performAsserts(); performAsserts();
}); }));
r.pipe(w); r.pipe(w);
flow(); flow();
function performAsserts() { function performAsserts() {
assert(ended);
assert(oldEnded); assert(oldEnded);
assert.deepStrictEqual(written, expected); assert.deepStrictEqual(written, expected);
} }
@ -81,10 +67,5 @@ runTest(100, false, function() { return Buffer.allocUnsafe(100); });
runTest(10, false, function() { return Buffer.from('xxxxxxxxxx'); }); runTest(10, false, function() { return Buffer.from('xxxxxxxxxx'); });
runTest(1, true, function() { return { foo: 'bar' }; }); runTest(1, true, function() { return { foo: 'bar' }; });
var objectChunks = [ 5, 'a', false, 0, '', 'xyz', { x: 4 }, 7, [], 555 ]; const objectChunks = [ 5, 'a', false, 0, '', 'xyz', { x: 4 }, 7, [], 555 ];
runTest(1, true, function() { return objectChunks.shift(); }); runTest(1, true, function() { return objectChunks.shift(); });
process.on('exit', function() {
assert.equal(testRuns, completedRuns);
console.log('ok');
});

Loading…
Cancel
Save