2019-10-17 09:47:43 +03:00
|
|
|
//! Enums denoting options for test execution.
|
|
|
|
|
2019-10-17 19:10:35 +03:00
|
|
|
/// Number of times to run a benchmarked function
|
2019-10-17 09:47:43 +03:00
|
|
|
#[derive(Clone, PartialEq, Eq)]
|
|
|
|
pub enum BenchMode {
|
|
|
|
Auto,
|
|
|
|
Single,
|
|
|
|
}
|
|
|
|
|
2019-10-17 19:10:35 +03:00
|
|
|
/// Whether test is expected to panic or not
|
2019-10-17 09:47:43 +03:00
|
|
|
#[derive(Copy, Clone, Debug, PartialEq, Eq, Hash)]
|
|
|
|
pub enum ShouldPanic {
|
|
|
|
No,
|
|
|
|
Yes,
|
|
|
|
YesWithMessage(&'static str),
|
|
|
|
}
|
|
|
|
|
2019-10-17 19:10:35 +03:00
|
|
|
/// Whether should console output be colored or not
|
2019-10-17 09:47:43 +03:00
|
|
|
#[derive(Copy, Clone, Debug)]
|
|
|
|
pub enum ColorConfig {
|
|
|
|
AutoColor,
|
|
|
|
AlwaysColor,
|
|
|
|
NeverColor,
|
|
|
|
}
|
|
|
|
|
2019-10-17 19:10:35 +03:00
|
|
|
/// Format of the test results output
|
2019-10-17 09:47:43 +03:00
|
|
|
#[derive(Copy, Clone, Debug, PartialEq, Eq)]
|
|
|
|
pub enum OutputFormat {
|
2019-10-17 19:10:35 +03:00
|
|
|
/// Verbose output
|
2019-10-17 09:47:43 +03:00
|
|
|
Pretty,
|
2019-10-17 19:10:35 +03:00
|
|
|
/// Quiet output
|
2019-10-17 09:47:43 +03:00
|
|
|
Terse,
|
2019-10-17 19:10:35 +03:00
|
|
|
/// JSON output
|
2019-10-17 09:47:43 +03:00
|
|
|
Json,
|
2021-04-25 14:29:24 -07:00
|
|
|
/// JUnit output
|
|
|
|
Junit,
|
2019-10-17 09:47:43 +03:00
|
|
|
}
|
|
|
|
|
2020-03-06 12:13:55 +01:00
|
|
|
/// Whether ignored test should be run or not
|
2019-10-17 09:47:43 +03:00
|
|
|
#[derive(Copy, Clone, Debug, PartialEq, Eq)]
|
|
|
|
pub enum RunIgnored {
|
|
|
|
Yes,
|
|
|
|
No,
|
2019-10-17 19:10:35 +03:00
|
|
|
/// Run only ignored tests
|
2019-10-17 09:47:43 +03:00
|
|
|
Only,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Clone, Copy)]
|
|
|
|
pub enum RunStrategy {
|
|
|
|
/// Runs the test in the current process, and sends the result back over the
|
|
|
|
/// supplied channel.
|
|
|
|
InProcess,
|
|
|
|
|
|
|
|
/// Spawns a subprocess to run the test, and sends the result back over the
|
|
|
|
/// supplied channel. Requires `argv[0]` to exist and point to the binary
|
|
|
|
/// that's currently running.
|
|
|
|
SpawnPrimary,
|
|
|
|
}
|
|
|
|
|
2019-10-17 19:10:35 +03:00
|
|
|
/// Options for the test run defined by the caller (instead of CLI arguments).
|
2019-10-17 09:47:43 +03:00
|
|
|
/// In case we want to add other options as well, just add them in this struct.
|
|
|
|
#[derive(Copy, Clone, Debug)]
|
|
|
|
pub struct Options {
|
|
|
|
pub display_output: bool,
|
|
|
|
pub panic_abort: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Options {
|
|
|
|
pub fn new() -> Options {
|
2019-12-22 17:42:04 -05:00
|
|
|
Options { display_output: false, panic_abort: false }
|
2019-10-17 09:47:43 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn display_output(mut self, display_output: bool) -> Options {
|
|
|
|
self.display_output = display_output;
|
|
|
|
self
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn panic_abort(mut self, panic_abort: bool) -> Options {
|
|
|
|
self.panic_abort = panic_abort;
|
|
|
|
self
|
|
|
|
}
|
|
|
|
}
|