mirror of
https://github.com/nushell/nushell
synced 2025-01-14 14:14:13 +00:00
Testing support tweaks: exit status in Outcome
(#10692)
This PR makes a couple of tweaks to the testing support crate: Add the `nu` invocation's exit status to the test output so that one can assert that nu exited with a successful code. This PR was split off of #10232.
This commit is contained in:
parent
2b5f1ee5b3
commit
a806717f35
2 changed files with 7 additions and 4 deletions
|
@ -3,12 +3,15 @@ pub mod fs;
|
||||||
pub mod locale_override;
|
pub mod locale_override;
|
||||||
pub mod macros;
|
pub mod macros;
|
||||||
pub mod playground;
|
pub mod playground;
|
||||||
|
use std::process::ExitStatus;
|
||||||
|
|
||||||
// Needs to be reexported for `nu!` macro
|
// Needs to be reexported for `nu!` macro
|
||||||
pub use nu_path;
|
pub use nu_path;
|
||||||
|
|
||||||
pub struct Outcome {
|
pub struct Outcome {
|
||||||
pub out: String,
|
pub out: String,
|
||||||
pub err: String,
|
pub err: String,
|
||||||
|
pub status: ExitStatus,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(windows)]
|
#[cfg(windows)]
|
||||||
|
@ -22,8 +25,8 @@ pub const NATIVE_PATH_ENV_SEPARATOR: char = ';';
|
||||||
pub const NATIVE_PATH_ENV_SEPARATOR: char = ':';
|
pub const NATIVE_PATH_ENV_SEPARATOR: char = ':';
|
||||||
|
|
||||||
impl Outcome {
|
impl Outcome {
|
||||||
pub fn new(out: String, err: String) -> Outcome {
|
pub fn new(out: String, err: String, status: ExitStatus) -> Outcome {
|
||||||
Outcome { out, err }
|
Outcome { out, err, status }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -279,7 +279,7 @@ pub fn nu_run_test(opts: NuOpts, commands: impl AsRef<str>, with_std: bool) -> O
|
||||||
|
|
||||||
println!("=== stderr\n{}", err);
|
println!("=== stderr\n{}", err);
|
||||||
|
|
||||||
Outcome::new(out, err.into_owned())
|
Outcome::new(out, err.into_owned(), output.status)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn nu_with_plugin_run_test(cwd: impl AsRef<Path>, plugins: &[&str], command: &str) -> Outcome {
|
pub fn nu_with_plugin_run_test(cwd: impl AsRef<Path>, plugins: &[&str], command: &str) -> Outcome {
|
||||||
|
@ -339,7 +339,7 @@ pub fn nu_with_plugin_run_test(cwd: impl AsRef<Path>, plugins: &[&str], command:
|
||||||
|
|
||||||
println!("=== stderr\n{}", err);
|
println!("=== stderr\n{}", err);
|
||||||
|
|
||||||
Outcome::new(out, err.into_owned())
|
Outcome::new(out, err.into_owned(), output.status)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn escape_quote_string(input: String) -> String {
|
fn escape_quote_string(input: String) -> String {
|
||||||
|
|
Loading…
Reference in a new issue