Browse Source

test: refactor test-crypto-random

* specify constructor for assert.throws()
* load additional modules only if crypto check passes
* normalize some potentially confusing indentation
* provided actual first and expected second in assertions

PR-URL: https://github.com/nodejs/node/pull/10232
Reviewed-By: Prince John Wesley <princejohnwesley@gmail.com>
Reviewed-By: Luigi Pinca <luigipinca@gmail.com>
Reviewed-By: Michaël Zasso <targos@protonmail.com>
v4.x
Rich Trott 8 years ago
committed by Myles Borins
parent
commit
2f44d7f367
No known key found for this signature in database GPG Key ID: 933B01F40B5CA946
  1. 43
      test/parallel/test-crypto-random.js

43
test/parallel/test-crypto-random.js

@ -1,55 +1,34 @@
'use strict'; 'use strict';
var common = require('../common'); const common = require('../common');
var assert = require('assert');
if (!common.hasCrypto) { if (!common.hasCrypto) {
common.skip('missing crypto'); common.skip('missing crypto');
return; return;
} }
var crypto = require('crypto');
const assert = require('assert');
const crypto = require('crypto');
crypto.DEFAULT_ENCODING = 'buffer'; crypto.DEFAULT_ENCODING = 'buffer';
// bump, we register a lot of exit listeners // bump, we register a lot of exit listeners
process.setMaxListeners(256); process.setMaxListeners(256);
[crypto.randomBytes, [crypto.randomBytes, crypto.pseudoRandomBytes].forEach(function(f) {
crypto.pseudoRandomBytes [-1, undefined, null, false, true, {}, []].forEach(function(value) {
].forEach(function(f) { assert.throws(function() { f(value); }, TypeError);
[-1, assert.throws(function() { f(value, function() {}); }, TypeError);
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) { [0, 1, 2, 4, 16, 256, 1024].forEach(function(len) {
f(len, checkCall(function(ex, buf) { f(len, common.mustCall(function(ex, buf) {
assert.equal(null, ex); assert.strictEqual(ex, null);
assert.equal(len, buf.length); assert.strictEqual(buf.length, len);
assert.ok(Buffer.isBuffer(buf)); 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() // #5126, "FATAL ERROR: v8::Object::SetIndexedPropertiesToExternalArrayData()
// length exceeds max acceptable value" // length exceeds max acceptable value"
assert.throws(function() { assert.throws(function() {

Loading…
Cancel
Save