mirror of
https://github.com/denoland/deno.git
synced 2024-12-26 09:10:40 -05:00
63ca68d058
Previously, `Deno.permissions.[revoke|request]()` wouldn't correctly process the `path: URL` when `name` was `ffi`. This change fixes that behaviour and adds a new function, `formDescriptor()`, to ensure `URL` arguments are consistently handled across `Deno.permissions.[query|revoke|request]()`.
109 lines
3.5 KiB
TypeScript
109 lines
3.5 KiB
TypeScript
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
|
import {
|
|
assert,
|
|
assertEquals,
|
|
assertRejects,
|
|
assertThrows,
|
|
} from "./test_util.ts";
|
|
|
|
Deno.test(async function permissionInvalidName() {
|
|
await assertRejects(async () => {
|
|
// deno-lint-ignore no-explicit-any
|
|
await Deno.permissions.query({ name: "foo" as any });
|
|
}, TypeError);
|
|
});
|
|
|
|
Deno.test(async function permissionNetInvalidHost() {
|
|
await assertRejects(async () => {
|
|
await Deno.permissions.query({ name: "net", host: ":" });
|
|
}, URIError);
|
|
});
|
|
|
|
Deno.test(async function permissionSysValidKind() {
|
|
await Deno.permissions.query({ name: "sys", kind: "loadavg" });
|
|
await Deno.permissions.query({ name: "sys", kind: "osRelease" });
|
|
await Deno.permissions.query({ name: "sys", kind: "osUptime" });
|
|
await Deno.permissions.query({ name: "sys", kind: "networkInterfaces" });
|
|
await Deno.permissions.query({ name: "sys", kind: "systemMemoryInfo" });
|
|
await Deno.permissions.query({ name: "sys", kind: "hostname" });
|
|
await Deno.permissions.query({ name: "sys", kind: "uid" });
|
|
await Deno.permissions.query({ name: "sys", kind: "gid" });
|
|
});
|
|
|
|
Deno.test(async function permissionSysInvalidKind() {
|
|
await assertRejects(async () => {
|
|
// deno-lint-ignore no-explicit-any
|
|
await Deno.permissions.query({ name: "sys", kind: "abc" as any });
|
|
}, TypeError);
|
|
});
|
|
|
|
Deno.test(async function permissionQueryReturnsEventTarget() {
|
|
const status = await Deno.permissions.query({ name: "hrtime" });
|
|
assert(["granted", "denied", "prompt"].includes(status.state));
|
|
let called = false;
|
|
status.addEventListener("change", () => {
|
|
called = true;
|
|
});
|
|
status.dispatchEvent(new Event("change"));
|
|
assert(called);
|
|
assert(status === (await Deno.permissions.query({ name: "hrtime" })));
|
|
});
|
|
|
|
Deno.test(async function permissionQueryForReadReturnsSameStatus() {
|
|
const status1 = await Deno.permissions.query({
|
|
name: "read",
|
|
path: ".",
|
|
});
|
|
const status2 = await Deno.permissions.query({
|
|
name: "read",
|
|
path: ".",
|
|
});
|
|
assert(status1 === status2);
|
|
});
|
|
|
|
Deno.test(function permissionsIllegalConstructor() {
|
|
assertThrows(() => new Deno.Permissions(), TypeError, "Illegal constructor.");
|
|
assertEquals(Deno.Permissions.length, 0);
|
|
});
|
|
|
|
Deno.test(function permissionStatusIllegalConstructor() {
|
|
assertThrows(
|
|
() => new Deno.PermissionStatus(),
|
|
TypeError,
|
|
"Illegal constructor.",
|
|
);
|
|
assertEquals(Deno.PermissionStatus.length, 0);
|
|
});
|
|
|
|
// Regression test for https://github.com/denoland/deno/issues/17020
|
|
Deno.test(async function permissionURL() {
|
|
const path = new URL(".", import.meta.url);
|
|
|
|
await Deno.permissions.query({ name: "read", path });
|
|
await Deno.permissions.query({ name: "write", path });
|
|
await Deno.permissions.query({ name: "ffi", path });
|
|
await Deno.permissions.query({ name: "run", command: path });
|
|
});
|
|
|
|
Deno.test(async function permissionDescriptorValidation() {
|
|
for (const value of [undefined, null, {}]) {
|
|
for (const method of ["query", "request", "revoke"]) {
|
|
await assertRejects(
|
|
async () => {
|
|
// deno-lint-ignore no-explicit-any
|
|
await (Deno.permissions as any)[method](value as any);
|
|
},
|
|
TypeError,
|
|
'"undefined" is not a valid permission name',
|
|
);
|
|
}
|
|
}
|
|
});
|
|
|
|
// Regression test for https://github.com/denoland/deno/issues/15894.
|
|
Deno.test(async function permissionStatusObjectsNotEqual() {
|
|
assert(
|
|
await Deno.permissions.query({ name: "env", variable: "A" }) !=
|
|
await Deno.permissions.query({ name: "env", variable: "B" }),
|
|
);
|
|
});
|