aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/packages/create-turbo/__tests__/isWritable.test.ts
diff options
context:
space:
mode:
author简律纯 <hsiangnianian@outlook.com>2023-04-28 01:36:44 +0800
committer简律纯 <hsiangnianian@outlook.com>2023-04-28 01:36:44 +0800
commitdd84b9d64fb98746a230cd24233ff50a562c39c9 (patch)
treeb583261ef00b3afe72ec4d6dacb31e57779a6faf /packages/create-turbo/__tests__/isWritable.test.ts
parent0b46fcd72ac34382387b2bcf9095233efbcc52f4 (diff)
downloadHydroRoll-dd84b9d64fb98746a230cd24233ff50a562c39c9.tar.gz
HydroRoll-dd84b9d64fb98746a230cd24233ff50a562c39c9.zip
Diffstat (limited to 'packages/create-turbo/__tests__/isWritable.test.ts')
-rw-r--r--packages/create-turbo/__tests__/isWritable.test.ts35
1 files changed, 35 insertions, 0 deletions
diff --git a/packages/create-turbo/__tests__/isWritable.test.ts b/packages/create-turbo/__tests__/isWritable.test.ts
new file mode 100644
index 0000000..b06670b
--- /dev/null
+++ b/packages/create-turbo/__tests__/isWritable.test.ts
@@ -0,0 +1,35 @@
+import path from "path";
+import { isWriteable } from "../src/utils/isWriteable";
+import { setupTestFixtures } from "@turbo/test-utils";
+import fs from "fs-extra";
+
+describe("isWriteable", () => {
+ const { useFixture } = setupTestFixtures({
+ directory: path.join(__dirname, "../"),
+ });
+
+ it("correctly identifies a writeable directory", async () => {
+ const { root } = useFixture({ fixture: `is-writeable` });
+ const result = await isWriteable(root);
+ expect(result).toEqual(true);
+ });
+
+ it("correctly identifies a non-writeable directory", async () => {
+ const { root } = useFixture({ fixture: `is-writeable` });
+ const result = await isWriteable(path.join(root, "does-not-exist"));
+ expect(result).toEqual(false);
+ });
+
+ it("returns false on unexpected failure", async () => {
+ const { root } = useFixture({ fixture: `is-writeable` });
+ const mockFsAccess = jest
+ .spyOn(fs, "access")
+ .mockRejectedValue(new Error("unknown error"));
+
+ const result = await isWriteable(root);
+ expect(result).toEqual(false);
+ expect(mockFsAccess).toHaveBeenCalledWith(root, fs.constants.W_OK);
+
+ mockFsAccess.mockRestore();
+ });
+});