From 44b2b950fd20e59fca1e6dddf522d456d2fd622f Mon Sep 17 00:00:00 2001 From: Roj Date: Thu, 8 Dec 2022 02:13:45 +0300 Subject: feat(cli): support configuring the lock file in the config file (#16781) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This allows the user to completely opt out from the lock file or rename it without having to use `--no-lock` and/or `--lock` in all commands. ## Don’t Use Lock File ```json { "lock": false } ``` ## Use Lock File With a Different Name ```json { "lock": "deno2.lock" } ``` The CLI args `--no-lock` and `--lock` will always override what is in the config file. Co-authored-by: David Sherret --- cli/tests/testdata/run/config_file_lock_boolean/deno.lock | 7 +++++++ cli/tests/testdata/run/config_file_lock_boolean/false.json | 3 +++ cli/tests/testdata/run/config_file_lock_boolean/false.main.out | 2 ++ cli/tests/testdata/run/config_file_lock_boolean/main.ts | 1 + cli/tests/testdata/run/config_file_lock_boolean/true.json | 3 +++ cli/tests/testdata/run/config_file_lock_boolean/true.main.out | 3 +++ cli/tests/testdata/run/config_file_lock_path.json | 3 +++ cli/tests/testdata/run/config_file_lock_path.out | 3 +++ 8 files changed, 25 insertions(+) create mode 100644 cli/tests/testdata/run/config_file_lock_boolean/deno.lock create mode 100644 cli/tests/testdata/run/config_file_lock_boolean/false.json create mode 100644 cli/tests/testdata/run/config_file_lock_boolean/false.main.out create mode 100644 cli/tests/testdata/run/config_file_lock_boolean/main.ts create mode 100644 cli/tests/testdata/run/config_file_lock_boolean/true.json create mode 100644 cli/tests/testdata/run/config_file_lock_boolean/true.main.out create mode 100644 cli/tests/testdata/run/config_file_lock_path.json create mode 100644 cli/tests/testdata/run/config_file_lock_path.out (limited to 'cli/tests/testdata') diff --git a/cli/tests/testdata/run/config_file_lock_boolean/deno.lock b/cli/tests/testdata/run/config_file_lock_boolean/deno.lock new file mode 100644 index 000000000..059f66789 --- /dev/null +++ b/cli/tests/testdata/run/config_file_lock_boolean/deno.lock @@ -0,0 +1,7 @@ +{ + "version": "2", + "remote": { + "http://localhost:4545/subdir/mod2.ts": "cae1d3e9f3c38cd415ff52dff854be8f3d17d35f8d7b3d285e813fb0f6393a2f", + "http://localhost:4545/subdir/print_hello.ts": "foobar" + } +} diff --git a/cli/tests/testdata/run/config_file_lock_boolean/false.json b/cli/tests/testdata/run/config_file_lock_boolean/false.json new file mode 100644 index 000000000..358b7d299 --- /dev/null +++ b/cli/tests/testdata/run/config_file_lock_boolean/false.json @@ -0,0 +1,3 @@ +{ + "lock": false +} diff --git a/cli/tests/testdata/run/config_file_lock_boolean/false.main.out b/cli/tests/testdata/run/config_file_lock_boolean/false.main.out new file mode 100644 index 000000000..0d8f0a237 --- /dev/null +++ b/cli/tests/testdata/run/config_file_lock_boolean/false.main.out @@ -0,0 +1,2 @@ +Download http://localhost:4545/subdir/mod2.ts +Download http://localhost:4545/subdir/print_hello.ts diff --git a/cli/tests/testdata/run/config_file_lock_boolean/main.ts b/cli/tests/testdata/run/config_file_lock_boolean/main.ts new file mode 100644 index 000000000..baa52775d --- /dev/null +++ b/cli/tests/testdata/run/config_file_lock_boolean/main.ts @@ -0,0 +1 @@ +import "http://localhost:4545/subdir/mod2.ts"; diff --git a/cli/tests/testdata/run/config_file_lock_boolean/true.json b/cli/tests/testdata/run/config_file_lock_boolean/true.json new file mode 100644 index 000000000..090481af9 --- /dev/null +++ b/cli/tests/testdata/run/config_file_lock_boolean/true.json @@ -0,0 +1,3 @@ +{ + "lock": true +} diff --git a/cli/tests/testdata/run/config_file_lock_boolean/true.main.out b/cli/tests/testdata/run/config_file_lock_boolean/true.main.out new file mode 100644 index 000000000..313c0eb0c --- /dev/null +++ b/cli/tests/testdata/run/config_file_lock_boolean/true.main.out @@ -0,0 +1,3 @@ +[WILDCARD]The source code is invalid, as it does not match the expected hash in the lock file. + Specifier: http://localhost:4545/subdir/print_hello.ts + Lock file: [WILDCARD]deno.lock diff --git a/cli/tests/testdata/run/config_file_lock_path.json b/cli/tests/testdata/run/config_file_lock_path.json new file mode 100644 index 000000000..2c393f76e --- /dev/null +++ b/cli/tests/testdata/run/config_file_lock_path.json @@ -0,0 +1,3 @@ +{ + "lock": "./lock_check_err2.json" +} diff --git a/cli/tests/testdata/run/config_file_lock_path.out b/cli/tests/testdata/run/config_file_lock_path.out new file mode 100644 index 000000000..97d35337f --- /dev/null +++ b/cli/tests/testdata/run/config_file_lock_path.out @@ -0,0 +1,3 @@ +[WILDCARD]The source code is invalid, as it does not match the expected hash in the lock file. + Specifier: http://localhost:4545/subdir/mt_text_ecmascript.j3.js + Lock file: [WILDCARD]lock_check_err2.json -- cgit v1.2.3