mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-27 12:25:05 +00:00
Add cargo file tidy test
This commit is contained in:
parent
85e1f0905a
commit
e73ffbf1e5
3 changed files with 50 additions and 14 deletions
|
@ -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
|
||||||
|
|
|
@ -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 {
|
|
||||||
entry.file_name().to_str().map(|s| s.starts_with('.')).unwrap_or(false)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn rust_files_in(path: &Path) -> impl Iterator<Item = PathBuf> {
|
||||||
|
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)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -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..")
|
||||||
|
|
Loading…
Reference in a new issue