2020-02-09 05:00:49 +00:00
|
|
|
// Dogfood cannot run on Windows
|
|
|
|
#![cfg(not(windows))]
|
2020-10-06 06:20:18 +00:00
|
|
|
#![feature(once_cell)]
|
2020-02-09 05:00:49 +00:00
|
|
|
|
2020-10-06 06:20:18 +00:00
|
|
|
use std::lazy::SyncLazy;
|
2020-02-01 17:00:48 +00:00
|
|
|
use std::path::PathBuf;
|
|
|
|
use std::process::Command;
|
|
|
|
|
|
|
|
mod cargo;
|
|
|
|
|
2020-10-06 06:20:18 +00:00
|
|
|
static CLIPPY_PATH: SyncLazy<PathBuf> = SyncLazy::new(|| cargo::TARGET_LIB.join("cargo-clippy"));
|
2020-02-01 17:00:48 +00:00
|
|
|
|
2017-12-15 09:02:39 +00:00
|
|
|
#[test]
|
2019-09-11 18:52:36 +00:00
|
|
|
fn dogfood_clippy() {
|
|
|
|
// run clippy on itself and fail the test if lint warnings are reported
|
2020-02-09 05:00:49 +00:00
|
|
|
if cargo::is_rustc_test_suite() {
|
2018-01-18 21:02:58 +00:00
|
|
|
return;
|
|
|
|
}
|
2020-02-01 17:00:48 +00:00
|
|
|
let root_dir = PathBuf::from(env!("CARGO_MANIFEST_DIR"));
|
2018-11-21 15:14:42 +00:00
|
|
|
|
2020-11-08 12:39:46 +00:00
|
|
|
let output = if cfg!(feature = "internal-lints") {
|
|
|
|
// with internal lints and internal warnings
|
|
|
|
Command::new(&*CLIPPY_PATH)
|
|
|
|
.current_dir(root_dir)
|
|
|
|
.env("CLIPPY_DOGFOOD", "1")
|
|
|
|
.env("CARGO_INCREMENTAL", "0")
|
|
|
|
.arg("clippy-preview")
|
|
|
|
.arg("--all-targets")
|
|
|
|
.arg("--all-features")
|
|
|
|
.args(&["--features", "internal-lints"])
|
|
|
|
.arg("--")
|
|
|
|
.args(&["-D", "clippy::all"])
|
|
|
|
.args(&["-D", "clippy::pedantic"])
|
|
|
|
.args(&["-D", "clippy::internal"])
|
|
|
|
.arg("-Cdebuginfo=0") // disable debuginfo to generate less data in the target dir
|
|
|
|
.output()
|
|
|
|
.unwrap()
|
|
|
|
} else {
|
|
|
|
// without internal lints or warnings
|
|
|
|
Command::new(&*CLIPPY_PATH)
|
|
|
|
.current_dir(root_dir)
|
|
|
|
.env("CLIPPY_DOGFOOD", "1")
|
|
|
|
.env("CARGO_INCREMENTAL", "0")
|
|
|
|
.arg("clippy-preview")
|
|
|
|
.arg("--all-targets")
|
|
|
|
.arg("--all-features")
|
|
|
|
.arg("--")
|
|
|
|
.args(&["-D", "clippy::all"])
|
|
|
|
.args(&["-D", "clippy::pedantic"])
|
|
|
|
.arg("-Cdebuginfo=0") // disable debuginfo to generate less data in the target dir
|
|
|
|
.output()
|
|
|
|
.unwrap()
|
|
|
|
};
|
2018-11-21 15:14:42 +00:00
|
|
|
println!("status: {}", output.status);
|
|
|
|
println!("stdout: {}", String::from_utf8_lossy(&output.stdout));
|
|
|
|
println!("stderr: {}", String::from_utf8_lossy(&output.stderr));
|
|
|
|
|
|
|
|
assert!(output.status.success());
|
|
|
|
}
|
|
|
|
|
2018-11-30 18:54:47 +00:00
|
|
|
#[test]
|
2019-09-11 18:52:36 +00:00
|
|
|
fn dogfood_subprojects() {
|
|
|
|
// run clippy on remaining subprojects and fail the test if lint warnings are reported
|
2020-02-09 05:00:49 +00:00
|
|
|
if cargo::is_rustc_test_suite() {
|
2018-11-21 15:14:42 +00:00
|
|
|
return;
|
|
|
|
}
|
2020-02-01 17:00:48 +00:00
|
|
|
let root_dir = PathBuf::from(env!("CARGO_MANIFEST_DIR"));
|
2018-11-21 15:14:42 +00:00
|
|
|
|
|
|
|
for d in &[
|
|
|
|
"clippy_workspace_tests",
|
|
|
|
"clippy_workspace_tests/src",
|
|
|
|
"clippy_workspace_tests/subcrate",
|
|
|
|
"clippy_workspace_tests/subcrate/src",
|
|
|
|
"clippy_dev",
|
|
|
|
"rustc_tools_util",
|
|
|
|
] {
|
2020-02-05 15:13:55 +00:00
|
|
|
let output = Command::new(&*CLIPPY_PATH)
|
2018-11-30 18:54:47 +00:00
|
|
|
.current_dir(root_dir.join(d))
|
2018-11-24 21:24:13 +00:00
|
|
|
.env("CLIPPY_DOGFOOD", "1")
|
2019-09-06 17:35:20 +00:00
|
|
|
.env("CARGO_INCREMENTAL", "0")
|
2018-11-21 15:14:42 +00:00
|
|
|
.arg("clippy")
|
|
|
|
.arg("--")
|
|
|
|
.args(&["-D", "clippy::all"])
|
|
|
|
.args(&["-D", "clippy::pedantic"])
|
2019-09-11 18:52:36 +00:00
|
|
|
.arg("-Cdebuginfo=0") // disable debuginfo to generate less data in the target dir
|
2018-03-15 15:08:49 +00:00
|
|
|
.output()
|
|
|
|
.unwrap();
|
2017-12-15 09:02:39 +00:00
|
|
|
println!("status: {}", output.status);
|
|
|
|
println!("stdout: {}", String::from_utf8_lossy(&output.stdout));
|
|
|
|
println!("stderr: {}", String::from_utf8_lossy(&output.stderr));
|
|
|
|
|
|
|
|
assert!(output.status.success());
|
|
|
|
}
|
|
|
|
}
|