1
1
mirror of https://github.com/casey/just.git synced 2024-11-23 20:15:05 +03:00
just/src/integration.rs

217 lines
3.3 KiB
Rust
Raw Normal View History

2016-10-29 01:25:59 +03:00
extern crate tempdir;
extern crate brev;
use tempdir::TempDir;
2016-10-29 05:38:03 +03:00
use super::std::process::Command;
2016-10-29 01:25:59 +03:00
fn integration_test(
name: &str,
args: &[&str],
justfile: &str,
expected_status: i32,
expected_stdout: &str,
expected_stderr: &str,
) {
let tmp = TempDir::new(name)
.unwrap_or_else(|err| panic!("tmpdir: failed to create temporary directory: {}", err));
let mut path = tmp.path().to_path_buf();
path.push("justfile");
brev::dump(path, justfile);
2016-10-29 05:38:03 +03:00
let mut binary = super::std::env::current_dir().unwrap();
2016-10-29 01:25:59 +03:00
binary.push("./target/debug/j");
let output = Command::new(binary)
.current_dir(tmp.path())
.args(args)
.output()
.expect("j invocation failed");
let mut failure = false;
let status = output.status.code().unwrap();
if status != expected_status {
println!("bad status: {} != {}", status, expected_status);
failure = true;
}
2016-10-29 05:38:03 +03:00
let stdout = super::std::str::from_utf8(&output.stdout).unwrap();
2016-10-29 01:25:59 +03:00
if stdout != expected_stdout {
2016-10-29 05:38:03 +03:00
println!("bad stdout:\ngot:\n{}\n\nexpected:\n{}", stdout, expected_stdout);
2016-10-29 01:25:59 +03:00
failure = true;
}
2016-10-29 05:38:03 +03:00
let stderr = super::std::str::from_utf8(&output.stderr).unwrap();
2016-10-29 01:25:59 +03:00
if stderr != expected_stderr {
2016-10-29 05:38:03 +03:00
println!("bad stdout:\ngot:\n{}\n\nexpected:\n{}", stderr, expected_stderr);
2016-10-29 01:25:59 +03:00
failure = true;
}
if failure {
panic!("test failed");
}
}
#[test]
2016-10-29 01:59:50 +03:00
fn default() {
2016-10-29 01:25:59 +03:00
integration_test(
2016-10-29 01:59:50 +03:00
"default",
2016-10-29 01:25:59 +03:00
&[],
2016-10-29 01:59:50 +03:00
"default:\n echo hello\nother: \n echo bar",
2016-10-29 01:25:59 +03:00
0,
"hello\n",
"echo hello\n",
)
}
2016-10-29 01:34:01 +03:00
#[test]
fn quiet() {
integration_test(
"quiet",
&[],
"default:\n @echo hello",
0,
"hello\n",
"",
)
}
#[test]
fn order() {
let text = "
b: a
echo b
@mv a b
a:
echo a
@touch F
@touch a
d: c
echo d
@rm c
c: b
echo c
@mv b c";
integration_test(
"order",
&["a", "d"],
text,
0,
"a\nb\nc\nd\n",
"echo a\necho b\necho c\necho d\n",
);
}
2016-10-29 01:59:50 +03:00
#[test]
fn list() {
let text =
"b: a
a:
d: c
c: b";
integration_test(
"list",
&["--list"],
text,
0,
"a b c d\n",
"",
);
}
#[test]
fn select() {
let text =
"b:
@echo b
a:
@echo a
d:
@echo d
c:
@echo c";
integration_test(
"select",
&["d", "c"],
text,
0,
"d\nc\n",
"",
);
}
#[test]
fn show() {
let text =
r#"hello = "foo"
bar = hello + hello
recipe:
echo {{hello + "bar" + bar}}"#;
integration_test(
"show",
&["--show", "recipe"],
text,
0,
r#"recipe:
echo {{hello + "bar" + bar}}
"#,
"",
);
}
2016-10-29 01:59:50 +03:00
2016-10-29 05:38:03 +03:00
#[test]
fn debug() {
let text =
r#"hello = "foo"
bar = hello + hello
recipe:
echo {{hello + "bar" + bar}}"#;
integration_test(
"debug",
&["--debug"],
text,
0,
r#"bar = hello + hello # "foofoo"
hello = "foo" # "foo"
recipe:
echo {{hello + "bar" + bar # "foobarfoofoo"}}
"#,
"",
);
}
2016-10-29 01:59:50 +03:00
#[test]
fn status() {
let text =
"
recipe:
@function f { return 100; }; f";
integration_test(
"status",
&[],
text,
100,
"",
"Recipe \"recipe\" failed with exit code 100\n",
);
}
2016-10-29 06:34:25 +03:00
#[test]
fn error() {
integration_test(
"error",
&[],
"bar:\nhello:\nfoo: bar baaaaaaaz hello",
255,
"",
2016-10-29 06:40:16 +03:00
"error: recipe `foo` has unknown dependency `baaaaaaaz`
2016-10-29 06:34:25 +03:00
|
3 | foo: bar baaaaaaaz hello
| ^^^^^^^^^
",
);
}