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_lstat_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_lstat_test.ts')
-rw-r--r-- | std/node/_fs/_fs_lstat_test.ts | 22 |
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); + }, + }); +}); |