1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-11 08:33:43 -05:00

fix(node): add crypto.pseudoRandomBytes (#21649)

This commit is contained in:
Divy Srivastava 2023-12-20 07:54:55 +05:30 committed by GitHub
parent 55fac9f5ea
commit 5aa27c45f1
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 27 additions and 1 deletions

View file

@ -6,7 +6,7 @@ import {
assertThrows,
} from "../../../../test_util/std/assert/mod.ts";
import { assertCallbackErrorUncaught } from "../_test_utils.ts";
import { randomBytes } from "node:crypto";
import { pseudoRandomBytes, randomBytes } from "node:crypto";
const MAX_RANDOM_VALUES = 65536;
const MAX_SIZE = 4294967295;
@ -90,3 +90,23 @@ Deno.test("[std/node/crypto] randomBytes callback isn't called twice if error is
invocation: "randomBytes(0, ",
});
});
// https://github.com/denoland/deno/issues/21632
Deno.test("pseudoRandomBytes works", function () {
assertEquals(pseudoRandomBytes(0).length, 0, "len: " + 0);
assertEquals(pseudoRandomBytes(3).length, 3, "len: " + 3);
assertEquals(pseudoRandomBytes(30).length, 30, "len: " + 30);
assertEquals(pseudoRandomBytes(300).length, 300, "len: " + 300);
assertEquals(
pseudoRandomBytes(17 + MAX_RANDOM_VALUES).length,
17 + MAX_RANDOM_VALUES,
"len: " + 17 + MAX_RANDOM_VALUES,
);
assertEquals(
pseudoRandomBytes(MAX_RANDOM_VALUES * 100).length,
MAX_RANDOM_VALUES * 100,
"len: " + MAX_RANDOM_VALUES * 100,
);
assertThrows(() => pseudoRandomBytes(MAX_SIZE + 1));
assertThrows(() => pseudoRandomBytes(-1));
});

View file

@ -306,6 +306,9 @@ const setFips = fipsForced ? setFipsForced : setFipsCrypto;
const sign = signOneShot;
const verify = verifyOneShot;
/* Deprecated in Node.js, alias of randomBytes */
const pseudoRandomBytes = randomBytes;
export default {
Certificate,
checkPrime,
@ -353,6 +356,7 @@ export default {
publicDecrypt,
publicEncrypt,
randomBytes,
pseudoRandomBytes,
randomFill,
randomFillSync,
randomInt,
@ -485,6 +489,8 @@ export {
pbkdf2Sync,
privateDecrypt,
privateEncrypt,
/* Deprecated in Node.js, alias of randomBytes */
pseudoRandomBytes,
publicDecrypt,
publicEncrypt,
randomBytes,