blob: b0997216297c5d7217e612aae19f75ee19f3e83a (
plain)
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
|
use assert_cmd::prelude::OutputAssertExt; // Add methods on commands
use predicates::prelude::{predicate, PredicateBooleanExt}; // Used for writing assertions
#[cfg(unix)]
use std::os::unix::process::ExitStatusExt;
pub trait Success2 {
// Our own function with better reporting of errors
fn success2(self) -> Self;
}
#[cfg(unix)]
fn get_signal(status: std::process::ExitStatus) -> Option<i32> {
status.signal()
}
#[cfg(not(unix))]
fn get_signal(_status: std::process::ExitStatus) -> Option<i32> {
None
}
impl Success2 for assert_cmd::assert::Assert {
fn success2(self) -> Self {
if !self.get_output().status.success() {
let output = self.get_output();
let code = output.status.code();
println!("status: {}", output.status);
println!("stdout: {}", String::from_utf8_lossy(&output.stdout));
println!("stderr: {}", String::from_utf8_lossy(&output.stderr));
if cfg!(unix) {
if code.is_none() {
let signal = get_signal(output.status).unwrap();
panic!("INTERRUPTED with signal: {}", signal);
}
}
let actual_code = code.unwrap();
println!("code: {}", actual_code);
panic!("Non zero exit code");
}
self
}
}
fn fpm_bin() -> std::process::Command {
let mut fpm_bin_relative: std::path::PathBuf = ["target", "debug", "fpm"].iter().collect();
fpm_bin_relative.set_extension(std::env::consts::EXE_EXTENSION);
let fpm_bin_absolute = std::fs::canonicalize(fpm_bin_relative).unwrap();
std::process::Command::new(fpm_bin_absolute.to_str().unwrap())
}
#[test]
fn test_help() {
let mut cmd = fpm_bin();
cmd.arg("--help");
cmd.assert()
.success2()
.stdout(
predicate::str::contains("--help Prints help information"));
}
#[test]
fn test_1() {
let mut build = fpm_bin();
build.arg("build")
.arg("--target-dir")
.arg("build-test")
.current_dir("tests/1");
build.assert()
.success2()
.stdout(predicate::str::contains("Built target p1")
.and(predicate::str::contains("TEST1 OK").not()));
let mut run = fpm_bin();
run.arg("run")
.arg("--target-dir")
.arg("build-test")
.current_dir("tests/1");
run.assert()
.success2()
.stdout(predicate::str::contains("TEST1 OK"));
}
#[test]
fn test_2() {
let mut build = fpm_bin();
build.arg("build")
.arg("--target-dir")
.arg("build-test")
.current_dir("tests/2");
build.assert()
.success2()
.stdout(predicate::str::contains("Built target p1")
.and(predicate::str::contains("TEST2 OK").not()));
let mut run = fpm_bin();
run.arg("run")
.arg("--target-dir")
.arg("build-test")
.current_dir("tests/2");
run.assert()
.success2()
.stdout(predicate::str::contains("TEST2 OK"));
}
|