mirror of
https://github.com/denoland/deno.git
synced 2025-01-18 11:53:59 -05:00
f5e46c9bf2
This looks like a massive PR, but it's only a move from cli/tests -> tests, and updates of relative paths for files. This is the first step towards aggregate all of the integration test files under tests/, which will lead to a set of integration tests that can run without the CLI binary being built. While we could leave these tests under `cli`, it would require us to keep a more complex directory structure for the various test runners. In addition, we have a lot of complexity to ignore various test files in the `cli` project itself (cargo publish exclusion rules, autotests = false, etc). And finally, the `tests/` folder will eventually house the `test_ffi`, `test_napi` and other testing code, reducing the size of the root repo directory. For easier review, the extremely large and noisy "move" is in the first commit (with no changes -- just a move), while the remainder of the changes to actual files is in the second commit.
195 lines
5.5 KiB
TypeScript
195 lines
5.5 KiB
TypeScript
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
import {
|
|
assert,
|
|
assertEquals,
|
|
assertRejects,
|
|
assertThrows,
|
|
} from "./test_util.ts";
|
|
|
|
Deno.test(
|
|
{ permissions: { read: true, write: true } },
|
|
function linkSyncSuccess() {
|
|
const testDir = Deno.makeTempDirSync();
|
|
const oldData = "Hardlink";
|
|
const oldName = testDir + "/oldname";
|
|
const newName = testDir + "/newname";
|
|
Deno.writeFileSync(oldName, new TextEncoder().encode(oldData));
|
|
// Create the hard link.
|
|
Deno.linkSync(oldName, newName);
|
|
// We should expect reading the same content.
|
|
const newData = Deno.readTextFileSync(newName);
|
|
assertEquals(oldData, newData);
|
|
// Writing to newname also affects oldname.
|
|
const newData2 = "Modified";
|
|
Deno.writeFileSync(newName, new TextEncoder().encode(newData2));
|
|
assertEquals(
|
|
newData2,
|
|
Deno.readTextFileSync(oldName),
|
|
);
|
|
// Writing to oldname also affects newname.
|
|
const newData3 = "ModifiedAgain";
|
|
Deno.writeFileSync(oldName, new TextEncoder().encode(newData3));
|
|
assertEquals(
|
|
newData3,
|
|
Deno.readTextFileSync(newName),
|
|
);
|
|
// Remove oldname. File still accessible through newname.
|
|
Deno.removeSync(oldName);
|
|
const newNameStat = Deno.statSync(newName);
|
|
assert(newNameStat.isFile);
|
|
assert(!newNameStat.isSymlink); // Not a symlink.
|
|
assertEquals(
|
|
newData3,
|
|
Deno.readTextFileSync(newName),
|
|
);
|
|
},
|
|
);
|
|
|
|
Deno.test(
|
|
{ permissions: { read: true, write: true } },
|
|
function linkSyncExists() {
|
|
const testDir = Deno.makeTempDirSync();
|
|
const oldName = testDir + "/oldname";
|
|
const newName = testDir + "/newname";
|
|
Deno.writeFileSync(oldName, new TextEncoder().encode("oldName"));
|
|
// newname is already created.
|
|
Deno.writeFileSync(newName, new TextEncoder().encode("newName"));
|
|
|
|
assertThrows(
|
|
() => {
|
|
Deno.linkSync(oldName, newName);
|
|
},
|
|
Deno.errors.AlreadyExists,
|
|
`link '${oldName}' -> '${newName}'`,
|
|
);
|
|
},
|
|
);
|
|
|
|
Deno.test(
|
|
{ permissions: { read: true, write: true } },
|
|
function linkSyncNotFound() {
|
|
const testDir = Deno.makeTempDirSync();
|
|
const oldName = testDir + "/oldname";
|
|
const newName = testDir + "/newname";
|
|
|
|
assertThrows(
|
|
() => {
|
|
Deno.linkSync(oldName, newName);
|
|
},
|
|
Deno.errors.NotFound,
|
|
`link '${oldName}' -> '${newName}'`,
|
|
);
|
|
},
|
|
);
|
|
|
|
Deno.test(
|
|
{ permissions: { read: false, write: true } },
|
|
function linkSyncReadPerm() {
|
|
assertThrows(() => {
|
|
Deno.linkSync("oldbaddir", "newbaddir");
|
|
}, Deno.errors.PermissionDenied);
|
|
},
|
|
);
|
|
|
|
Deno.test(
|
|
{ permissions: { read: true, write: false } },
|
|
function linkSyncWritePerm() {
|
|
assertThrows(() => {
|
|
Deno.linkSync("oldbaddir", "newbaddir");
|
|
}, Deno.errors.PermissionDenied);
|
|
},
|
|
);
|
|
|
|
Deno.test(
|
|
{ permissions: { read: true, write: true } },
|
|
async function linkSuccess() {
|
|
const testDir = Deno.makeTempDirSync();
|
|
const oldData = "Hardlink";
|
|
const oldName = testDir + "/oldname";
|
|
const newName = testDir + "/newname";
|
|
Deno.writeFileSync(oldName, new TextEncoder().encode(oldData));
|
|
// Create the hard link.
|
|
await Deno.link(oldName, newName);
|
|
// We should expect reading the same content.
|
|
const newData = Deno.readTextFileSync(newName);
|
|
assertEquals(oldData, newData);
|
|
// Writing to newname also affects oldname.
|
|
const newData2 = "Modified";
|
|
Deno.writeFileSync(newName, new TextEncoder().encode(newData2));
|
|
assertEquals(
|
|
newData2,
|
|
Deno.readTextFileSync(oldName),
|
|
);
|
|
// Writing to oldname also affects newname.
|
|
const newData3 = "ModifiedAgain";
|
|
Deno.writeFileSync(oldName, new TextEncoder().encode(newData3));
|
|
assertEquals(
|
|
newData3,
|
|
Deno.readTextFileSync(newName),
|
|
);
|
|
// Remove oldname. File still accessible through newname.
|
|
Deno.removeSync(oldName);
|
|
const newNameStat = Deno.statSync(newName);
|
|
assert(newNameStat.isFile);
|
|
assert(!newNameStat.isSymlink); // Not a symlink.
|
|
assertEquals(
|
|
newData3,
|
|
Deno.readTextFileSync(newName),
|
|
);
|
|
},
|
|
);
|
|
|
|
Deno.test(
|
|
{ permissions: { read: true, write: true } },
|
|
async function linkExists() {
|
|
const testDir = Deno.makeTempDirSync();
|
|
const oldName = testDir + "/oldname";
|
|
const newName = testDir + "/newname";
|
|
Deno.writeFileSync(oldName, new TextEncoder().encode("oldName"));
|
|
// newname is already created.
|
|
Deno.writeFileSync(newName, new TextEncoder().encode("newName"));
|
|
|
|
await assertRejects(
|
|
async () => {
|
|
await Deno.link(oldName, newName);
|
|
},
|
|
Deno.errors.AlreadyExists,
|
|
`link '${oldName}' -> '${newName}'`,
|
|
);
|
|
},
|
|
);
|
|
|
|
Deno.test(
|
|
{ permissions: { read: true, write: true } },
|
|
async function linkNotFound() {
|
|
const testDir = Deno.makeTempDirSync();
|
|
const oldName = testDir + "/oldname";
|
|
const newName = testDir + "/newname";
|
|
|
|
await assertRejects(
|
|
async () => {
|
|
await Deno.link(oldName, newName);
|
|
},
|
|
Deno.errors.NotFound,
|
|
`link '${oldName}' -> '${newName}'`,
|
|
);
|
|
},
|
|
);
|
|
|
|
Deno.test(
|
|
{ permissions: { read: false, write: true } },
|
|
async function linkReadPerm() {
|
|
await assertRejects(async () => {
|
|
await Deno.link("oldbaddir", "newbaddir");
|
|
}, Deno.errors.PermissionDenied);
|
|
},
|
|
);
|
|
|
|
Deno.test(
|
|
{ permissions: { read: true, write: false } },
|
|
async function linkWritePerm() {
|
|
await assertRejects(async () => {
|
|
await Deno.link("oldbaddir", "newbaddir");
|
|
}, Deno.errors.PermissionDenied);
|
|
},
|
|
);
|