mirror of
https://github.com/denoland/deno.git
synced 2025-01-12 17:09:00 -05:00
feat(runtime): support URL overloads for Deno.symlink
and Deno.symlinkSync
(#10664)
This commit is contained in:
parent
dc69b03339
commit
ece56d9935
3 changed files with 56 additions and 7 deletions
8
cli/dts/lib.deno.ns.d.ts
vendored
8
cli/dts/lib.deno.ns.d.ts
vendored
|
@ -2379,8 +2379,8 @@ declare namespace Deno {
|
||||||
*
|
*
|
||||||
* Requires `allow-write` permission. */
|
* Requires `allow-write` permission. */
|
||||||
export function symlinkSync(
|
export function symlinkSync(
|
||||||
oldpath: string,
|
oldpath: string | URL,
|
||||||
newpath: string,
|
newpath: string | URL,
|
||||||
options?: SymlinkOptions,
|
options?: SymlinkOptions,
|
||||||
): void;
|
): void;
|
||||||
|
|
||||||
|
@ -2396,8 +2396,8 @@ declare namespace Deno {
|
||||||
*
|
*
|
||||||
* Requires `allow-write` permission. */
|
* Requires `allow-write` permission. */
|
||||||
export function symlink(
|
export function symlink(
|
||||||
oldpath: string,
|
oldpath: string | URL,
|
||||||
newpath: string,
|
newpath: string | URL,
|
||||||
options?: SymlinkOptions,
|
options?: SymlinkOptions,
|
||||||
): Promise<void>;
|
): Promise<void>;
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,10 @@
|
||||||
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
|
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
|
||||||
import { assert, assertThrows, unitTest } from "./test_util.ts";
|
import {
|
||||||
|
assert,
|
||||||
|
assertThrows,
|
||||||
|
pathToAbsoluteFileUrl,
|
||||||
|
unitTest,
|
||||||
|
} from "./test_util.ts";
|
||||||
|
|
||||||
unitTest(
|
unitTest(
|
||||||
{ perms: { read: true, write: true } },
|
{ perms: { read: true, write: true } },
|
||||||
|
@ -16,6 +21,24 @@ unitTest(
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|
||||||
|
unitTest(
|
||||||
|
{ perms: { read: true, write: true } },
|
||||||
|
function symlinkSyncURL(): void {
|
||||||
|
const testDir = Deno.makeTempDirSync();
|
||||||
|
const oldname = testDir + "/oldname";
|
||||||
|
const newname = testDir + "/newname";
|
||||||
|
Deno.mkdirSync(oldname);
|
||||||
|
Deno.symlinkSync(
|
||||||
|
pathToAbsoluteFileUrl(oldname),
|
||||||
|
pathToAbsoluteFileUrl(newname),
|
||||||
|
);
|
||||||
|
const newNameInfoLStat = Deno.lstatSync(newname);
|
||||||
|
const newNameInfoStat = Deno.statSync(newname);
|
||||||
|
assert(newNameInfoLStat.isSymlink);
|
||||||
|
assert(newNameInfoStat.isDirectory);
|
||||||
|
},
|
||||||
|
);
|
||||||
|
|
||||||
unitTest(function symlinkSyncPerm(): void {
|
unitTest(function symlinkSyncPerm(): void {
|
||||||
assertThrows(() => {
|
assertThrows(() => {
|
||||||
Deno.symlinkSync("oldbaddir", "newbaddir");
|
Deno.symlinkSync("oldbaddir", "newbaddir");
|
||||||
|
@ -36,3 +59,21 @@ unitTest(
|
||||||
assert(newNameInfoStat.isDirectory, "NOT DIRECTORY");
|
assert(newNameInfoStat.isDirectory, "NOT DIRECTORY");
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|
||||||
|
unitTest(
|
||||||
|
{ perms: { read: true, write: true } },
|
||||||
|
async function symlinkURL(): Promise<void> {
|
||||||
|
const testDir = Deno.makeTempDirSync();
|
||||||
|
const oldname = testDir + "/oldname";
|
||||||
|
const newname = testDir + "/newname";
|
||||||
|
Deno.mkdirSync(oldname);
|
||||||
|
await Deno.symlink(
|
||||||
|
pathToAbsoluteFileUrl(oldname),
|
||||||
|
pathToAbsoluteFileUrl(newname),
|
||||||
|
);
|
||||||
|
const newNameInfoLStat = Deno.lstatSync(newname);
|
||||||
|
const newNameInfoStat = Deno.statSync(newname);
|
||||||
|
assert(newNameInfoLStat.isSymlink, "NOT SYMLINK");
|
||||||
|
assert(newNameInfoStat.isDirectory, "NOT DIRECTORY");
|
||||||
|
},
|
||||||
|
);
|
||||||
|
|
|
@ -344,7 +344,11 @@
|
||||||
newpath,
|
newpath,
|
||||||
options,
|
options,
|
||||||
) {
|
) {
|
||||||
core.opSync("op_symlink_sync", { oldpath, newpath, options });
|
core.opSync("op_symlink_sync", {
|
||||||
|
oldpath: pathFromURL(oldpath),
|
||||||
|
newpath: pathFromURL(newpath),
|
||||||
|
options,
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async function symlink(
|
async function symlink(
|
||||||
|
@ -352,7 +356,11 @@
|
||||||
newpath,
|
newpath,
|
||||||
options,
|
options,
|
||||||
) {
|
) {
|
||||||
await core.opAsync("op_symlink_async", { oldpath, newpath, options });
|
await core.opAsync("op_symlink_async", {
|
||||||
|
oldpath: pathFromURL(oldpath),
|
||||||
|
newpath: pathFromURL(newpath),
|
||||||
|
options,
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function fdatasyncSync(rid) {
|
function fdatasyncSync(rid) {
|
||||||
|
|
Loading…
Reference in a new issue