summaryrefslogtreecommitdiff
path: root/std/node/_fs/_fs_lstat_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_lstat_test.ts
parentf9949a31707dcaa5a8786bfe4f84ed202be91607 (diff)
fix(std/node): Stop callbacks being called twice when callback throws error (#8867)
Diffstat (limited to 'std/node/_fs/_fs_lstat_test.ts')
-rw-r--r--std/node/_fs/_fs_lstat_test.ts22
1 files changed, 18 insertions, 4 deletions
diff --git a/std/node/_fs/_fs_lstat_test.ts b/std/node/_fs/_fs_lstat_test.ts
index 1da0a562f..b8c562538 100644
--- a/std/node/_fs/_fs_lstat_test.ts
+++ b/std/node/_fs/_fs_lstat_test.ts
@@ -1,5 +1,6 @@
import { lstat, lstatSync } from "./_fs_lstat.ts";
import { fail } from "../../testing/asserts.ts";
+import { assertCallbackErrorUncaught } from "../_utils.ts";
import { assertStats, assertStatsBigInt } from "./_fs_stat_test.ts";
import type { BigIntStats, Stats } from "./_fs_stat.ts";
@@ -15,8 +16,7 @@ Deno.test({
})
.then((stat) => {
assertStats(stat, Deno.lstatSync(file));
- })
- .catch(() => fail())
+ }, () => fail())
.finally(() => {
Deno.removeSync(file);
});
@@ -41,8 +41,10 @@ Deno.test({
resolve(stat);
});
})
- .then((stat) => assertStatsBigInt(stat, Deno.lstatSync(file)))
- .catch(() => fail())
+ .then(
+ (stat) => assertStatsBigInt(stat, Deno.lstatSync(file)),
+ () => fail(),
+ )
.finally(() => Deno.removeSync(file));
},
});
@@ -54,3 +56,15 @@ Deno.test({
assertStatsBigInt(lstatSync(file, { bigint: true }), Deno.lstatSync(file));
},
});
+
+Deno.test("[std/node/fs] lstat callback isn't called twice if error is thrown", async () => {
+ const tempFile = await Deno.makeTempFile();
+ const importUrl = new URL("./_fs_lstat.ts", import.meta.url);
+ await assertCallbackErrorUncaught({
+ prelude: `import { lstat } from ${JSON.stringify(importUrl)}`,
+ invocation: `lstat(${JSON.stringify(tempFile)}, `,
+ async cleanup() {
+ await Deno.remove(tempFile);
+ },
+ });
+});