1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
use crate::process::exit_status::ExitStatus;
use crate::Exit;
fn format_exit_status(exit: &Result<ExitStatus, Exit>) -> String {
format!(
"Result({}, {})",
exit.as_ref()
.map_or_else(|_| String::from("None"), |e| { format!("{:?}", e) }),
exit.as_ref().map_or_else(
|e| { format!("Exit {{ Message({}), Status({:?}) }}", e.message, e.status) },
|_| String::from("None")
)
)
}
pub fn _assert_exit_status(actual: &Result<ExitStatus, Exit>, expected: &Result<ExitStatus, Exit>) {
if !match actual.as_ref() {
Ok(actual_exit_status) => {
if let Ok(expected_exit_status) = expected.as_ref() {
actual_exit_status == expected_exit_status
}
else {
false
}
},
Err(actual_exit) => {
if let Err(expected_exit) = expected.as_ref() {
actual_exit.status == expected_exit.status && actual_exit.message == expected_exit.message
}
else {
false
}
},
} {
panic!(vec![
"\n",
"Exit result does not match",
"==========",
"Expected:",
format_exit_status(expected).as_str(),
"Actual:",
format_exit_status(actual).as_str(),
"==========\n"
]
.join("\n"));
}
}
#[macro_export]
macro_rules! assert_exit_status {
($actual:expr, status = $status:expr) => {
crate::testutil::_assert_exit_status(&$actual, &Ok($status));
};
($actual:expr, message = $message:expr, status = $status:expr) => {
crate::testutil::_assert_exit_status(
&$actual,
&Err(Exit {
message: String::from($message),
status: $status,
}),
);
};
}
|