mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
944f68046c
New Buffer implementation allows greater than kMaxLength to be created. So instead check if the passed value is a valid Smi. PR-URL: https://github.com/nodejs/io.js/pull/1825 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
58 lines
1.3 KiB
JavaScript
58 lines
1.3 KiB
JavaScript
'use strict';
|
|
var common = require('../common');
|
|
var assert = require('assert');
|
|
|
|
if (!common.hasCrypto) {
|
|
console.log('1..0 # Skipped: missing crypto');
|
|
return;
|
|
}
|
|
var crypto = require('crypto');
|
|
|
|
crypto.DEFAULT_ENCODING = 'buffer';
|
|
|
|
// bump, we register a lot of exit listeners
|
|
process.setMaxListeners(256);
|
|
|
|
[crypto.randomBytes,
|
|
crypto.pseudoRandomBytes
|
|
].forEach(function(f) {
|
|
[-1,
|
|
undefined,
|
|
null,
|
|
false,
|
|
true,
|
|
{},
|
|
[]
|
|
].forEach(function(value) {
|
|
assert.throws(function() { f(value); });
|
|
assert.throws(function() { f(value, function() {}); });
|
|
});
|
|
|
|
[0, 1, 2, 4, 16, 256, 1024].forEach(function(len) {
|
|
f(len, checkCall(function(ex, buf) {
|
|
assert.equal(null, ex);
|
|
assert.equal(len, buf.length);
|
|
assert.ok(Buffer.isBuffer(buf));
|
|
}));
|
|
});
|
|
});
|
|
|
|
// assert that the callback is indeed called
|
|
function checkCall(cb, desc) {
|
|
var called_ = false;
|
|
|
|
process.on('exit', function() {
|
|
assert.equal(true, called_, desc || ('callback not called: ' + cb));
|
|
});
|
|
|
|
return function() {
|
|
return called_ = true, cb.apply(cb, Array.prototype.slice.call(arguments));
|
|
};
|
|
}
|
|
|
|
// #5126, "FATAL ERROR: v8::Object::SetIndexedPropertiesToExternalArrayData()
|
|
// length exceeds max acceptable value"
|
|
assert.throws(function() {
|
|
crypto.randomBytes((-1 >>> 0) + 1);
|
|
}, TypeError);
|