summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorisaacs <i@izs.me>2013-09-05 13:11:51 -0700
committerisaacs <i@izs.me>2013-09-05 13:19:23 -0700
commit1da7bcc22ca115d4cb17193bc97cda027ebe2e30 (patch)
tree0bbb252b7b9ca7dfc1e41e31bcf89256f7fb97c4
parent6301613ff57c0be81f9b9e0592ac15b6102daace (diff)
downloadnode-new-1da7bcc22ca115d4cb17193bc97cda027ebe2e30.tar.gz
stream: objectMode transforms allow falsey values
Closes #6183
-rw-r--r--lib/_stream_transform.js2
-rw-r--r--test/simple/test-stream-transform-objectmode-falsey-value.js53
2 files changed, 54 insertions, 1 deletions
diff --git a/lib/_stream_transform.js b/lib/_stream_transform.js
index e925b4bb51..4755602033 100644
--- a/lib/_stream_transform.js
+++ b/lib/_stream_transform.js
@@ -174,7 +174,7 @@ Transform.prototype._write = function(chunk, encoding, cb) {
Transform.prototype._read = function(n) {
var ts = this._transformState;
- if (ts.writechunk && ts.writecb && !ts.transforming) {
+ if (ts.writechunk !== null && ts.writecb && !ts.transforming) {
ts.transforming = true;
this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);
} else {
diff --git a/test/simple/test-stream-transform-objectmode-falsey-value.js b/test/simple/test-stream-transform-objectmode-falsey-value.js
new file mode 100644
index 0000000000..31b5bbaaf5
--- /dev/null
+++ b/test/simple/test-stream-transform-objectmode-falsey-value.js
@@ -0,0 +1,53 @@
+// Copyright Joyent, Inc. and other Node contributors.
+//
+// Permission is hereby granted, free of charge, to any person obtaining a
+// copy of this software and associated documentation files (the
+// "Software"), to deal in the Software without restriction, including
+// without limitation the rights to use, copy, modify, merge, publish,
+// distribute, sublicense, and/or sell copies of the Software, and to permit
+// persons to whom the Software is furnished to do so, subject to the
+// following conditions:
+//
+// The above copyright notice and this permission notice shall be included
+// in all copies or substantial portions of the Software.
+//
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
+// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
+// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
+// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
+// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
+// USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+var common = require('../common');
+var assert = require('assert');
+
+var stream = require('stream');
+var PassThrough = stream.PassThrough;
+
+var src = new PassThrough({ objectMode: true });
+var tx = new PassThrough({ objectMode: true });
+var dest = new PassThrough({ objectMode: true });
+
+var expect = [ -1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 ];
+var results = [];
+process.on('exit', function() {
+ assert.deepEqual(results, expect);
+ console.log('ok');
+});
+
+dest.on('data', function(x) {
+ results.push(x);
+});
+
+src.pipe(tx).pipe(dest);
+
+var i = -1;
+var int = setInterval(function() {
+ if (i > 10) {
+ src.end();
+ clearInterval(int);
+ } else {
+ src.write(i++);
+ }
+});