-
Notifications
You must be signed in to change notification settings - Fork 1.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow using cargo nextest
for running tests
#13045
Changes from all commits
8373e94
ebb1cea
ff9dc06
fd15523
ef159e3
2bf9a5c
452ad3d
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -62,6 +62,15 @@ async fn run_tests() -> Result<()> { | |
env_logger::init(); | ||
|
||
let options: Options = clap::Parser::parse(); | ||
if options.list { | ||
// nextest parses stdout, so print messages to stderr | ||
eprintln!("NOTICE: --list option unsupported, quitting"); | ||
// return Ok, not error so that tools like nextest which are listing all | ||
// workspace tests (by running `cargo test ... --list --format terse`) | ||
// do not fail when they encounter this binary. Instead, print nothing | ||
// to stdout and return OK so they can continue listing other tests. | ||
return Ok(()); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. why Ok? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Because if it returns an error, What is happening I think is that So if the There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Added some comments in fd15523 |
||
} | ||
options.warn_on_ignored(); | ||
|
||
// Run all tests in parallel, reporting failures at the end | ||
|
@@ -276,7 +285,7 @@ fn read_dir_recursive_impl(dst: &mut Vec<PathBuf>, path: &Path) -> Result<()> { | |
|
||
/// Parsed command line options | ||
/// | ||
/// This structure attempts to mimic the command line options | ||
/// This structure attempts to mimic the command line options of the built in rust test runner | ||
/// accepted by IDEs such as CLion that pass arguments | ||
/// | ||
/// See <https://github.com/apache/datafusion/issues/8287> for more details | ||
|
@@ -320,6 +329,18 @@ struct Options { | |
help = "IGNORED (for compatibility with built in rust test runner)" | ||
)] | ||
show_output: bool, | ||
|
||
#[clap( | ||
long, | ||
help = "Quits immediately, not listing anything (for compatibility with built-in rust test runner)" | ||
)] | ||
list: bool, | ||
|
||
#[clap( | ||
long, | ||
help = "IGNORED (for compatibility with built-in rust test runner)" | ||
)] | ||
ignored: bool, | ||
} | ||
|
||
impl Options { | ||
|
@@ -354,15 +375,15 @@ impl Options { | |
/// Logs warning messages to stdout if any ignored options are passed | ||
fn warn_on_ignored(&self) { | ||
if self.format.is_some() { | ||
println!("WARNING: Ignoring `--format` compatibility option"); | ||
eprintln!("WARNING: Ignoring `--format` compatibility option"); | ||
} | ||
|
||
if self.z_options.is_some() { | ||
println!("WARNING: Ignoring `-Z` compatibility option"); | ||
eprintln!("WARNING: Ignoring `-Z` compatibility option"); | ||
} | ||
|
||
if self.show_output { | ||
println!("WARNING: Ignoring `--show-output` compatibility option"); | ||
eprintln!("WARNING: Ignoring `--show-output` compatibility option"); | ||
} | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
❤️
a very good explanation