2016-04-22 10:34:14 +02:00
|
|
|
extern crate compiletest_rs as compiletest;
|
|
|
|
|
2016-06-15 13:18:35 +02:00
|
|
|
use std::path::{PathBuf, Path};
|
|
|
|
use std::io::Write;
|
2016-04-22 10:34:14 +02:00
|
|
|
|
2016-06-15 13:18:35 +02:00
|
|
|
fn run_mode(dir: &'static str, mode: &'static str, sysroot: &str) {
|
2016-06-13 11:24:01 +02:00
|
|
|
// Disable rustc's new error fomatting. It breaks these tests.
|
|
|
|
std::env::remove_var("RUST_NEW_ERROR_FORMAT");
|
2016-06-14 11:54:28 +02:00
|
|
|
let flags = format!("--sysroot {} -Dwarnings", sysroot);
|
2016-06-15 13:18:35 +02:00
|
|
|
for_all_targets(sysroot, |target| {
|
2016-05-31 12:05:25 +02:00
|
|
|
let mut config = compiletest::default_config();
|
2016-06-14 11:54:28 +02:00
|
|
|
config.host_rustcflags = Some(flags.clone());
|
2016-06-13 11:24:01 +02:00
|
|
|
config.mode = mode.parse().expect("Invalid mode");
|
2016-06-15 13:18:35 +02:00
|
|
|
config.run_lib_path = Path::new(sysroot).join("lib").join("rustlib").join(&target).join("lib");
|
2016-05-31 12:05:25 +02:00
|
|
|
config.rustc_path = "target/debug/miri".into();
|
2016-06-15 13:18:35 +02:00
|
|
|
config.src_base = PathBuf::from(format!("tests/{}", dir));
|
2016-05-31 12:05:25 +02:00
|
|
|
config.target = target.to_owned();
|
2016-06-14 11:54:28 +02:00
|
|
|
config.target_rustcflags = Some(flags.clone());
|
2016-05-31 12:05:25 +02:00
|
|
|
compiletest::run_tests(&config);
|
2016-06-15 13:18:35 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
fn for_all_targets<F: Fn(String)>(sysroot: &str, f: F) {
|
|
|
|
for target in std::fs::read_dir(format!("{}/lib/rustlib/", sysroot)).unwrap() {
|
|
|
|
let target = target.unwrap();
|
|
|
|
if !target.metadata().unwrap().is_dir() {
|
|
|
|
continue;
|
|
|
|
}
|
2016-06-16 10:34:05 +02:00
|
|
|
let target = target.file_name().into_string().unwrap();
|
2016-06-15 13:18:35 +02:00
|
|
|
if target == "etc" {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
let stderr = std::io::stderr();
|
|
|
|
writeln!(stderr.lock(), "running tests for target {}", target).unwrap();
|
|
|
|
f(target);
|
2016-05-31 12:05:25 +02:00
|
|
|
}
|
2016-04-22 10:34:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn compile_test() {
|
2016-06-16 10:50:23 +02:00
|
|
|
let mut failed = false;
|
2016-06-15 13:18:35 +02:00
|
|
|
// Taken from https://github.com/Manishearth/rust-clippy/pull/911.
|
|
|
|
let home = option_env!("RUSTUP_HOME").or(option_env!("MULTIRUST_HOME"));
|
|
|
|
let toolchain = option_env!("RUSTUP_TOOLCHAIN").or(option_env!("MULTIRUST_TOOLCHAIN"));
|
|
|
|
let sysroot = match (home, toolchain) {
|
|
|
|
(Some(home), Some(toolchain)) => format!("{}/toolchains/{}", home, toolchain),
|
|
|
|
_ => option_env!("RUST_SYSROOT")
|
|
|
|
.expect("need to specify RUST_SYSROOT env var or use rustup or multirust")
|
|
|
|
.to_owned(),
|
|
|
|
};
|
|
|
|
run_mode("compile-fail", "compile-fail", &sysroot);
|
|
|
|
for_all_targets(&sysroot, |target| {
|
|
|
|
for file in std::fs::read_dir("tests/run-pass").unwrap() {
|
|
|
|
let file = file.unwrap();
|
|
|
|
if !file.metadata().unwrap().is_file() {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
let file = file.path();
|
|
|
|
let stderr = std::io::stderr();
|
2016-06-16 10:30:47 +02:00
|
|
|
write!(stderr.lock(), "test [miri-pass] {} ", file.to_str().unwrap()).unwrap();
|
2016-06-15 13:18:35 +02:00
|
|
|
let mut cmd = std::process::Command::new("target/debug/miri");
|
|
|
|
cmd.arg(file);
|
|
|
|
cmd.arg(format!("--sysroot={}", sysroot));
|
|
|
|
cmd.arg("-Dwarnings");
|
2016-06-16 10:30:47 +02:00
|
|
|
cmd.arg(format!("--target={}", target));
|
2016-06-16 10:52:23 +02:00
|
|
|
cmd.env("RUST_SYSROOT", sysroot);
|
2016-06-15 13:18:35 +02:00
|
|
|
let libs = Path::new(&sysroot).join("lib");
|
|
|
|
let sysroot = libs.join("rustlib").join(&target).join("lib");
|
|
|
|
let paths = std::env::join_paths(&[libs, sysroot]).unwrap();
|
|
|
|
cmd.env(compiletest::procsrv::dylib_env_var(), paths);
|
2016-06-16 10:30:47 +02:00
|
|
|
match cmd.output() {
|
|
|
|
Ok(ref output) if output.status.success() => writeln!(stderr.lock(), "ok").unwrap(),
|
|
|
|
Ok(output) => {
|
2016-06-16 10:50:23 +02:00
|
|
|
failed = true;
|
2016-06-16 10:30:47 +02:00
|
|
|
writeln!(stderr.lock(), "FAILED with exit code {}", output.status.code().unwrap_or(0)).unwrap();
|
|
|
|
writeln!(stderr.lock(), "stdout: \n {}", std::str::from_utf8(&output.stdout).unwrap()).unwrap();
|
|
|
|
writeln!(stderr.lock(), "stderr: \n {}", std::str::from_utf8(&output.stderr).unwrap()).unwrap();
|
|
|
|
}
|
2016-06-16 10:50:23 +02:00
|
|
|
Err(e) => {
|
|
|
|
failed = true;
|
|
|
|
writeln!(stderr.lock(), "FAILED: {}", e).unwrap();
|
|
|
|
},
|
2016-06-16 10:30:47 +02:00
|
|
|
}
|
2016-06-15 13:18:35 +02:00
|
|
|
}
|
|
|
|
let stderr = std::io::stderr();
|
|
|
|
writeln!(stderr.lock(), "").unwrap();
|
|
|
|
})
|
2016-06-16 10:50:23 +02:00
|
|
|
if failed {
|
|
|
|
panic!("some tests failed");
|
|
|
|
}
|
2016-04-22 10:34:14 +02:00
|
|
|
}
|