summaryrefslogtreecommitdiff
path: root/tests/specs/npm/permissions_outside_package
diff options
context:
space:
mode:
authorBartek IwaƄczuk <biwanczuk@gmail.com>2024-09-26 02:50:54 +0100
committerGitHub <noreply@github.com>2024-09-26 01:50:54 +0000
commit5504acea6751480f1425c88353ad5d36257bdce7 (patch)
treefa02e6c546eae469aac894bfc71600ab4eccad28 /tests/specs/npm/permissions_outside_package
parent05415bb9de475aa8646985a545f30fe93136207e (diff)
feat: add `--allow-import` flag (#25469)
This replaces `--allow-net` for import permissions and makes the security sandbox stricter by also checking permissions for statically analyzable imports. By default, this has a value of `--allow-import=deno.land:443,jsr.io:443,esm.sh:443,raw.githubusercontent.com:443,gist.githubusercontent.com:443`, but that can be overridden by providing a different set of hosts. Additionally, when no value is provided, import permissions are inferred from the CLI arguments so the following works because `fresh.deno.dev:443` will be added to the list of allowed imports: ```ts deno run -A -r https://fresh.deno.dev ``` --------- Co-authored-by: David Sherret <dsherret@gmail.com>
Diffstat (limited to 'tests/specs/npm/permissions_outside_package')
-rw-r--r--tests/specs/npm/permissions_outside_package/__test__.jsonc8
-rw-r--r--tests/specs/npm/permissions_outside_package/permissions_outside_package/foo/config.js4
-rw-r--r--tests/specs/npm/permissions_outside_package/permissions_outside_package/foo/package.json4
-rw-r--r--tests/specs/npm/permissions_outside_package/permissions_outside_package/main.out3
-rw-r--r--tests/specs/npm/permissions_outside_package/permissions_outside_package/main.ts5
5 files changed, 24 insertions, 0 deletions
diff --git a/tests/specs/npm/permissions_outside_package/__test__.jsonc b/tests/specs/npm/permissions_outside_package/__test__.jsonc
new file mode 100644
index 000000000..58f917f73
--- /dev/null
+++ b/tests/specs/npm/permissions_outside_package/__test__.jsonc
@@ -0,0 +1,8 @@
+{
+ "args": "run --allow-read permissions_outside_package/main.ts",
+ "output": "permissions_outside_package/main.out",
+ "envs": {
+ "NO_COLOR": "1",
+ "NPM_CONFIG_REGISTRY": "http://localhost:4260/"
+ }
+}
diff --git a/tests/specs/npm/permissions_outside_package/permissions_outside_package/foo/config.js b/tests/specs/npm/permissions_outside_package/permissions_outside_package/foo/config.js
new file mode 100644
index 000000000..e667790d2
--- /dev/null
+++ b/tests/specs/npm/permissions_outside_package/permissions_outside_package/foo/config.js
@@ -0,0 +1,4 @@
+module.exports = {
+ "name": "foobar",
+ "version": "0.0.1",
+};
diff --git a/tests/specs/npm/permissions_outside_package/permissions_outside_package/foo/package.json b/tests/specs/npm/permissions_outside_package/permissions_outside_package/foo/package.json
new file mode 100644
index 000000000..cc049e6ce
--- /dev/null
+++ b/tests/specs/npm/permissions_outside_package/permissions_outside_package/foo/package.json
@@ -0,0 +1,4 @@
+{
+ "name": "foobar",
+ "version": "0.0.1"
+}
diff --git a/tests/specs/npm/permissions_outside_package/permissions_outside_package/main.out b/tests/specs/npm/permissions_outside_package/permissions_outside_package/main.out
new file mode 100644
index 000000000..089f329c4
--- /dev/null
+++ b/tests/specs/npm/permissions_outside_package/permissions_outside_package/main.out
@@ -0,0 +1,3 @@
+Download http://localhost:4260/@denotest/permissions-outside-package
+Download http://localhost:4260/@denotest/permissions-outside-package/1.0.0.tgz
+{ name: "foobar", version: "0.0.1" }
diff --git a/tests/specs/npm/permissions_outside_package/permissions_outside_package/main.ts b/tests/specs/npm/permissions_outside_package/permissions_outside_package/main.ts
new file mode 100644
index 000000000..934a3eebc
--- /dev/null
+++ b/tests/specs/npm/permissions_outside_package/permissions_outside_package/main.ts
@@ -0,0 +1,5 @@
+import { loadConfigFile } from "npm:@denotest/permissions-outside-package";
+
+const fileName = `${Deno.cwd()}/permissions_outside_package/foo/config.js`;
+const config = loadConfigFile(fileName);
+console.log(config);