Skip to content
This repository has been archived by the owner on Apr 22, 2023. It is now read-only.

Commit

Permalink
stream: make Readable.wrap support objectMode
Browse files Browse the repository at this point in the history
Added a check to see if the stream is in objectMode before deciding
whether to include or exclude data from an old-style wrapped stream.
  • Loading branch information
danielmoore authored and isaacs committed May 8, 2013
1 parent cf87ee6 commit 1ad93a6
Show file tree
Hide file tree
Showing 2 changed files with 66 additions and 52 deletions.
2 changes: 1 addition & 1 deletion lib/_stream_readable.js
Expand Up @@ -767,7 +767,7 @@ Readable.prototype.wrap = function(stream) {
stream.on('data', function(chunk) {
if (state.decoder)
chunk = state.decoder.write(chunk);
if (!chunk || !chunk.length)
if (!chunk || !state.objectMode && !chunk.length)
return;

var ret = self.push(chunk);
Expand Down
116 changes: 65 additions & 51 deletions test/simple/test-stream2-readable-wrap.js
Expand Up @@ -26,69 +26,83 @@ var Readable = require('_stream_readable');
var Writable = require('_stream_writable');
var EE = require('events').EventEmitter;

var old = new EE;
var r = new Readable({ highWaterMark: 10 });
assert.equal(r, r.wrap(old));
var testRuns = 0, completedRuns = 0;
function runTest(highWaterMark, objectMode, produce) {
testRuns++;

var ended = false;
r.on('end', function() {
ended = true;
});
var old = new EE;
var r = new Readable({ highWaterMark: highWaterMark, objectMode: objectMode });
assert.equal(r, r.wrap(old));

var pauses = 0;
var resumes = 0;
var ended = false;
r.on('end', function() {
ended = true;
});

old.pause = function() {
pauses++;
old.emit('pause');
flowing = false;
};
var pauses = 0;
var resumes = 0;

old.resume = function() {
resumes++;
old.emit('resume');
flow();
};

var flowing;
var chunks = 10;
var oldEnded = false;
function flow() {
flowing = true;
while (flowing && chunks-- > 0) {
old.emit('data', new Buffer('xxxxxxxxxx'));
}
if (chunks <= 0) {
oldEnded = true;
old.emit('end');
old.pause = function() {
pauses++;
old.emit('pause');
flowing = false;
};

old.resume = function() {
resumes++;
old.emit('resume');
flow();
};

var flowing;
var chunks = 10;
var oldEnded = false;
var expected = [];
function flow() {
flowing = true;
while (flowing && chunks-- > 0) {
var item = produce();
expected.push(item);
console.log('emit', chunks);
old.emit('data', item);
}
if (chunks <= 0) {
oldEnded = true;
console.log('old end', chunks, flowing);
old.emit('end');
}
}
}

var w = new Writable({ highWaterMark: 20 });
var written = [];
w._write = function(chunk, encoding, cb) {
written.push(chunk.toString());
setTimeout(cb);
};
var w = new Writable({ highWaterMark: highWaterMark * 2, objectMode: objectMode });
var written = [];
w._write = function(chunk, encoding, cb) {
console.log(chunk);
written.push(chunk);
setTimeout(cb);
};

var finished = false;
w.on('finish', function() {
finished = true;
});
w.on('finish', function() {
completedRuns++;
performAsserts();
});

r.pipe(w);

var expect = new Array(11).join('xxxxxxxxxx');
flow();

r.pipe(w);
function performAsserts() {
assert(ended);
assert(oldEnded);
assert.deepEqual(written, expected);
assert.equal(pauses, 10);
assert.equal(resumes, 9);
}
}

flow();
runTest(10, false, function(){ return new Buffer('xxxxxxxxxx'); });
runTest(1, true, function(){ return { foo: 'bar' }; });

process.on('exit', function() {
assert.equal(pauses, 10);
assert.equal(resumes, 9);
assert(ended);
assert(finished);
assert(oldEnded);
assert.equal(written.join(''), expect);
assert.equal(testRuns, completedRuns);
console.log('ok');
});

0 comments on commit 1ad93a6

Please sign in to comment.