Add crypto API randomInt() to random benchmarks
authorJérôme Benoit <jerome.benoit@sap.com>
Sun, 15 Jan 2023 15:46:15 +0000 (16:46 +0100)
committerJérôme Benoit <jerome.benoit@sap.com>
Sun, 15 Jan 2023 15:46:15 +0000 (16:46 +0100)
Signed-off-by: Jérôme Benoit <jerome.benoit@sap.com>
benchmark-utils.js
random.js

index 83d17ca7a7c4bb461d21dc4c994bc4e53b380ee4..121ef4ad375b6af43d43924677b070f88c024843 100644 (file)
@@ -9,6 +9,15 @@ function secureRandom () {
   return crypto.randomBytes(4).readUInt32LE() / 0x100000000
 }
 
+/**
+ *  Generate a cryptographically secure random number in the [0,1[ range
+ *
+ * @param
+ */
+function secureRandomWithRandomValues () {
+  return crypto.getRandomValues(new Uint32Array(1))[0] / 0x100000000
+}
+
 /**
  * @param max
  * @param min
@@ -95,5 +104,6 @@ module.exports = {
   generateRandomNumberArray,
   generateRandomObject,
   sleep,
-  secureRandom
+  secureRandom,
+  secureRandomWithRandomValues
 }
index f4fd9f0bd53f9182f13541be0b3bb17bc7c5e27c..2bdd430aea2ad7461772e1592c94d8c3ad3ceafa 100644 (file)
--- a/random.js
+++ b/random.js
@@ -1,7 +1,11 @@
 const Benchmark = require('benny')
-const { secureRandom } = require('./benchmark-utils')
+const {
+  secureRandom,
+  secureRandomWithRandomValues
+} = require('./benchmark-utils')
+const crypto = require('crypto')
 
-const maximum = Number.MAX_SAFE_INTEGER
+const maximum = 281474976710655
 
 /**
  * @param max
@@ -20,6 +24,26 @@ function getSecureRandomInteger (max = Number.MAX_SAFE_INTEGER, min = 0) {
   return Math.floor(secureRandom() * (max + 1))
 }
 
+/**
+ * @param max
+ * @param min
+ * @returns
+ */
+function getSecureRandomIntegerWithRandomValues (
+  max = Number.MAX_SAFE_INTEGER,
+  min = 0
+) {
+  if (max < min || max < 0 || min < 0) {
+    throw new RangeError('Invalid interval')
+  }
+  max = Math.floor(max)
+  if (min != null && min !== 0) {
+    min = Math.ceil(min)
+    return Math.floor(secureRandomWithRandomValues() * (max - min + 1)) + min
+  }
+  return Math.floor(secureRandomWithRandomValues() * (max + 1))
+}
+
 /**
  * @param max
  * @param min
@@ -42,7 +66,16 @@ Benchmark.suite(
   Benchmark.add('Secure random integer generator', () => {
     getSecureRandomInteger(maximum)
   }),
-  Benchmark.add('Random integer generator', () => {
+  Benchmark.add(
+    'Secure random with getRandomValues() integer generator',
+    () => {
+      getSecureRandomIntegerWithRandomValues(maximum)
+    }
+  ),
+  Benchmark.add('Crypto random integer generator', () => {
+    crypto.randomInt(maximum)
+  }),
+  Benchmark.add('Math random integer generator', () => {
     getRandomInteger(maximum)
   }),
   Benchmark.cycle(),