summaryrefslogtreecommitdiff
path: root/std/node/_fs/_fs_exists_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/_fs/_fs_exists_test.ts
parentf9949a31707dcaa5a8786bfe4f84ed202be91607 (diff)
fix(std/node): Stop callbacks being called twice when callback throws error (#8867)
Diffstat (limited to 'std/node/_fs/_fs_exists_test.ts')
-rw-r--r--std/node/_fs/_fs_exists_test.ts35
1 files changed, 34 insertions, 1 deletions
diff --git a/std/node/_fs/_fs_exists_test.ts b/std/node/_fs/_fs_exists_test.ts
index 6e120af98..ab0ae5c15 100644
--- a/std/node/_fs/_fs_exists_test.ts
+++ b/std/node/_fs/_fs_exists_test.ts
@@ -1,5 +1,9 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
-import { assertEquals } from "../../testing/asserts.ts";
+import {
+ assert,
+ assertEquals,
+ assertStringIncludes,
+} from "../../testing/asserts.ts";
import { exists, existsSync } from "./_fs_exists.ts";
Deno.test("existsFile", async function () {
@@ -23,3 +27,32 @@ Deno.test("existsSyncFile", function () {
Deno.removeSync(tmpFilePath);
assertEquals(existsSync("./notAvailable.txt"), false);
});
+
+Deno.test("[std/node/fs] exists callback isn't called twice if error is thrown", async () => {
+ // This doesn't use `assertCallbackErrorUncaught()` because `exists()` doesn't return a standard node callback, which is what it expects.
+ const tempFile = await Deno.makeTempFile();
+ const importUrl = new URL("./_fs_exists.ts", import.meta.url);
+ const p = Deno.run({
+ cmd: [
+ Deno.execPath(),
+ "eval",
+ "--no-check",
+ `
+ import { exists } from ${JSON.stringify(importUrl)};
+
+ exists(${JSON.stringify(tempFile)}, (exists) => {
+ // If the bug is present and the callback is called again with false (meaning an error occured),
+ // don't throw another error, so if the subprocess fails we know it had the correct behaviour.
+ if (exists) throw new Error("success");
+ });`,
+ ],
+ stderr: "piped",
+ });
+ const status = await p.status();
+ const stderr = new TextDecoder().decode(await Deno.readAll(p.stderr));
+ p.close();
+ p.stderr.close();
+ await Deno.remove(tempFile);
+ assert(!status.success);
+ assertStringIncludes(stderr, "Error: success");
+});