From f740c0b03fbf2916c31044b5cec262835325d0c7 Mon Sep 17 00:00:00 2001 From: Alex Saveau Date: Wed, 26 Apr 2023 01:02:17 -0700 Subject: [PATCH] Support picking the last subtest by using a random big number (#970) --- tests/src/tests.rs | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/tests/src/tests.rs b/tests/src/tests.rs index cf89e1b2c..0e22084ce 100644 --- a/tests/src/tests.rs +++ b/tests/src/tests.rs @@ -45,7 +45,8 @@ struct Args { filter: Vec, /// runs only the specified subtest #[arg(short, long)] - subtest: Option, + #[arg(allow_hyphen_values = true)] + subtest: Option, #[arg(long)] exact: bool, #[arg(long, default_value_t = env::var_os("UPDATE_EXPECT").is_some())] @@ -368,6 +369,10 @@ fn test( let parts: Vec<_> = text.split("\n---").collect(); for (i, &part) in parts.iter().enumerate() { if let Some(x) = args.subtest { + let x = usize::try_from( + x.rem_euclid(isize::try_from(parts.len()).unwrap_or_default()), + ) + .unwrap(); if x != i { writeln!(output, " Skipped subtest {i}.").unwrap(); continue;