Add cargo file tidy test

This commit is contained in:
Edwin Cheng 2021-02-03 22:01:09 +08:00
parent 85e1f0905a
commit e73ffbf1e5
3 changed files with 50 additions and 14 deletions

View file

@ -10,8 +10,8 @@ edition = "2018"
cargo-fuzz = true cargo-fuzz = true
[dependencies] [dependencies]
syntax = { path = ".." } syntax = { path = "..", version = "0.0.0" }
text_edit = { path = "../../text_edit" } text_edit = { path = "../../text_edit", version = "0.0.0" }
libfuzzer-sys = { git = "https://github.com/rust-fuzz/libfuzzer-sys.git" } libfuzzer-sys = { git = "https://github.com/rust-fuzz/libfuzzer-sys.git" }
# Prevent this from interfering with workspaces # Prevent this from interfering with workspaces

View file

@ -38,19 +38,13 @@ pub fn rust_files() -> impl Iterator<Item = PathBuf> {
rust_files_in(&project_root().join("crates")) rust_files_in(&project_root().join("crates"))
} }
pub fn rust_files_in(path: &Path) -> impl Iterator<Item = PathBuf> { pub fn cargo_files() -> impl Iterator<Item = PathBuf> {
let iter = WalkDir::new(path); files_in(&project_root(), "toml")
return iter .filter(|path| path.file_name().map(|it| it == "Cargo.toml").unwrap_or(false))
.into_iter() }
.filter_entry(|e| !is_hidden(e))
.map(|e| e.unwrap())
.filter(|e| !e.file_type().is_dir())
.map(|e| e.into_path())
.filter(|path| path.extension().map(|it| it == "rs").unwrap_or(false));
fn is_hidden(entry: &DirEntry) -> bool { pub fn rust_files_in(path: &Path) -> impl Iterator<Item = PathBuf> {
entry.file_name().to_str().map(|s| s.starts_with('.')).unwrap_or(false) files_in(path, "rs")
}
} }
pub fn run_rustfmt(mode: Mode) -> Result<()> { pub fn run_rustfmt(mode: Mode) -> Result<()> {
@ -120,3 +114,18 @@ fn date_iso() -> Result<String> {
fn is_release_tag(tag: &str) -> bool { fn is_release_tag(tag: &str) -> bool {
tag.len() == "2020-02-24".len() && tag.starts_with(|c: char| c.is_ascii_digit()) tag.len() == "2020-02-24".len() && tag.starts_with(|c: char| c.is_ascii_digit())
} }
fn files_in(path: &Path, ext: &'static str) -> impl Iterator<Item = PathBuf> {
let iter = WalkDir::new(path);
return iter
.into_iter()
.filter_entry(|e| !is_hidden(e))
.map(|e| e.unwrap())
.filter(|e| !e.file_type().is_dir())
.map(|e| e.into_path())
.filter(move |path| path.extension().map(|it| it == ext).unwrap_or(false));
fn is_hidden(entry: &DirEntry) -> bool {
entry.file_name().to_str().map(|s| s.starts_with('.')).unwrap_or(false)
}
}

View file

@ -5,6 +5,7 @@ use std::{
use xshell::{cmd, read_file}; use xshell::{cmd, read_file};
use xtask::{ use xtask::{
cargo_files,
codegen::{self, Mode}, codegen::{self, Mode},
project_root, run_rustfmt, rust_files, project_root, run_rustfmt, rust_files,
}; };
@ -93,6 +94,32 @@ fn rust_files_are_tidy() {
tidy_docs.finish(); tidy_docs.finish();
} }
#[test]
fn cargo_files_are_tidy() {
for cargo in cargo_files() {
let mut section = None;
for (line_no, text) in read_file(&cargo).unwrap().lines().enumerate() {
let text = text.trim();
if text.starts_with("[") {
section = Some(text);
continue;
}
if !section.map(|it| it.starts_with("[dependencies")).unwrap_or(false) {
continue;
}
let text: String = text.split_whitespace().collect();
if text.contains("path=") && !text.contains("version") {
panic!(
"\ncargo internal dependencies should have version.\n\
{}:{}\n",
cargo.display(),
line_no + 1
)
}
}
}
}
#[test] #[test]
fn check_merge_commits() { fn check_merge_commits() {
let stdout = cmd!("git rev-list --merges --invert-grep --author 'bors\\[bot\\]' HEAD~19..") let stdout = cmd!("git rev-list --merges --invert-grep --author 'bors\\[bot\\]' HEAD~19..")