2021-09-08 08:19:14 -05:00
|
|
|
#![cfg_attr(feature = "deny-warnings", deny(warnings))]
|
|
|
|
#![warn(rust_2018_idioms, unused_lifetimes)]
|
2019-01-23 11:49:02 +03:00
|
|
|
#![allow(clippy::assertions_on_constants)]
|
2021-10-24 22:19:59 +01:00
|
|
|
#![feature(path_file_prefix)]
|
2019-01-23 11:49:02 +03:00
|
|
|
|
2021-10-24 22:19:59 +01:00
|
|
|
use std::cmp::Ordering;
|
|
|
|
use std::ffi::OsStr;
|
2019-01-17 23:19:51 -05:00
|
|
|
use std::fs::{self, DirEntry};
|
|
|
|
use std::path::Path;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_missing_tests() {
|
2019-01-17 23:50:30 -05:00
|
|
|
let missing_files = explore_directory(Path::new("./tests"));
|
2019-01-18 00:12:35 -05:00
|
|
|
if !missing_files.is_empty() {
|
2019-01-17 23:50:30 -05:00
|
|
|
assert!(
|
|
|
|
false,
|
2021-02-02 20:24:42 +01:00
|
|
|
"Didn't see a test file for the following files:\n\n{}\n",
|
|
|
|
missing_files
|
|
|
|
.iter()
|
2022-09-23 13:55:30 -04:00
|
|
|
.map(|s| format!("\t{s}"))
|
2021-02-02 20:24:42 +01:00
|
|
|
.collect::<Vec<_>>()
|
|
|
|
.join("\n")
|
2019-01-17 23:50:30 -05:00
|
|
|
);
|
|
|
|
}
|
2019-01-17 23:19:51 -05:00
|
|
|
}
|
|
|
|
|
2021-10-24 22:19:59 +01:00
|
|
|
// Test for missing files.
|
2019-01-17 23:50:30 -05:00
|
|
|
fn explore_directory(dir: &Path) -> Vec<String> {
|
|
|
|
let mut missing_files: Vec<String> = Vec::new();
|
2019-01-17 23:19:51 -05:00
|
|
|
let mut current_file = String::new();
|
2019-01-17 23:50:30 -05:00
|
|
|
let mut files: Vec<DirEntry> = fs::read_dir(dir).unwrap().filter_map(Result::ok).collect();
|
2021-10-24 22:19:59 +01:00
|
|
|
files.sort_by(|x, y| {
|
|
|
|
match x.path().file_prefix().cmp(&y.path().file_prefix()) {
|
|
|
|
Ordering::Equal => (),
|
|
|
|
ord => return ord,
|
|
|
|
}
|
|
|
|
// Sort rs files before the others if they share the same prefix. So when we see
|
|
|
|
// the file prefix for the first time and it's not a rust file, it means the rust
|
|
|
|
// file has to be missing.
|
|
|
|
match (
|
|
|
|
x.path().extension().and_then(OsStr::to_str),
|
|
|
|
y.path().extension().and_then(OsStr::to_str),
|
|
|
|
) {
|
|
|
|
(Some("rs"), _) => Ordering::Less,
|
|
|
|
(_, Some("rs")) => Ordering::Greater,
|
|
|
|
_ => Ordering::Equal,
|
|
|
|
}
|
|
|
|
});
|
2019-01-18 00:12:35 -05:00
|
|
|
for entry in &files {
|
2019-01-17 23:19:51 -05:00
|
|
|
let path = entry.path();
|
|
|
|
if path.is_dir() {
|
2019-01-17 23:50:30 -05:00
|
|
|
missing_files.extend(explore_directory(&path));
|
2019-01-17 23:19:51 -05:00
|
|
|
} else {
|
2021-10-24 22:19:59 +01:00
|
|
|
let file_prefix = path.file_prefix().unwrap().to_str().unwrap().to_string();
|
2019-01-18 00:12:35 -05:00
|
|
|
if let Some(ext) = path.extension() {
|
|
|
|
match ext.to_str().unwrap() {
|
2021-10-24 22:19:59 +01:00
|
|
|
"rs" => current_file = file_prefix.clone(),
|
2019-01-18 00:12:35 -05:00
|
|
|
"stderr" | "stdout" => {
|
2021-10-24 22:19:59 +01:00
|
|
|
if file_prefix != current_file {
|
2019-01-18 00:12:35 -05:00
|
|
|
missing_files.push(path.to_str().unwrap().to_string());
|
|
|
|
}
|
|
|
|
},
|
|
|
|
_ => continue,
|
|
|
|
};
|
2019-01-17 23:19:51 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2019-01-17 23:50:30 -05:00
|
|
|
missing_files
|
2019-01-17 23:19:51 -05:00
|
|
|
}
|