nodejs/test/parallel/test-buffer-tostring-rangeerror.js
Michaël Zasso eb159a8cfd
test: remove duplicated allocUnsafeSlow test
PR-URL: https://github.com/nodejs/node/pull/58524
Reviewed-By: Yagiz Nizipli <yagiz@nizipli.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Luigi Pinca <luigipinca@gmail.com>
Reviewed-By: Darshan Sen <raisinten@gmail.com>
2025-06-02 11:32:58 +00:00

44 lines
1002 B
JavaScript

'use strict';
const common = require('../common');
// This test ensures that Node.js throws an Error when trying to convert a
// large buffer into a string.
// Regression test for https://github.com/nodejs/node/issues/649.
if (!common.enoughTestMem) {
common.skip('skipped due to memory requirements');
}
const assert = require('assert');
const {
Buffer,
constants: {
MAX_STRING_LENGTH,
},
} = require('buffer');
const len = MAX_STRING_LENGTH + 1;
const message = {
code: 'ERR_STRING_TOO_LONG',
name: 'Error',
};
function test(getBuffer) {
let buf;
try {
buf = getBuffer();
} catch (e) {
// If the buffer allocation fails, we skip the test.
if (e.code === 'ERR_MEMORY_ALLOCATION_FAILED' || /Array buffer allocation failed/.test(e.message)) {
return;
}
}
assert.throws(() => { buf.toString('utf8'); }, message);
}
test(() => Buffer(len));
test(() => Buffer.alloc(len));
test(() => Buffer.allocUnsafe(len));
test(() => Buffer.allocUnsafeSlow(len));