summaryrefslogtreecommitdiff
path: root/std/node/_fs/_fs_rmdir_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_rmdir_test.ts
parentf9949a31707dcaa5a8786bfe4f84ed202be91607 (diff)
fix(std/node): Stop callbacks being called twice when callback throws error (#8867)
Diffstat (limited to 'std/node/_fs/_fs_rmdir_test.ts')
-rw-r--r--std/node/_fs/_fs_rmdir_test.ts20
1 files changed, 16 insertions, 4 deletions
diff --git a/std/node/_fs/_fs_rmdir_test.ts b/std/node/_fs/_fs_rmdir_test.ts
index 006bd7b9d..6f9c33274 100644
--- a/std/node/_fs/_fs_rmdir_test.ts
+++ b/std/node/_fs/_fs_rmdir_test.ts
@@ -3,6 +3,7 @@ import { rmdir, rmdirSync } from "./_fs_rmdir.ts";
import { closeSync } from "./_fs_close.ts";
import { existsSync } from "../../fs/mod.ts";
import { join } from "../../path/mod.ts";
+import { assertCallbackErrorUncaught } from "../_utils.ts";
Deno.test({
name: "ASYNC: removing empty folder",
@@ -14,8 +15,7 @@ Deno.test({
resolve();
});
})
- .then(() => assertEquals(existsSync(dir), false))
- .catch(() => fail())
+ .then(() => assertEquals(existsSync(dir), false), () => fail())
.finally(() => {
if (existsSync(dir)) Deno.removeSync(dir);
});
@@ -58,8 +58,7 @@ Deno.test({
resolve();
});
})
- .then(() => assertEquals(existsSync(dir), false))
- .catch(() => fail())
+ .then(() => assertEquals(existsSync(dir), false), () => fail())
.finally(() => {
if (existsSync(dir)) Deno.removeSync(dir, { recursive: true });
const rAfter = Deno.resources();
@@ -86,3 +85,16 @@ Deno.test({
},
ignore: Deno.build.os === "windows",
});
+
+Deno.test("[std/node/fs] rmdir callback isn't called twice if error is thrown", async () => {
+ // The correct behaviour is not to catch any errors thrown,
+ // but that means there'll be an uncaught error and the test will fail.
+ // So the only way to test this is to spawn a subprocess, and succeed if it has a non-zero exit code.
+ // (assertThrowsAsync won't work because there's no way to catch the error.)
+ const tempDir = await Deno.makeTempDir();
+ const importUrl = new URL("./_fs_rmdir.ts", import.meta.url);
+ await assertCallbackErrorUncaught({
+ prelude: `import { rmdir } from ${JSON.stringify(importUrl)}`,
+ invocation: `rmdir(${JSON.stringify(tempDir)}, `,
+ });
+});