mirror of
https://github.com/nodejs/node.git
synced 2025-05-08 11:21:41 +00:00

Do not check the error message if it is generated by the JavaScript engine (V8, ChakraCore, etc.). Do confirm that it is a `RangeError`. PR-URL: https://github.com/nodejs/node/pull/16272 Reviewed-By: Michaël Zasso <targos@protonmail.com> Reviewed-By: Refael Ackermann <refack@gmail.com> Reviewed-By: Yuta Hiroto <hello@about-hiroppy.com> Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com> Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com> Reviewed-By: Tobias Nießen <tniessen@tnie.de>
72 lines
2.0 KiB
JavaScript
72 lines
2.0 KiB
JavaScript
'use strict';
|
|
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
const buffer = require('buffer');
|
|
const SlowBuffer = buffer.SlowBuffer;
|
|
|
|
const ones = [1, 1, 1, 1];
|
|
|
|
// should create a Buffer
|
|
let sb = SlowBuffer(4);
|
|
assert(sb instanceof Buffer);
|
|
assert.strictEqual(sb.length, 4);
|
|
sb.fill(1);
|
|
for (const [key, value] of sb.entries()) {
|
|
assert.deepStrictEqual(value, ones[key]);
|
|
}
|
|
|
|
// 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);
|
|
for (const [key, value] of sb.entries()) {
|
|
assert.deepStrictEqual(value, ones[key]);
|
|
}
|
|
|
|
// should work with edge cases
|
|
assert.strictEqual(SlowBuffer(0).length, 0);
|
|
try {
|
|
assert.strictEqual(
|
|
SlowBuffer(buffer.kMaxLength).length, buffer.kMaxLength);
|
|
} catch (e) {
|
|
// Don't match on message as it is from the JavaScript engine. V8 and
|
|
// ChakraCore provide different messages.
|
|
assert.strictEqual(e.name, 'RangeError');
|
|
}
|
|
|
|
// 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
|
|
const bufferMaxSizeMsg = common.expectsError({
|
|
code: 'ERR_INVALID_OPT_VALUE',
|
|
type: RangeError,
|
|
message: /^The value "[^"]*" is invalid for option "size"$/
|
|
}, 2);
|
|
assert.throws(function() {
|
|
SlowBuffer(Infinity);
|
|
}, bufferMaxSizeMsg);
|
|
assert.throws(function() {
|
|
SlowBuffer(-1);
|
|
}, common.expectsError({
|
|
code: 'ERR_INVALID_OPT_VALUE',
|
|
type: RangeError,
|
|
message: 'The value "-1" is invalid for option "size"'
|
|
}));
|
|
|
|
assert.throws(function() {
|
|
SlowBuffer(buffer.kMaxLength + 1);
|
|
}, bufferMaxSizeMsg);
|