HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux ip-172-31-42-149 5.15.0-1084-aws #91~20.04.1-Ubuntu SMP Fri May 2 07:00:04 UTC 2025 aarch64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/vhost/disk-apps/alq-cali.bikenow.co/node_modules/crypto-browserify/test/random-bytes.js
'use strict';

var test = require('tape');
var crypto = require('../');
var randomBytes = require('randombytes');
var entries = require('object.entries');

var randomBytesFunctions = {
	randomBytes: randomBytes,
	pseudoRandomBytes: crypto.pseudoRandomBytes
};

// Both randomBytes and pseudoRandomBytes should provide the same interface
entries(randomBytesFunctions).forEach(function (entry) {
	var randomBytesName = entry[0];
	var randomBytesFn = entry[1];

	test('get error message', function (t) {
		try {
			var b = randomBytesFn(10);
			t.ok(Buffer.isBuffer(b));
			t.end();
		} catch (err) {
			t.ok((/not supported/).test(err.message), '"not supported" is in error message');
			t.end();
		}
	});

	test(randomBytesName, function (t) {
		t.plan(5);
		t.equal(randomBytesFn(10).length, 10);
		t.ok(Buffer.isBuffer(randomBytesFn(10)));
		randomBytesFn(10, function (ex, bytes) {
			t.error(ex);
			t.equal(bytes.length, 10);
			t.ok(Buffer.isBuffer(bytes));
			t.end();
		});
	});

	test(randomBytesName + ' seem random', function (t) {
		var L = 1000;
		var buffer = randomBytesFn(L);

		var mean = Array.prototype.reduce.call(buffer, function (a, b) { return a + b; }, 0) / L;

		// test that the random numbers are plausably random.
		// Math.random() will pass this, but this will catch
		// terrible mistakes such as this blunder:
		// https://github.com/browserify/crypto-browserify/commit/3267955e1df7edd1680e52aeede9a89506ed2464#commitcomment-7916835

		// this doesn't check that the bytes are in a random *order*
		// but it's better than nothing.

		var expected = 256 / 2;
		var smean = Math.sqrt(mean);

		// console.log doesn't work right on testling, *grumble grumble*
		console.log(JSON.stringify([expected - smean, mean, expected + smean]));
		t.ok(mean < expected + smean);
		t.ok(mean > expected - smean);

		t.end();
	});
});