summaryrefslogtreecommitdiff
path: root/std/node/_crypto/pbkdf2_test.ts
diff options
context:
space:
mode:
Diffstat (limited to 'std/node/_crypto/pbkdf2_test.ts')
-rw-r--r--std/node/_crypto/pbkdf2_test.ts15
1 files changed, 14 insertions, 1 deletions
diff --git a/std/node/_crypto/pbkdf2_test.ts b/std/node/_crypto/pbkdf2_test.ts
index 798805ce4..29f149cbe 100644
--- a/std/node/_crypto/pbkdf2_test.ts
+++ b/std/node/_crypto/pbkdf2_test.ts
@@ -3,7 +3,12 @@ import {
pbkdf2,
pbkdf2Sync,
} from "./pbkdf2.ts";
-import { assert, assertEquals } from "../../testing/asserts.ts";
+import {
+ assert,
+ assertEquals,
+ assertStringIncludes,
+} from "../../testing/asserts.ts";
+import { assertCallbackErrorUncaught } from "../_utils.ts";
type Pbkdf2Fixture = {
key: string | Float64Array | Int32Array | Uint8Array;
@@ -412,3 +417,11 @@ Deno.test("pbkdf2Sync hashes data correctly", () => {
}
});
});
+
+Deno.test("[std/node/crypto] pbkdf2 callback isn't called twice if error is thrown", async () => {
+ const importUrl = new URL("./pbkdf2.ts", import.meta.url);
+ await assertCallbackErrorUncaught({
+ prelude: `import { pbkdf2 } from ${JSON.stringify(importUrl)}`,
+ invocation: 'pbkdf2("password", "salt", 1, 32, "sha1", ',
+ });
+});