summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorСковорода Никита Андреевич <chalkerx@gmail.com>2016-09-16 08:07:23 +0300
committerRod Vagg <rod@vagg.org>2016-09-28 11:19:18 +1000
commit495d688e069f97e8135a877773cd12cb52617e92 (patch)
tree0d2040fcb35d214cced0f34239a7e108d2874e83
parentc34e58e68416b34a976dfae72c7123b3b334a6b0 (diff)
downloadandroid-node-v8-495d688e069f97e8135a877773cd12cb52617e92.tar.gz
android-node-v8-495d688e069f97e8135a877773cd12cb52617e92.tar.bz2
android-node-v8-495d688e069f97e8135a877773cd12cb52617e92.zip
buffer: zero-fill uninitialized bytes in .concat()
This makes sure that no uninitialized bytes are leaked when the specified `totalLength` input value is greater than the actual total length of the specified buffers array, e.g. in Buffer.concat([Buffer.alloc(0)], 100). PR-URL: https://github.com/nodejs/node-private/pull/64 Reviewed-By: Rod Vagg <rod@vagg.org> Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
-rw-r--r--lib/buffer.js8
-rw-r--r--test/parallel/test-buffer-concat.js24
2 files changed, 31 insertions, 1 deletions
diff --git a/lib/buffer.js b/lib/buffer.js
index 86aa2e512e..495b521def 100644
--- a/lib/buffer.js
+++ b/lib/buffer.js
@@ -338,6 +338,14 @@ Buffer.concat = function(list, length) {
pos += buf.length;
}
+ // Note: `length` is always equal to `buffer.length` at this point
+ if (pos < length) {
+ // Zero-fill the remaining bytes if the specified `length` was more than
+ // the actual total length, i.e. if we have some remaining allocated bytes
+ // there were not initialized.
+ buffer.fill(0, pos, length);
+ }
+
return buffer;
};
diff --git a/test/parallel/test-buffer-concat.js b/test/parallel/test-buffer-concat.js
index 3946b22141..800f1055aa 100644
--- a/test/parallel/test-buffer-concat.js
+++ b/test/parallel/test-buffer-concat.js
@@ -1,5 +1,5 @@
'use strict';
-require('../common');
+const common = require('../common');
const assert = require('assert');
const zero = [];
@@ -38,3 +38,25 @@ function assertWrongList(value) {
err.message === '"list" argument must be an Array of Buffers';
});
}
+
+const random10 = common.hasCrypto
+ ? require('crypto').randomBytes(10)
+ : Buffer.alloc(10, 1);
+const empty = Buffer.alloc(0);
+
+assert.notDeepStrictEqual(random10, empty);
+assert.notDeepStrictEqual(random10, Buffer.alloc(10));
+
+assert.deepStrictEqual(Buffer.concat([], 100), empty);
+assert.deepStrictEqual(Buffer.concat([random10], 0), empty);
+assert.deepStrictEqual(Buffer.concat([random10], 10), random10);
+assert.deepStrictEqual(Buffer.concat([random10, random10], 10), random10);
+assert.deepStrictEqual(Buffer.concat([empty, random10]), random10);
+assert.deepStrictEqual(Buffer.concat([random10, empty, empty]), random10);
+
+// The tail should be zero-filled
+assert.deepStrictEqual(Buffer.concat([empty], 100), Buffer.alloc(100));
+assert.deepStrictEqual(Buffer.concat([empty], 4096), Buffer.alloc(4096));
+assert.deepStrictEqual(
+ Buffer.concat([random10], 40),
+ Buffer.concat([random10, Buffer.alloc(30)]));