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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
#[macro_export]
macro_rules! assertable_command_stdout_contains_str {
($command:expr, $str:expr $(,)?) => ({
let output = $ command.output();
if output.is_err() {
Err(format!("assertable failed: `assertable_command_stdout_contains_str!(command, str)`\n command program: `{:?}`,\n str: `{:?}`,\n output: {:?}", $command.get_program(), $str, output))
} else {
let actual = String::from_utf8(output.unwrap().stdout).unwrap();
if actual.contains($str) {
Ok(())
} else {
Err(format!("assertable failed: `assertable_command_stdout_contains_str!(command, str)`\n command program: `{:?}`,\n str: `{:?}`,\n stdout: `{:?}`", $command.get_program(), $str, actual))
}
}
});
($command:expr, $str:expr, $($arg:tt)+) => ({
let output = $ command.output();
if output.is_err() {
Err($($arg)+)
} else {
let actual = String::from_utf8(output.unwrap().stdout).unwrap();
if actual.contains($str) {
Ok(())
} else {
Err($($arg)+)
}
}
});
}
#[cfg(test)]
mod tests {
use std::process::Command;
#[test]
fn asserterable_command_stdout_contains_str_x_arity_2_success() {
let mut a = Command::new("printf");
a.args(["%s", "alpha"]);
let str = "lph";
let x = assertable_command_stdout_contains_str!(a, str);
assert_eq!(x.unwrap(), ());
}
#[test]
fn asserterable_command_stdout_contains_str_x_arity_2_failure() {
let mut a = Command::new("printf");
a.args(["%s", "alpha"]);
let str = "xyz";
let x = assertable_command_stdout_contains_str!(a, str);
assert_eq!(x.unwrap_err(), "assertable failed: `assertable_command_stdout_contains_str!(command, str)`\n command program: `\"printf\"`,\n str: `\"xyz\"`,\n stdout: `\"alpha\"`");
}
#[test]
fn asserterable_command_stdout_contains_str_x_arity_3_success() {
let mut a = Command::new("printf");
a.args(["%s", "alpha"]);
let str = "lph";
let x = assertable_command_stdout_contains_str!(a, str, "message");
assert_eq!(x.unwrap(), ());
}
#[test]
fn asserterable_command_stdout_contains_str_x_arity_3_failure() {
let mut a = Command::new("printf");
a.args(["%s", "alpha"]);
let str = "xyz";
let x = assertable_command_stdout_contains_str!(a, str, "message");
assert_eq!(x.unwrap_err(), "message");
}
}