summaryrefslogtreecommitdiff
path: root/std/node/_crypto/pbkdf2_test.ts
diff options
context:
space:
mode:
authorLiam Murphy <43807659+Liamolucko@users.noreply.github.com>2021-01-26 23:34:40 +1100
committerGitHub <noreply@github.com>2021-01-26 13:34:40 +0100
commit06bd692e5c4a8f66960d3919e7087530b60c20dd (patch)
tree54da22655c71341c0e1e750d5197623e4fa0e286 /std/node/_crypto/pbkdf2_test.ts
parentf9949a31707dcaa5a8786bfe4f84ed202be91607 (diff)
fix(std/node): Stop callbacks being called twice when callback throws error (#8867)
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", ',
+ });
+});