summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--cli/tests/unit/remove_test.ts574
1 files changed, 184 insertions, 390 deletions
diff --git a/cli/tests/unit/remove_test.ts b/cli/tests/unit/remove_test.ts
index 5d293ec51..f9095c1c1 100644
--- a/cli/tests/unit/remove_test.ts
+++ b/cli/tests/unit/remove_test.ts
@@ -1,463 +1,257 @@
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
import { unitTest, assert, assertEquals } from "./test_util.ts";
-// SYNC
+const REMOVE_METHODS = ["remove", "removeSync"] as const;
unitTest(
{ perms: { write: true, read: true } },
- function removeSyncDirSuccess(): void {
- // REMOVE EMPTY DIRECTORY
- const path = Deno.makeTempDirSync() + "/subdir";
- Deno.mkdirSync(path);
- const pathInfo = Deno.statSync(path);
- assert(pathInfo.isDirectory); // check exist first
- Deno.removeSync(path); // remove
- // We then check again after remove
- let err;
- try {
- Deno.statSync(path);
- } catch (e) {
- err = e;
- }
- // Directory is gone
- assert(err instanceof Deno.errors.NotFound);
- }
-);
-
-unitTest(
- { perms: { write: true, read: true } },
- function removeSyncFileSuccess(): void {
- // REMOVE FILE
- const enc = new TextEncoder();
- const data = enc.encode("Hello");
- const filename = Deno.makeTempDirSync() + "/test.txt";
- Deno.writeFileSync(filename, data, { mode: 0o666 });
- const fileInfo = Deno.statSync(filename);
- assert(fileInfo.isFile); // check exist first
- Deno.removeSync(filename); // remove
- // We then check again after remove
- let err;
- try {
- Deno.statSync(filename);
- } catch (e) {
- err = e;
+ async function removeDirSuccess(): Promise<void> {
+ for (const method of REMOVE_METHODS) {
+ // REMOVE EMPTY DIRECTORY
+ const path = Deno.makeTempDirSync() + "/subdir";
+ Deno.mkdirSync(path);
+ const pathInfo = Deno.statSync(path);
+ assert(pathInfo.isDirectory); // check exist first
+ await Deno[method](path); // remove
+ // We then check again after remove
+ let err;
+ try {
+ Deno.statSync(path);
+ } catch (e) {
+ err = e;
+ }
+ // Directory is gone
+ assert(err instanceof Deno.errors.NotFound);
}
- // File is gone
- assert(err instanceof Deno.errors.NotFound);
}
);
unitTest(
{ perms: { write: true, read: true } },
- function removeSyncFail(): void {
- // NON-EMPTY DIRECTORY
- const path = Deno.makeTempDirSync() + "/dir/subdir";
- const subPath = path + "/subsubdir";
- Deno.mkdirSync(path, { recursive: true });
- Deno.mkdirSync(subPath);
- const pathInfo = Deno.statSync(path);
- assert(pathInfo.isDirectory); // check exist first
- const subPathInfo = Deno.statSync(subPath);
- assert(subPathInfo.isDirectory); // check exist first
- let err;
- try {
- // Should not be able to recursively remove
- Deno.removeSync(path);
- } catch (e) {
- err = e;
- }
- // TODO(ry) Is Other really the error we should get here? What would Go do?
- assert(err instanceof Error);
- // NON-EXISTENT DIRECTORY/FILE
- try {
- // Non-existent
- Deno.removeSync("/baddir");
- } catch (e) {
- err = e;
+ async function removeFileSuccess(): Promise<void> {
+ for (const method of REMOVE_METHODS) {
+ // REMOVE FILE
+ const enc = new TextEncoder();
+ const data = enc.encode("Hello");
+ const filename = Deno.makeTempDirSync() + "/test.txt";
+ Deno.writeFileSync(filename, data, { mode: 0o666 });
+ const fileInfo = Deno.statSync(filename);
+ assert(fileInfo.isFile); // check exist first
+ await Deno[method](filename); // remove
+ // We then check again after remove
+ let err;
+ try {
+ Deno.statSync(filename);
+ } catch (e) {
+ err = e;
+ }
+ // File is gone
+ assert(err instanceof Deno.errors.NotFound);
}
- assert(err instanceof Deno.errors.NotFound);
}
);
unitTest(
{ perms: { write: true, read: true } },
- function removeSyncDanglingSymlinkSuccess(): void {
- const danglingSymlinkPath = Deno.makeTempDirSync() + "/dangling_symlink";
- if (Deno.build.os === "windows") {
- Deno.symlinkSync("unexistent_file", danglingSymlinkPath, {
- type: "file",
- });
- } else {
- Deno.symlinkSync("unexistent_file", danglingSymlinkPath);
- }
- const pathInfo = Deno.lstatSync(danglingSymlinkPath);
- assert(pathInfo.isSymlink);
- Deno.removeSync(danglingSymlinkPath);
- let err;
- try {
- Deno.lstatSync(danglingSymlinkPath);
- } catch (e) {
- err = e;
+ async function removeFail(): Promise<void> {
+ for (const method of REMOVE_METHODS) {
+ // NON-EMPTY DIRECTORY
+ const path = Deno.makeTempDirSync() + "/dir/subdir";
+ const subPath = path + "/subsubdir";
+ Deno.mkdirSync(path, { recursive: true });
+ Deno.mkdirSync(subPath);
+ const pathInfo = Deno.statSync(path);
+ assert(pathInfo.isDirectory); // check exist first
+ const subPathInfo = Deno.statSync(subPath);
+ assert(subPathInfo.isDirectory); // check exist first
+ let err;
+ try {
+ // Should not be able to recursively remove
+ await Deno[method](path);
+ } catch (e) {
+ err = e;
+ }
+ // TODO(ry) Is Other really the error we should get here? What would Go do?
+ assert(err instanceof Error);
+ // NON-EXISTENT DIRECTORY/FILE
+ try {
+ // Non-existent
+ await Deno[method]("/baddir");
+ } catch (e) {
+ err = e;
+ }
+ assert(err instanceof Deno.errors.NotFound);
}
- assert(err instanceof Deno.errors.NotFound);
}
);
unitTest(
{ perms: { write: true, read: true } },
- function removeSyncValidSymlinkSuccess(): void {
- const encoder = new TextEncoder();
- const data = encoder.encode("Test");
- const tempDir = Deno.makeTempDirSync();
- const filePath = tempDir + "/test.txt";
- const validSymlinkPath = tempDir + "/valid_symlink";
- Deno.writeFileSync(filePath, data, { mode: 0o666 });
- if (Deno.build.os === "windows") {
- Deno.symlinkSync(filePath, validSymlinkPath, { type: "file" });
- } else {
- Deno.symlinkSync(filePath, validSymlinkPath);
- }
- const symlinkPathInfo = Deno.statSync(validSymlinkPath);
- assert(symlinkPathInfo.isFile);
- Deno.removeSync(validSymlinkPath);
- let err;
- try {
- Deno.statSync(validSymlinkPath);
- } catch (e) {
- err = e;
+ async function removeDanglingSymlinkSuccess(): Promise<void> {
+ for (const method of REMOVE_METHODS) {
+ const danglingSymlinkPath = Deno.makeTempDirSync() + "/dangling_symlink";
+ if (Deno.build.os === "windows") {
+ Deno.symlinkSync("unexistent_file", danglingSymlinkPath, {
+ type: "file",
+ });
+ } else {
+ Deno.symlinkSync("unexistent_file", danglingSymlinkPath);
+ }
+ const pathInfo = Deno.lstatSync(danglingSymlinkPath);
+ assert(pathInfo.isSymlink);
+ await Deno[method](danglingSymlinkPath);
+ let err;
+ try {
+ Deno.lstatSync(danglingSymlinkPath);
+ } catch (e) {
+ err = e;
+ }
+ assert(err instanceof Deno.errors.NotFound);
}
- Deno.removeSync(filePath);
- assert(err instanceof Deno.errors.NotFound);
}
);
-unitTest({ perms: { write: false } }, function removeSyncPerm(): void {
- let err;
- try {
- Deno.removeSync("/baddir");
- } catch (e) {
- err = e;
- }
- assert(err instanceof Deno.errors.PermissionDenied);
- assertEquals(err.name, "PermissionDenied");
-});
-
unitTest(
{ perms: { write: true, read: true } },
- function removeAllSyncDirSuccess(): void {
- // REMOVE EMPTY DIRECTORY
- let path = Deno.makeTempDirSync() + "/dir/subdir";
- Deno.mkdirSync(path, { recursive: true });
- let pathInfo = Deno.statSync(path);
- assert(pathInfo.isDirectory); // check exist first
- Deno.removeSync(path, { recursive: true }); // remove
- // We then check again after remove
- let err;
- try {
- Deno.statSync(path);
- } catch (e) {
- err = e;
- }
- // Directory is gone
- assert(err instanceof Deno.errors.NotFound);
-
- // REMOVE NON-EMPTY DIRECTORY
- path = Deno.makeTempDirSync() + "/dir/subdir";
- const subPath = path + "/subsubdir";
- Deno.mkdirSync(path, { recursive: true });
- Deno.mkdirSync(subPath);
- pathInfo = Deno.statSync(path);
- assert(pathInfo.isDirectory); // check exist first
- const subPathInfo = Deno.statSync(subPath);
- assert(subPathInfo.isDirectory); // check exist first
- Deno.removeSync(path, { recursive: true }); // remove
- // We then check parent directory again after remove
- try {
- Deno.statSync(path);
- } catch (e) {
- err = e;
+ async function removeValidSymlinkSuccess(): Promise<void> {
+ for (const method of REMOVE_METHODS) {
+ const encoder = new TextEncoder();
+ const data = encoder.encode("Test");
+ const tempDir = Deno.makeTempDirSync();
+ const filePath = tempDir + "/test.txt";
+ const validSymlinkPath = tempDir + "/valid_symlink";
+ Deno.writeFileSync(filePath, data, { mode: 0o666 });
+ if (Deno.build.os === "windows") {
+ Deno.symlinkSync(filePath, validSymlinkPath, { type: "file" });
+ } else {
+ Deno.symlinkSync(filePath, validSymlinkPath);
+ }
+ const symlinkPathInfo = Deno.statSync(validSymlinkPath);
+ assert(symlinkPathInfo.isFile);
+ await Deno[method](validSymlinkPath);
+ let err;
+ try {
+ Deno.statSync(validSymlinkPath);
+ } catch (e) {
+ err = e;
+ }
+ await Deno[method](filePath);
+ assert(err instanceof Deno.errors.NotFound);
}
- // Directory is gone
- assert(err instanceof Deno.errors.NotFound);
}
);
-unitTest(
- { perms: { write: true, read: true } },
- function removeAllSyncFileSuccess(): void {
- // REMOVE FILE
- const enc = new TextEncoder();
- const data = enc.encode("Hello");
- const filename = Deno.makeTempDirSync() + "/test.txt";
- Deno.writeFileSync(filename, data, { mode: 0o666 });
- const fileInfo = Deno.statSync(filename);
- assert(fileInfo.isFile); // check exist first
- Deno.removeSync(filename, { recursive: true }); // remove
- // We then check again after remove
+unitTest({ perms: { write: false } }, async function removePerm(): Promise<
+ void
+> {
+ for (const method of REMOVE_METHODS) {
let err;
try {
- Deno.statSync(filename);
+ await Deno[method]("/baddir");
} catch (e) {
err = e;
}
- // File is gone
- assert(err instanceof Deno.errors.NotFound);
- }
-);
-
-unitTest({ perms: { write: true } }, function removeAllSyncFail(): void {
- // NON-EXISTENT DIRECTORY/FILE
- let err;
- try {
- // Non-existent
- Deno.removeSync("/baddir", { recursive: true });
- } catch (e) {
- err = e;
+ assert(err instanceof Deno.errors.PermissionDenied);
+ assertEquals(err.name, "PermissionDenied");
}
- assert(err instanceof Deno.errors.NotFound);
});
-unitTest({ perms: { write: false } }, function removeAllSyncPerm(): void {
- let err;
- try {
- Deno.removeSync("/baddir", { recursive: true });
- } catch (e) {
- err = e;
- }
- assert(err instanceof Deno.errors.PermissionDenied);
- assertEquals(err.name, "PermissionDenied");
-});
-
-// ASYNC
-
unitTest(
{ perms: { write: true, read: true } },
- async function removeDirSuccess(): Promise<void> {
- // REMOVE EMPTY DIRECTORY
- const path = Deno.makeTempDirSync() + "/dir/subdir";
- Deno.mkdirSync(path, { recursive: true });
- const pathInfo = Deno.statSync(path);
- assert(pathInfo.isDirectory); // check exist first
- await Deno.remove(path); // remove
- // We then check again after remove
- let err;
- try {
- Deno.statSync(path);
- } catch (e) {
- err = e;
- }
- // Directory is gone
- assert(err instanceof Deno.errors.NotFound);
- }
-);
-
-unitTest(
- { perms: { write: true, read: true } },
- async function removeFileSuccess(): Promise<void> {
- // REMOVE FILE
- const enc = new TextEncoder();
- const data = enc.encode("Hello");
- const filename = Deno.makeTempDirSync() + "/test.txt";
- Deno.writeFileSync(filename, data, { mode: 0o666 });
- const fileInfo = Deno.statSync(filename);
- assert(fileInfo.isFile); // check exist first
- await Deno.remove(filename); // remove
- // We then check again after remove
- let err;
- try {
- Deno.statSync(filename);
- } catch (e) {
- err = e;
- }
- // File is gone
- assert(err instanceof Deno.errors.NotFound);
- }
-);
-
-unitTest(
- { perms: { write: true, read: true } },
- async function removeFail(): Promise<void> {
- // NON-EMPTY DIRECTORY
- const path = Deno.makeTempDirSync() + "/dir/subdir";
- const subPath = path + "/subsubdir";
- Deno.mkdirSync(path, { recursive: true });
- Deno.mkdirSync(subPath);
- const pathInfo = Deno.statSync(path);
- assert(pathInfo.isDirectory); // check exist first
- const subPathInfo = Deno.statSync(subPath);
- assert(subPathInfo.isDirectory); // check exist first
- let err;
- try {
- // Should not be able to recursively remove
- await Deno.remove(path);
- } catch (e) {
- err = e;
- }
- assert(err instanceof Error);
- // NON-EXISTENT DIRECTORY/FILE
- try {
- // Non-existent
- await Deno.remove("/baddir");
- } catch (e) {
- err = e;
- }
- assert(err instanceof Deno.errors.NotFound);
- }
-);
+ async function removeAllDirSuccess(): Promise<void> {
+ for (const method of REMOVE_METHODS) {
+ // REMOVE EMPTY DIRECTORY
+ let path = Deno.makeTempDirSync() + "/dir/subdir";
+ Deno.mkdirSync(path, { recursive: true });
+ let pathInfo = Deno.statSync(path);
+ assert(pathInfo.isDirectory); // check exist first
+ await Deno[method](path, { recursive: true }); // remove
+ // We then check again after remove
+ let err;
+ try {
+ Deno.statSync(path);
+ } catch (e) {
+ err = e;
+ }
+ // Directory is gone
+ assert(err instanceof Deno.errors.NotFound);
-unitTest(
- { perms: { write: true, read: true } },
- async function removeDanglingSymlinkSuccess(): Promise<void> {
- const danglingSymlinkPath = Deno.makeTempDirSync() + "/dangling_symlink";
- if (Deno.build.os === "windows") {
- Deno.symlinkSync("unexistent_file", danglingSymlinkPath, {
- type: "file",
- });
- } else {
- Deno.symlinkSync("unexistent_file", danglingSymlinkPath);
- }
- const pathInfo = Deno.lstatSync(danglingSymlinkPath);
- assert(pathInfo.isSymlink);
- await Deno.remove(danglingSymlinkPath);
- let err;
- try {
- Deno.lstatSync(danglingSymlinkPath);
- } catch (e) {
- err = e;
+ // REMOVE NON-EMPTY DIRECTORY
+ path = Deno.makeTempDirSync() + "/dir/subdir";
+ const subPath = path + "/subsubdir";
+ Deno.mkdirSync(path, { recursive: true });
+ Deno.mkdirSync(subPath);
+ pathInfo = Deno.statSync(path);
+ assert(pathInfo.isDirectory); // check exist first
+ const subPathInfo = Deno.statSync(subPath);
+ assert(subPathInfo.isDirectory); // check exist first
+ await Deno[method](path, { recursive: true }); // remove
+ // We then check parent directory again after remove
+ try {
+ Deno.statSync(path);
+ } catch (e) {
+ err = e;
+ }
+ // Directory is gone
+ assert(err instanceof Deno.errors.NotFound);
}
- assert(err instanceof Deno.errors.NotFound);
}
);
unitTest(
{ perms: { write: true, read: true } },
- async function removeValidSymlinkSuccess(): Promise<void> {
- const encoder = new TextEncoder();
- const data = encoder.encode("Test");
- const tempDir = Deno.makeTempDirSync();
- const filePath = tempDir + "/test.txt";
- const validSymlinkPath = tempDir + "/valid_symlink";
- Deno.writeFileSync(filePath, data, { mode: 0o666 });
- if (Deno.build.os === "windows") {
- Deno.symlinkSync(filePath, validSymlinkPath, { type: "file" });
- } else {
- Deno.symlinkSync(filePath, validSymlinkPath);
- }
- const symlinkPathInfo = Deno.statSync(validSymlinkPath);
- assert(symlinkPathInfo.isFile);
- await Deno.remove(validSymlinkPath);
- let err;
- try {
- Deno.statSync(validSymlinkPath);
- } catch (e) {
- err = e;
+ async function removeAllFileSuccess(): Promise<void> {
+ for (const method of REMOVE_METHODS) {
+ // REMOVE FILE
+ const enc = new TextEncoder();
+ const data = enc.encode("Hello");
+ const filename = Deno.makeTempDirSync() + "/test.txt";
+ Deno.writeFileSync(filename, data, { mode: 0o666 });
+ const fileInfo = Deno.statSync(filename);
+ assert(fileInfo.isFile); // check exist first
+ await Deno[method](filename, { recursive: true }); // remove
+ // We then check again after remove
+ let err;
+ try {
+ Deno.statSync(filename);
+ } catch (e) {
+ err = e;
+ }
+ // File is gone
+ assert(err instanceof Deno.errors.NotFound);
}
- Deno.removeSync(filePath);
- assert(err instanceof Deno.errors.NotFound);
}
);
-unitTest({ perms: { write: false } }, async function removePerm(): Promise<
+unitTest({ perms: { write: true } }, async function removeAllFail(): Promise<
void
> {
- let err;
- try {
- await Deno.remove("/baddir");
- } catch (e) {
- err = e;
- }
- assert(err instanceof Deno.errors.PermissionDenied);
- assertEquals(err.name, "PermissionDenied");
-});
-
-unitTest(
- { perms: { write: true, read: true } },
- async function removeAllDirSuccess(): Promise<void> {
- // REMOVE EMPTY DIRECTORY
- let path = Deno.makeTempDirSync() + "/dir/subdir";
- Deno.mkdirSync(path, { recursive: true });
- let pathInfo = Deno.statSync(path);
- assert(pathInfo.isDirectory); // check exist first
- await Deno.remove(path, { recursive: true }); // remove
- // We then check again after remove
+ for (const method of REMOVE_METHODS) {
+ // NON-EXISTENT DIRECTORY/FILE
let err;
try {
- Deno.statSync(path);
- } catch (e) {
- err = e;
- }
- // Directory is gone
- assert(err instanceof Deno.errors.NotFound);
-
- // REMOVE NON-EMPTY DIRECTORY
- path = Deno.makeTempDirSync() + "/dir/subdir";
- const subPath = path + "/subsubdir";
- Deno.mkdirSync(path, { recursive: true });
- Deno.mkdirSync(subPath);
- pathInfo = Deno.statSync(path);
- assert(pathInfo.isDirectory); // check exist first
- const subPathInfo = Deno.statSync(subPath);
- assert(subPathInfo.isDirectory); // check exist first
- await Deno.remove(path, { recursive: true }); // remove
- // We then check parent directory again after remove
- try {
- Deno.statSync(path);
+ // Non-existent
+ await Deno[method]("/baddir", { recursive: true });
} catch (e) {
err = e;
}
- // Directory is gone
assert(err instanceof Deno.errors.NotFound);
}
-);
+});
-unitTest(
- { perms: { write: true, read: true } },
- async function removeAllFileSuccess(): Promise<void> {
- // REMOVE FILE
- const enc = new TextEncoder();
- const data = enc.encode("Hello");
- const filename = Deno.makeTempDirSync() + "/test.txt";
- Deno.writeFileSync(filename, data, { mode: 0o666 });
- const fileInfo = Deno.statSync(filename);
- assert(fileInfo.isFile); // check exist first
- await Deno.remove(filename, { recursive: true }); // remove
- // We then check again after remove
+unitTest({ perms: { write: false } }, async function removeAllPerm(): Promise<
+ void
+> {
+ for (const method of REMOVE_METHODS) {
let err;
try {
- Deno.statSync(filename);
+ await Deno[method]("/baddir", { recursive: true });
} catch (e) {
err = e;
}
- // File is gone
- assert(err instanceof Deno.errors.NotFound);
- }
-);
-
-unitTest({ perms: { write: true } }, async function removeAllFail(): Promise<
- void
-> {
- // NON-EXISTENT DIRECTORY/FILE
- let err;
- try {
- // Non-existent
- await Deno.remove("/baddir", { recursive: true });
- } catch (e) {
- err = e;
- }
- assert(err instanceof Deno.errors.NotFound);
-});
-
-unitTest({ perms: { write: false } }, async function removeAllPerm(): Promise<
- void
-> {
- let err;
- try {
- await Deno.remove("/baddir", { recursive: true });
- } catch (e) {
- err = e;
+ assert(err instanceof Deno.errors.PermissionDenied);
+ assertEquals(err.name, "PermissionDenied");
}
- assert(err instanceof Deno.errors.PermissionDenied);
- assertEquals(err.name, "PermissionDenied");
});
unitTest(
@@ -466,7 +260,7 @@ unitTest(
perms: { write: true, read: true },
},
async function removeUnixSocketSuccess(): Promise<void> {
- for (const method of ["remove", "removeSync"] as const) {
+ for (const method of REMOVE_METHODS) {
// MAKE TEMPORARY UNIX SOCKET
const path = Deno.makeTempDirSync() + "/test.sock";
const listener = Deno.listen({ transport: "unix", path });