From a6a82d692f3e07f0142f8adf6b9d6876f7287964 Mon Sep 17 00:00:00 2001 From: laniakea64 Date: Sun, 6 Oct 2024 16:56:03 -0400 Subject: [PATCH] tests: switch from `cargo-watch` to `watchexec-cli` and improve `just watch` --- CONTRIBUTING.md | 4 ++-- tests/justfile | 19 +++++++++---------- 2 files changed, 11 insertions(+), 12 deletions(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 35a614b..bd92ddc 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -43,7 +43,7 @@ is a simple test-runner in the `main` fn. * Rust ([simple/recommended installation instructions](https://www.rust-lang.org/tools/install); for detailed and alternative installation instructions see [here](https://forge.rust-lang.org/infra/other-installation-methods.html)) Run `just deps` to install the cargo dev dependencies, which right now is only -[`cargo-watch`](https://crates.io/crates/cargo-watch). +[Watchexec CLI](https://crates.io/crates/watchexec-cli). ### Running the tests @@ -80,7 +80,7 @@ To run the filetype detection tests, run `just ftdetect` in tests/. If you're going to do more than a simple change, I recommend calling `just watch` in tests/, which will watch for any changes in the whole repo and re-run the test suite. By default, it will run the syntax highlighting tests. -`just watch` accepts up to two parameters to customize which tests to watch: +`just watch` accepts positional parameters to customize which tests to watch: ```bash # watch all syntax highlighting tests (default) diff --git a/tests/justfile b/tests/justfile index 9b3b7de..7a18756 100644 --- a/tests/justfile +++ b/tests/justfile @@ -14,17 +14,16 @@ cases_invalid_justfiles := """ run FILTER='': cargo run {{ if FILTER == '' { '' } else { '-- ' + quote(FILTER) } }} -watchwatch := '`just watch watch` is redundant' - # run tests whenever a file changes -watch RECIPE='run' FILTER='': build - cargo watch \ +[positional-arguments] +watch *args: + {{if args =~ '(?:^|\s)watch(?:\s|$)' { error('`just watch watch` is redundant') } else { '' } }} + watchexec \ --clear \ - --shell "{{quote(just_executable())}} \ - {{if RECIPE == 'watch' { error(watchwatch) } else { quote(RECIPE) } }} \ - {{if RECIPE + FILTER =~ 'watch' { error(watchwatch) } else if FILTER == '' { '' } else { quote(FILTER) } }} \ - " \ - --watch .. + --shell=none \ + --project-origin {{quote(clean(source_directory() / '..'))}} \ + --watch {{quote(clean(source_directory() / '..'))}} \ + {{quote(just_executable())}} "$@" # run ftdetect tests ftdetect: @@ -32,7 +31,7 @@ ftdetect: # install development dependencies deps: - cargo install --locked cargo-watch + cargo install watchexec-cli # compile test runner without running tests build: