From ba209d6abd74c4ee85abe732ca19e1c067d77744 Mon Sep 17 00:00:00 2001 From: Weihang Lo Date: Fri, 18 Aug 2023 10:50:40 +0100 Subject: [PATCH 1/4] refactor(arg): rename `arg_jobs` to `arg_parallel` --- src/bin/cargo/commands/bench.rs | 2 +- src/bin/cargo/commands/build.rs | 2 +- src/bin/cargo/commands/check.rs | 2 +- src/bin/cargo/commands/doc.rs | 2 +- src/bin/cargo/commands/fix.rs | 2 +- src/bin/cargo/commands/install.rs | 2 +- src/bin/cargo/commands/package.rs | 2 +- src/bin/cargo/commands/publish.rs | 2 +- src/bin/cargo/commands/run.rs | 2 +- src/bin/cargo/commands/rustc.rs | 2 +- src/bin/cargo/commands/rustdoc.rs | 2 +- src/bin/cargo/commands/test.rs | 2 +- src/cargo/util/command_prelude.rs | 6 +++--- 13 files changed, 15 insertions(+), 15 deletions(-) diff --git a/src/bin/cargo/commands/bench.rs b/src/bin/cargo/commands/bench.rs index bb2c193b0a14..9c36422c47db 100644 --- a/src/bin/cargo/commands/bench.rs +++ b/src/bin/cargo/commands/bench.rs @@ -42,7 +42,7 @@ pub fn cli() -> Command { "Benchmark all targets", ) .arg_features() - .arg_jobs_without_keep_going() + .arg_jobs() .arg(flag("keep-going", "Use `--no-fail-fast` instead").hide(true)) // See rust-lang/cargo#11702 .arg_profile("Build artifacts with the specified profile") .arg_target_triple("Build for the target triple") diff --git a/src/bin/cargo/commands/build.rs b/src/bin/cargo/commands/build.rs index e25638aa0d8e..19076d32895a 100644 --- a/src/bin/cargo/commands/build.rs +++ b/src/bin/cargo/commands/build.rs @@ -31,7 +31,7 @@ pub fn cli() -> Command { .arg_features() .arg_release("Build artifacts in release mode, with optimizations") .arg_profile("Build artifacts with the specified profile") - .arg_jobs() + .arg_parallel() .arg_target_triple("Build for the target triple") .arg_target_dir() .arg( diff --git a/src/bin/cargo/commands/check.rs b/src/bin/cargo/commands/check.rs index ab6f990488b6..62df0c106705 100644 --- a/src/bin/cargo/commands/check.rs +++ b/src/bin/cargo/commands/check.rs @@ -29,7 +29,7 @@ pub fn cli() -> Command { "Check all targets", ) .arg_features() - .arg_jobs() + .arg_parallel() .arg_release("Check artifacts in release mode, with optimizations") .arg_profile("Check artifacts with the specified profile") .arg_target_triple("Check for the target triple") diff --git a/src/bin/cargo/commands/doc.rs b/src/bin/cargo/commands/doc.rs index c3dfe426dd0e..e209eb7dbdb4 100644 --- a/src/bin/cargo/commands/doc.rs +++ b/src/bin/cargo/commands/doc.rs @@ -32,7 +32,7 @@ pub fn cli() -> Command { "Document only the specified example", "Document all examples", ) - .arg_jobs() + .arg_parallel() .arg_release("Build artifacts in release mode, with optimizations") .arg_profile("Build artifacts with the specified profile") .arg_target_triple("Build for the target triple") diff --git a/src/bin/cargo/commands/fix.rs b/src/bin/cargo/commands/fix.rs index 1f98dd67e0f2..96afbbdccd4c 100644 --- a/src/bin/cargo/commands/fix.rs +++ b/src/bin/cargo/commands/fix.rs @@ -47,7 +47,7 @@ pub fn cli() -> Command { "Fix all targets (default)", ) .arg_features() - .arg_jobs() + .arg_parallel() .arg_release("Fix artifacts in release mode, with optimizations") .arg_profile("Build artifacts with the specified profile") .arg_target_triple("Fix for the target triple") diff --git a/src/bin/cargo/commands/install.rs b/src/bin/cargo/commands/install.rs index 8abb00190441..05d3483232d2 100644 --- a/src/bin/cargo/commands/install.rs +++ b/src/bin/cargo/commands/install.rs @@ -75,7 +75,7 @@ pub fn cli() -> Command { "Install all examples", ) .arg_features() - .arg_jobs() + .arg_parallel() .arg(flag( "debug", "Build in debug mode (with the 'dev' profile) instead of release mode", diff --git a/src/bin/cargo/commands/package.rs b/src/bin/cargo/commands/package.rs index cf4ac795c6b3..e87fb3ef8a79 100644 --- a/src/bin/cargo/commands/package.rs +++ b/src/bin/cargo/commands/package.rs @@ -33,7 +33,7 @@ pub fn cli() -> Command { .arg_features() .arg_target_triple("Build for the target triple") .arg_target_dir() - .arg_jobs() + .arg_parallel() .arg_manifest_path() .after_help("Run `cargo help package` for more detailed information.\n") } diff --git a/src/bin/cargo/commands/publish.rs b/src/bin/cargo/commands/publish.rs index bda240c8c821..f30633e3de42 100644 --- a/src/bin/cargo/commands/publish.rs +++ b/src/bin/cargo/commands/publish.rs @@ -20,7 +20,7 @@ pub fn cli() -> Command { .arg_quiet() .arg_package("Package to publish") .arg_features() - .arg_jobs() + .arg_parallel() .arg_target_triple("Build for the target triple") .arg_target_dir() .arg_manifest_path() diff --git a/src/bin/cargo/commands/run.rs b/src/bin/cargo/commands/run.rs index 1649f72ac31b..ce2099b0e505 100644 --- a/src/bin/cargo/commands/run.rs +++ b/src/bin/cargo/commands/run.rs @@ -30,7 +30,7 @@ pub fn cli() -> Command { "Name of the example target to run", ) .arg_features() - .arg_jobs() + .arg_parallel() .arg_release("Build artifacts in release mode, with optimizations") .arg_profile("Build artifacts with the specified profile") .arg_target_triple("Build for the target triple") diff --git a/src/bin/cargo/commands/rustc.rs b/src/bin/cargo/commands/rustc.rs index 0a0364e3755e..d318b619463e 100644 --- a/src/bin/cargo/commands/rustc.rs +++ b/src/bin/cargo/commands/rustc.rs @@ -44,7 +44,7 @@ pub fn cli() -> Command { "Build all targets", ) .arg_features() - .arg_jobs() + .arg_parallel() .arg_release("Build artifacts in release mode, with optimizations") .arg_profile("Build artifacts with the specified profile") .arg_target_triple("Target triple which compiles will be for") diff --git a/src/bin/cargo/commands/rustdoc.rs b/src/bin/cargo/commands/rustdoc.rs index 488256ba7dce..25ca7dacf36d 100644 --- a/src/bin/cargo/commands/rustdoc.rs +++ b/src/bin/cargo/commands/rustdoc.rs @@ -32,7 +32,7 @@ pub fn cli() -> Command { "Build all targets", ) .arg_features() - .arg_jobs() + .arg_parallel() .arg_release("Build artifacts in release mode, with optimizations") .arg_profile("Build artifacts with the specified profile") .arg_target_triple("Build for the target triple") diff --git a/src/bin/cargo/commands/test.rs b/src/bin/cargo/commands/test.rs index 80c935d628e7..8313851f3a73 100644 --- a/src/bin/cargo/commands/test.rs +++ b/src/bin/cargo/commands/test.rs @@ -48,7 +48,7 @@ pub fn cli() -> Command { "Test all targets (does not include doctests)", ) .arg_features() - .arg_jobs_without_keep_going() + .arg_jobs() .arg(flag("keep-going", "Use `--no-fail-fast` instead").hide(true)) // See rust-lang/cargo#11702 .arg_release("Build artifacts in release mode, with optimizations") .arg_profile("Build artifacts with the specified profile") diff --git a/src/cargo/util/command_prelude.rs b/src/cargo/util/command_prelude.rs index bc707ef6f657..332ac415b53c 100644 --- a/src/cargo/util/command_prelude.rs +++ b/src/cargo/util/command_prelude.rs @@ -82,8 +82,8 @@ pub trait CommandExt: Sized { ) } - fn arg_jobs(self) -> Self { - self.arg_jobs_without_keep_going()._arg( + fn arg_parallel(self) -> Self { + self.arg_jobs()._arg( flag( "keep-going", "Do not abort the build as soon as there is an error (unstable)", @@ -92,7 +92,7 @@ pub trait CommandExt: Sized { ) } - fn arg_jobs_without_keep_going(self) -> Self { + fn arg_jobs(self) -> Self { self._arg( opt("jobs", "Number of parallel jobs, defaults to # of CPUs.") .short('j') From c1f7e2bb04863d1c6b4e0995c15a541fbaff1a5a Mon Sep 17 00:00:00 2001 From: Weihang Lo Date: Fri, 18 Aug 2023 10:55:44 +0100 Subject: [PATCH 2/4] chore: upgrate clap to 4.3.23 --- Cargo.lock | 8 ++++---- Cargo.toml | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 7e2129306f7c..78afddfbaac0 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -508,18 +508,18 @@ dependencies = [ [[package]] name = "clap" -version = "4.3.19" +version = "4.3.23" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5fd304a20bff958a57f04c4e96a2e7594cc4490a0e809cbd48bb6437edaa452d" +checksum = "03aef18ddf7d879c15ce20f04826ef8418101c7e528014c3eeea13321047dca3" dependencies = [ "clap_builder", ] [[package]] name = "clap_builder" -version = "4.3.19" +version = "4.3.23" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "01c6a3f08f1fe5662a35cfe393aec09c4df95f60ee93b7556505260f75eee9e1" +checksum = "f8ce6fffb678c9b80a70b6b6de0aad31df727623a70fd9a842c30cd573e2fa98" dependencies = [ "anstream", "anstyle", diff --git a/Cargo.toml b/Cargo.toml index 16de41e38ce2..2659e496161f 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -28,7 +28,7 @@ cargo-test-macro = { path = "crates/cargo-test-macro" } cargo-test-support = { path = "crates/cargo-test-support" } cargo-util = { version = "0.2.6", path = "crates/cargo-util" } cargo_metadata = "0.14.0" -clap = "4.3.19" +clap = "4.3.23" core-foundation = { version = "0.9.3", features = ["mac_os_10_7_support"] } crates-io = { version = "0.38.0", path = "crates/crates-io" } criterion = { version = "0.5.1", features = ["html_reports"] } From 4d0958587b8412fc7667881717a5b218e195dde5 Mon Sep 17 00:00:00 2001 From: Weihang Lo Date: Fri, 18 Aug 2023 10:54:41 +0100 Subject: [PATCH 3/4] refactor(arg): use `UnknownArgumentValueParser` to suggest arg for unknown args --- src/bin/cargo/commands/bench.rs | 12 +------- src/bin/cargo/commands/test.rs | 12 +------- src/bin/cargo/commands/vendor.rs | 48 +++++++++++-------------------- src/cargo/util/command_prelude.rs | 22 +++++++++++++- tests/testsuite/bench.rs | 11 +++++-- tests/testsuite/test.rs | 11 +++++-- 6 files changed, 55 insertions(+), 61 deletions(-) diff --git a/src/bin/cargo/commands/bench.rs b/src/bin/cargo/commands/bench.rs index 9c36422c47db..971dc9456483 100644 --- a/src/bin/cargo/commands/bench.rs +++ b/src/bin/cargo/commands/bench.rs @@ -43,7 +43,7 @@ pub fn cli() -> Command { ) .arg_features() .arg_jobs() - .arg(flag("keep-going", "Use `--no-fail-fast` instead").hide(true)) // See rust-lang/cargo#11702 + .arg_unsupported_keep_going() .arg_profile("Build artifacts with the specified profile") .arg_target_triple("Build for the target triple") .arg_target_dir() @@ -56,16 +56,6 @@ pub fn cli() -> Command { pub fn exec(config: &mut Config, args: &ArgMatches) -> CliResult { let ws = args.workspace(config)?; - if args.keep_going() { - return Err(anyhow::format_err!( - "\ -unexpected argument `--keep-going` found - - tip: to run as many benchmarks as possible without failing fast, use `--no-fail-fast`" - ) - .into()); - } - let mut compile_opts = args.compile_options( config, CompileMode::Bench, diff --git a/src/bin/cargo/commands/test.rs b/src/bin/cargo/commands/test.rs index 8313851f3a73..f8ec0e2f9460 100644 --- a/src/bin/cargo/commands/test.rs +++ b/src/bin/cargo/commands/test.rs @@ -49,7 +49,7 @@ pub fn cli() -> Command { ) .arg_features() .arg_jobs() - .arg(flag("keep-going", "Use `--no-fail-fast` instead").hide(true)) // See rust-lang/cargo#11702 + .arg_unsupported_keep_going() .arg_release("Build artifacts in release mode, with optimizations") .arg_profile("Build artifacts with the specified profile") .arg_target_triple("Build for the target triple") @@ -66,16 +66,6 @@ pub fn cli() -> Command { pub fn exec(config: &mut Config, args: &ArgMatches) -> CliResult { let ws = args.workspace(config)?; - if args.keep_going() { - return Err(anyhow::format_err!( - "\ -unexpected argument `--keep-going` found - - tip: to run as many tests as possible without failing fast, use `--no-fail-fast`" - ) - .into()); - } - let mut compile_opts = args.compile_options( config, CompileMode::Test, diff --git a/src/bin/cargo/commands/vendor.rs b/src/bin/cargo/commands/vendor.rs index 69b4ee3802c8..f0c1ecad061a 100644 --- a/src/bin/cargo/commands/vendor.rs +++ b/src/bin/cargo/commands/vendor.rs @@ -32,15 +32,27 @@ pub fn cli() -> Command { "versioned-dirs", "Always include version in subdir name", )) - .arg(flag("no-merge-sources", "Not supported").hide(true)) - .arg(flag("relative-path", "Not supported").hide(true)) - .arg(flag("only-git-deps", "Not supported").hide(true)) - .arg(flag("disallow-duplicates", "Not supported").hide(true)) + .arg(unsupported("no-merge-sources")) + .arg(unsupported("relative-path")) + .arg(unsupported("only-git-deps")) + .arg(unsupported("disallow-duplicates")) .arg_quiet() .arg_manifest_path() .after_help("Run `cargo help vendor` for more detailed information.\n") } +fn unsupported(name: &'static str) -> Arg { + // When we moved `cargo vendor` into Cargo itself we didn't stabilize a few + // flags, so try to provide a helpful error message in that case to ensure + // that users currently using the flag aren't tripped up. + let value_parser = clap::builder::UnknownArgumentValueParser::suggest("the crates.io `cargo vendor` command has been merged into Cargo") + .and_suggest(format!("and the flag `--{name}` isn't supported currently")) + .and_suggest("to continue using the flag, execute `cargo-vendor vendor ...`") + .and_suggest("to suggest this flag supported in Cargo, file an issue at "); + + flag(name, "").value_parser(value_parser).hide(true) +} + pub fn exec(config: &mut Config, args: &ArgMatches) -> CliResult { // We're doing the vendoring operation ourselves, so we don't actually want // to respect any of the `source` configuration in Cargo itself. That's @@ -50,34 +62,6 @@ pub fn exec(config: &mut Config, args: &ArgMatches) -> CliResult { config.values_mut()?.remove("source"); } - // When we moved `cargo vendor` into Cargo itself we didn't stabilize a few - // flags, so try to provide a helpful error message in that case to ensure - // that users currently using the flag aren't tripped up. - let crates_io_cargo_vendor_flag = if args.flag("no-merge-sources") { - Some("--no-merge-sources") - } else if args.flag("relative-path") { - Some("--relative-path") - } else if args.flag("only-git-deps") { - Some("--only-git-deps") - } else if args.flag("disallow-duplicates") { - Some("--disallow-duplicates") - } else { - None - }; - if let Some(flag) = crates_io_cargo_vendor_flag { - return Err(anyhow::format_err!( - "\ -the crates.io `cargo vendor` command has now been merged into Cargo itself -and does not support the flag `{}` currently; to continue using the flag you -can execute `cargo-vendor vendor ...`, and if you would like to see this flag -supported in Cargo itself please feel free to file an issue at -https://github.com/rust-lang/cargo/issues/new -", - flag - ) - .into()); - } - let ws = args.workspace(config)?; let path = args .get_one::("path") diff --git a/src/cargo/util/command_prelude.rs b/src/cargo/util/command_prelude.rs index 332ac415b53c..84545ae998e5 100644 --- a/src/cargo/util/command_prelude.rs +++ b/src/cargo/util/command_prelude.rs @@ -14,6 +14,7 @@ use crate::util::{ use crate::CargoResult; use anyhow::bail; use cargo_util::paths; +use clap::builder::UnknownArgumentValueParser; use std::ffi::{OsStr, OsString}; use std::path::Path; use std::path::PathBuf; @@ -102,6 +103,12 @@ pub trait CommandExt: Sized { ) } + fn arg_unsupported_keep_going(self) -> Self { + let msg = "use `--no-fail-fast` to run as many tests as possible regardless of failure"; + let value_parser = UnknownArgumentValueParser::suggest(msg); + self._arg(flag("keep-going", "").value_parser(value_parser).hide(true)) + } + fn arg_targets_all( self, lib: &'static str, @@ -431,7 +438,7 @@ pub trait ArgMatchesExt { } fn keep_going(&self) -> bool { - self.flag("keep-going") + self.maybe_flag("keep-going") } fn targets(&self) -> Vec { @@ -777,6 +784,8 @@ pub trait ArgMatchesExt { fn flag(&self, name: &str) -> bool; + fn maybe_flag(&self, name: &str) -> bool; + fn _value_of(&self, name: &str) -> Option<&str>; fn _values_of(&self, name: &str) -> Vec; @@ -797,6 +806,17 @@ impl<'a> ArgMatchesExt for ArgMatches { .unwrap_or(false) } + // This works around before an upstream fix in clap for `UnknownArgumentValueParser` accepting + // generics arguments. `flag()` cannot be used with `--keep-going` at this moment due to + // . + fn maybe_flag(&self, name: &str) -> bool { + self.try_get_one::(name) + .ok() + .flatten() + .copied() + .unwrap_or_default() + } + fn _value_of(&self, name: &str) -> Option<&str> { ignore_unknown(self.try_get_one::(name)).map(String::as_str) } diff --git a/tests/testsuite/bench.rs b/tests/testsuite/bench.rs index d773308c6836..6b09d47eb5f6 100644 --- a/tests/testsuite/bench.rs +++ b/tests/testsuite/bench.rs @@ -1681,11 +1681,16 @@ fn cargo_bench_no_keep_going() { p.cargo("bench --keep-going") .with_stderr( "\ -error: unexpected argument `--keep-going` found +error: unexpected argument '--keep-going' found - tip: to run as many benchmarks as possible without failing fast, use `--no-fail-fast`", + tip: use `--no-fail-fast` to run as many tests as possible regardless of failure + +Usage: cargo bench [OPTIONS] [BENCHNAME] [-- [args]...] + +For more information, try '--help'. +", ) - .with_status(101) + .with_status(1) .run(); } diff --git a/tests/testsuite/test.rs b/tests/testsuite/test.rs index c6ae4ce612f8..758bfe09c582 100644 --- a/tests/testsuite/test.rs +++ b/tests/testsuite/test.rs @@ -4854,11 +4854,16 @@ fn cargo_test_no_keep_going() { p.cargo("test --keep-going") .with_stderr( "\ -error: unexpected argument `--keep-going` found +error: unexpected argument '--keep-going' found - tip: to run as many tests as possible without failing fast, use `--no-fail-fast`", + tip: use `--no-fail-fast` to run as many tests as possible regardless of failure + +Usage: cargo test [OPTIONS] [TESTNAME] [-- [args]...] + +For more information, try '--help'. +", ) - .with_status(101) + .with_status(1) .run(); } From a31aaac5367b28d1bfe9c6debb0ad658dab73e60 Mon Sep 17 00:00:00 2001 From: Weihang Lo Date: Tue, 22 Aug 2023 07:44:36 +0100 Subject: [PATCH 4/4] test: move `--keep-going` suggestion match tests to UI tests We don't want to overly match to suggestion help from clap. --- tests/testsuite/bench.rs | 23 ------------------- tests/testsuite/cargo_bench/mod.rs | 1 + .../cargo_bench/no_keep_going/in/Cargo.toml | 3 +++ .../cargo_bench/no_keep_going/in/src/lib.rs | 0 .../cargo_bench/no_keep_going/mod.rs | 19 +++++++++++++++ .../cargo_bench/no_keep_going/stderr.log | 7 ++++++ .../cargo_bench/no_keep_going/stdout.log | 0 tests/testsuite/cargo_test/mod.rs | 1 + .../cargo_test/no_keep_going/in/Cargo.toml | 3 +++ .../cargo_test/no_keep_going/in/src/lib.rs | 0 .../testsuite/cargo_test/no_keep_going/mod.rs | 19 +++++++++++++++ .../cargo_test/no_keep_going/stderr.log | 7 ++++++ .../cargo_test/no_keep_going/stdout.log | 0 tests/testsuite/test.rs | 23 ------------------- 14 files changed, 60 insertions(+), 46 deletions(-) create mode 100644 tests/testsuite/cargo_bench/no_keep_going/in/Cargo.toml create mode 100644 tests/testsuite/cargo_bench/no_keep_going/in/src/lib.rs create mode 100644 tests/testsuite/cargo_bench/no_keep_going/mod.rs create mode 100644 tests/testsuite/cargo_bench/no_keep_going/stderr.log create mode 100644 tests/testsuite/cargo_bench/no_keep_going/stdout.log create mode 100644 tests/testsuite/cargo_test/no_keep_going/in/Cargo.toml create mode 100644 tests/testsuite/cargo_test/no_keep_going/in/src/lib.rs create mode 100644 tests/testsuite/cargo_test/no_keep_going/mod.rs create mode 100644 tests/testsuite/cargo_test/no_keep_going/stderr.log create mode 100644 tests/testsuite/cargo_test/no_keep_going/stdout.log diff --git a/tests/testsuite/bench.rs b/tests/testsuite/bench.rs index 6b09d47eb5f6..01017e85762c 100644 --- a/tests/testsuite/bench.rs +++ b/tests/testsuite/bench.rs @@ -1671,29 +1671,6 @@ fn json_artifact_includes_executable_for_benchmark() { .run(); } -#[cargo_test] -fn cargo_bench_no_keep_going() { - let p = project() - .file("Cargo.toml", &basic_bin_manifest("foo")) - .file("src/main.rs", "") - .build(); - - p.cargo("bench --keep-going") - .with_stderr( - "\ -error: unexpected argument '--keep-going' found - - tip: use `--no-fail-fast` to run as many tests as possible regardless of failure - -Usage: cargo bench [OPTIONS] [BENCHNAME] [-- [args]...] - -For more information, try '--help'. -", - ) - .with_status(1) - .run(); -} - #[cargo_test(nightly, reason = "bench")] fn cargo_bench_print_env_verbose() { let p = project() diff --git a/tests/testsuite/cargo_bench/mod.rs b/tests/testsuite/cargo_bench/mod.rs index c0ce11180711..28be9d1a7c5f 100644 --- a/tests/testsuite/cargo_bench/mod.rs +++ b/tests/testsuite/cargo_bench/mod.rs @@ -1 +1,2 @@ mod help; +mod no_keep_going; diff --git a/tests/testsuite/cargo_bench/no_keep_going/in/Cargo.toml b/tests/testsuite/cargo_bench/no_keep_going/in/Cargo.toml new file mode 100644 index 000000000000..c35d63273aa7 --- /dev/null +++ b/tests/testsuite/cargo_bench/no_keep_going/in/Cargo.toml @@ -0,0 +1,3 @@ +[package] +name = "foo" +version = "0.1.0" diff --git a/tests/testsuite/cargo_bench/no_keep_going/in/src/lib.rs b/tests/testsuite/cargo_bench/no_keep_going/in/src/lib.rs new file mode 100644 index 000000000000..e69de29bb2d1 diff --git a/tests/testsuite/cargo_bench/no_keep_going/mod.rs b/tests/testsuite/cargo_bench/no_keep_going/mod.rs new file mode 100644 index 000000000000..6ed5f81f9768 --- /dev/null +++ b/tests/testsuite/cargo_bench/no_keep_going/mod.rs @@ -0,0 +1,19 @@ +use cargo_test_support::curr_dir; +use cargo_test_support::CargoCommand; +use cargo_test_support::Project; + +#[cargo_test] +fn case() { + let project = Project::from_template(curr_dir!().join("in")); + let project_root = project.root(); + let cwd = &project_root; + + snapbox::cmd::Command::cargo_ui() + .arg("bench") + .arg("--keep-going") + .current_dir(cwd) + .assert() + .code(1) + .stdout_matches_path(curr_dir!().join("stdout.log")) + .stderr_matches_path(curr_dir!().join("stderr.log")); +} diff --git a/tests/testsuite/cargo_bench/no_keep_going/stderr.log b/tests/testsuite/cargo_bench/no_keep_going/stderr.log new file mode 100644 index 000000000000..8e8f1c034b80 --- /dev/null +++ b/tests/testsuite/cargo_bench/no_keep_going/stderr.log @@ -0,0 +1,7 @@ +error: unexpected argument '--keep-going' found + + tip: use `--no-fail-fast` to run as many tests as possible regardless of failure + +Usage: cargo bench [OPTIONS] [BENCHNAME] [-- [args]...] + +For more information, try '--help'. diff --git a/tests/testsuite/cargo_bench/no_keep_going/stdout.log b/tests/testsuite/cargo_bench/no_keep_going/stdout.log new file mode 100644 index 000000000000..e69de29bb2d1 diff --git a/tests/testsuite/cargo_test/mod.rs b/tests/testsuite/cargo_test/mod.rs index c0ce11180711..28be9d1a7c5f 100644 --- a/tests/testsuite/cargo_test/mod.rs +++ b/tests/testsuite/cargo_test/mod.rs @@ -1 +1,2 @@ mod help; +mod no_keep_going; diff --git a/tests/testsuite/cargo_test/no_keep_going/in/Cargo.toml b/tests/testsuite/cargo_test/no_keep_going/in/Cargo.toml new file mode 100644 index 000000000000..c35d63273aa7 --- /dev/null +++ b/tests/testsuite/cargo_test/no_keep_going/in/Cargo.toml @@ -0,0 +1,3 @@ +[package] +name = "foo" +version = "0.1.0" diff --git a/tests/testsuite/cargo_test/no_keep_going/in/src/lib.rs b/tests/testsuite/cargo_test/no_keep_going/in/src/lib.rs new file mode 100644 index 000000000000..e69de29bb2d1 diff --git a/tests/testsuite/cargo_test/no_keep_going/mod.rs b/tests/testsuite/cargo_test/no_keep_going/mod.rs new file mode 100644 index 000000000000..fdec61642359 --- /dev/null +++ b/tests/testsuite/cargo_test/no_keep_going/mod.rs @@ -0,0 +1,19 @@ +use cargo_test_support::curr_dir; +use cargo_test_support::CargoCommand; +use cargo_test_support::Project; + +#[cargo_test] +fn case() { + let project = Project::from_template(curr_dir!().join("in")); + let project_root = project.root(); + let cwd = &project_root; + + snapbox::cmd::Command::cargo_ui() + .arg("test") + .arg("--keep-going") + .current_dir(cwd) + .assert() + .code(1) + .stdout_matches_path(curr_dir!().join("stdout.log")) + .stderr_matches_path(curr_dir!().join("stderr.log")); +} diff --git a/tests/testsuite/cargo_test/no_keep_going/stderr.log b/tests/testsuite/cargo_test/no_keep_going/stderr.log new file mode 100644 index 000000000000..5772505b6741 --- /dev/null +++ b/tests/testsuite/cargo_test/no_keep_going/stderr.log @@ -0,0 +1,7 @@ +error: unexpected argument '--keep-going' found + + tip: use `--no-fail-fast` to run as many tests as possible regardless of failure + +Usage: cargo test [OPTIONS] [TESTNAME] [-- [args]...] + +For more information, try '--help'. diff --git a/tests/testsuite/cargo_test/no_keep_going/stdout.log b/tests/testsuite/cargo_test/no_keep_going/stdout.log new file mode 100644 index 000000000000..e69de29bb2d1 diff --git a/tests/testsuite/test.rs b/tests/testsuite/test.rs index 758bfe09c582..5f6528109bee 100644 --- a/tests/testsuite/test.rs +++ b/tests/testsuite/test.rs @@ -4844,29 +4844,6 @@ error: 2 targets failed: .run(); } -#[cargo_test] -fn cargo_test_no_keep_going() { - let p = project() - .file("Cargo.toml", &basic_bin_manifest("foo")) - .file("src/main.rs", "") - .build(); - - p.cargo("test --keep-going") - .with_stderr( - "\ -error: unexpected argument '--keep-going' found - - tip: use `--no-fail-fast` to run as many tests as possible regardless of failure - -Usage: cargo test [OPTIONS] [TESTNAME] [-- [args]...] - -For more information, try '--help'. -", - ) - .with_status(1) - .run(); -} - #[cargo_test] fn cargo_test_print_env_verbose() { let p = project()