summaryrefslogtreecommitdiff
path: root/std/node/_fs/_fs_readdir_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_readdir_test.ts
parentf9949a31707dcaa5a8786bfe4f84ed202be91607 (diff)
fix(std/node): Stop callbacks being called twice when callback throws error (#8867)
Diffstat (limited to 'std/node/_fs/_fs_readdir_test.ts')
-rw-r--r--std/node/_fs/_fs_readdir_test.ts30
1 files changed, 25 insertions, 5 deletions
diff --git a/std/node/_fs/_fs_readdir_test.ts b/std/node/_fs/_fs_readdir_test.ts
index 169e10245..165cb8141 100644
--- a/std/node/_fs/_fs_readdir_test.ts
+++ b/std/node/_fs/_fs_readdir_test.ts
@@ -1,4 +1,5 @@
import { assertEquals, assertNotEquals, fail } from "../../testing/asserts.ts";
+import { assertCallbackErrorUncaught } from "../_utils.ts";
import { readdir, readdirSync } from "./_fs_readdir.ts";
import { join } from "../../path/mod.ts";
@@ -12,8 +13,7 @@ Deno.test({
resolve(files);
});
})
- .then((files) => assertEquals(files, []))
- .catch(() => fail())
+ .then((files) => assertEquals(files, []), () => fail())
.finally(() => Deno.removeSync(dir));
},
});
@@ -40,10 +40,14 @@ Deno.test({
resolve(files);
});
})
- .then((files) =>
- assertEqualsArrayAnyOrder(files, ["file1.txt", "some_dir", "file2.txt"])
+ .then(
+ (files) =>
+ assertEqualsArrayAnyOrder(
+ files,
+ ["file1.txt", "some_dir", "file2.txt"],
+ ),
+ () => fail(),
)
- .catch(() => fail())
.finally(() => Deno.removeSync(dir, { recursive: true }));
},
});
@@ -69,3 +73,19 @@ Deno.test({
);
},
});
+
+Deno.test("[std/node/fs] readdir 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_readdir.ts", import.meta.url);
+ await assertCallbackErrorUncaught({
+ prelude: `import { readdir } from ${JSON.stringify(importUrl)}`,
+ invocation: `readdir(${JSON.stringify(tempDir)}, `,
+ async cleanup() {
+ await Deno.remove(tempDir);
+ },
+ });
+});