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_link_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_link_test.ts')
-rw-r--r-- | std/node/_fs/_fs_link_test.ts | 27 |
1 files changed, 21 insertions, 6 deletions
diff --git a/std/node/_fs/_fs_link_test.ts b/std/node/_fs/_fs_link_test.ts index 4804b2eed..9e2aeb8b6 100644 --- a/std/node/_fs/_fs_link_test.ts +++ b/std/node/_fs/_fs_link_test.ts @@ -1,7 +1,8 @@ // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. -import { assertEquals, fail } from "../../testing/asserts.ts"; +import * as path from "../../path/mod.ts"; +import { assert, assertEquals, fail } from "../../testing/asserts.ts"; +import { assertCallbackErrorUncaught } from "../_utils.ts"; import { link, linkSync } from "./_fs_link.ts"; -import { assert } from "../../testing/asserts.ts"; Deno.test({ name: "ASYNC: hard linking files works as expected", @@ -16,8 +17,7 @@ Deno.test({ }) .then(() => { assertEquals(Deno.statSync(tempFile), Deno.statSync(linkedFile)); - }) - .catch(() => { + }, () => { fail("Expected to succeed"); }) .finally(() => { @@ -39,8 +39,7 @@ Deno.test({ }) .then(() => { fail("Expected to succeed"); - }) - .catch((err) => { + }, (err) => { assert(err); failed = true; }); @@ -60,3 +59,19 @@ Deno.test({ Deno.removeSync(linkedFile); }, }); + +Deno.test("[std/node/fs] link callback isn't called twice if error is thrown", async () => { + const tempDir = await Deno.makeTempDir(); + const tempFile = path.join(tempDir, "file.txt"); + const linkFile = path.join(tempDir, "link.txt"); + await Deno.writeTextFile(tempFile, "hello world"); + const importUrl = new URL("./_fs_link.ts", import.meta.url); + await assertCallbackErrorUncaught({ + prelude: `import { link } from ${JSON.stringify(importUrl)}`, + invocation: `link(${JSON.stringify(tempFile)}, + ${JSON.stringify(linkFile)}, `, + async cleanup() { + await Deno.remove(tempDir, { recursive: true }); + }, + }); +}); |