mirror of https://github.com/lukechilds/node.git
Browse Source
Fixes a regression that appeared with the new Buffer implementation in v3. Without this change, calling the SlowBuffer constructor with something else than a number would abort on the C++ side. This makes sure that the length argument is coerced to number or is 0. Fixes: https://github.com/nodejs/node/issues/2634 PR-URL: https://github.com/nodejs/node/pull/2635 Reviewed-By: trevnorris - Trevor Norris <trev.norris@gmail.com> Reviewed-By: cjihrig - Colin Ihrig <cjihrig@gmail.com>v5.x
Michaël Zasso
9 years ago
committed by
Rod Vagg
2 changed files with 57 additions and 2 deletions
@ -0,0 +1,55 @@ |
|||||
|
'use strict'; |
||||
|
|
||||
|
const common = require('../common'); |
||||
|
const assert = require('assert'); |
||||
|
const buffer = require('buffer'); |
||||
|
const Buffer = buffer.Buffer; |
||||
|
const SlowBuffer = buffer.SlowBuffer; |
||||
|
|
||||
|
const ones = [1, 1, 1, 1]; |
||||
|
|
||||
|
// should create a Buffer
|
||||
|
let sb = new SlowBuffer(4); |
||||
|
assert(sb instanceof Buffer); |
||||
|
assert.strictEqual(sb.length, 4); |
||||
|
sb.fill(1); |
||||
|
assert.deepEqual(sb, ones); |
||||
|
|
||||
|
// underlying ArrayBuffer should have the same length
|
||||
|
assert.strictEqual(sb.buffer.byteLength, 4); |
||||
|
|
||||
|
// should work without new
|
||||
|
sb = SlowBuffer(4); |
||||
|
assert(sb instanceof Buffer); |
||||
|
assert.strictEqual(sb.length, 4); |
||||
|
sb.fill(1); |
||||
|
assert.deepEqual(sb, ones); |
||||
|
|
||||
|
// should work with edge cases
|
||||
|
assert.strictEqual(SlowBuffer(0).length, 0); |
||||
|
try { |
||||
|
assert.strictEqual(SlowBuffer(buffer.kMaxLength).length, buffer.kMaxLength); |
||||
|
} catch (e) { |
||||
|
assert.equal(e.message, 'Buffer allocation failed - process out of memory'); |
||||
|
} |
||||
|
|
||||
|
// should work with number-coercible values
|
||||
|
assert.strictEqual(SlowBuffer('6').length, 6); |
||||
|
assert.strictEqual(SlowBuffer(true).length, 1); |
||||
|
|
||||
|
// should create zero-length buffer if parameter is not a number
|
||||
|
assert.strictEqual(SlowBuffer().length, 0); |
||||
|
assert.strictEqual(SlowBuffer(NaN).length, 0); |
||||
|
assert.strictEqual(SlowBuffer({}).length, 0); |
||||
|
assert.strictEqual(SlowBuffer('string').length, 0); |
||||
|
|
||||
|
// should throw with invalid length
|
||||
|
assert.throws(function() { |
||||
|
new SlowBuffer(Infinity); |
||||
|
}, 'invalid Buffer length'); |
||||
|
assert.throws(function() { |
||||
|
new SlowBuffer(-1); |
||||
|
}, 'invalid Buffer length'); |
||||
|
assert.throws(function() { |
||||
|
new SlowBuffer(buffer.kMaxLength + 1); |
||||
|
}, 'invalid Buffer length'); |
Loading…
Reference in new issue