mirror of
https://github.com/nodejs/node.git
synced 2025-08-15 13:48:44 +02:00

This reverts commit 647175ee0b
.
PR-URL: https://github.com/nodejs/node/pull/58211
Reviewed-By: Marco Ippolito <marcoippolito54@gmail.com>
Reviewed-By: LiviaMedeiros <livia@cirno.name>
Reviewed-By: Antoine du Hamel <duhamelantoine1995@gmail.com>
Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com>
Reviewed-By: Darshan Sen <raisinten@gmail.com>
Reviewed-By: Luigi Pinca <luigipinca@gmail.com>
Reviewed-By: Chengzhong Wu <legendecas@gmail.com>
Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
Reviewed-By: Richard Lau <rlau@redhat.com>
Reviewed-By: Michaël Zasso <targos@protonmail.com>
Reviewed-By: Rafael Gonzaga <rafael.nunu@hotmail.com>
Reviewed-By: Yagiz Nizipli <yagiz@nizipli.com>
Reviewed-By: Juan José Arboleda <soyjuanarbol@gmail.com>
59 lines
1.7 KiB
JavaScript
59 lines
1.7 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];
|
|
|
|
common.expectWarning(
|
|
'DeprecationWarning',
|
|
'SlowBuffer() is deprecated. Please use Buffer.allocUnsafeSlow()',
|
|
'DEP0030'
|
|
);
|
|
|
|
// 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);
|
|
|
|
// Should throw with invalid length type
|
|
const bufferInvalidTypeMsg = {
|
|
code: 'ERR_INVALID_ARG_TYPE',
|
|
name: 'TypeError',
|
|
message: /^The "size" argument must be of type number/,
|
|
};
|
|
assert.throws(() => SlowBuffer(), bufferInvalidTypeMsg);
|
|
assert.throws(() => SlowBuffer({}), bufferInvalidTypeMsg);
|
|
assert.throws(() => SlowBuffer('6'), bufferInvalidTypeMsg);
|
|
assert.throws(() => SlowBuffer(true), bufferInvalidTypeMsg);
|
|
|
|
// Should throw with invalid length value
|
|
const bufferMaxSizeMsg = {
|
|
code: 'ERR_OUT_OF_RANGE',
|
|
name: 'RangeError',
|
|
};
|
|
assert.throws(() => SlowBuffer(NaN), bufferMaxSizeMsg);
|
|
assert.throws(() => SlowBuffer(Infinity), bufferMaxSizeMsg);
|
|
assert.throws(() => SlowBuffer(-1), bufferMaxSizeMsg);
|
|
assert.throws(() => SlowBuffer(buffer.kMaxLength + 1), bufferMaxSizeMsg);
|