summaryrefslogtreecommitdiff
path: root/std/node/_fs/_fs_link_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_link_test.ts
parentf9949a31707dcaa5a8786bfe4f84ed202be91607 (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.ts27
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 });
+ },
+ });
+});