diff options
author | Liam Murphy <43807659+Liamolucko@users.noreply.github.com> | 2021-01-26 23:34:40 +1100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-01-26 13:34:40 +0100 |
commit | 06bd692e5c4a8f66960d3919e7087530b60c20dd (patch) | |
tree | 54da22655c71341c0e1e750d5197623e4fa0e286 /std/node/_fs/_fs_exists_test.ts | |
parent | f9949a31707dcaa5a8786bfe4f84ed202be91607 (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.ts | 35 |
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"); +}); |