Skip to content

Commit

Permalink
refactor: remove expects in nested test file detection
Browse files Browse the repository at this point in the history
  • Loading branch information
calebcartwright committed Oct 23, 2019
1 parent 1eb1446 commit 55d583f
Showing 1 changed file with 27 additions and 24 deletions.
51 changes: 27 additions & 24 deletions src/cargo-fmt/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -270,10 +270,7 @@ impl Target {
) -> Self {
let path = PathBuf::from(&target.src_path);
let canonicalized = fs::canonicalize(&path).unwrap_or(path);
let test_files = match nested_int_test_files {
Some(files) => files,
None => vec![],
};
let test_files = nested_int_test_files.unwrap_or(vec![]);

Target {
path: canonicalized,
Expand Down Expand Up @@ -524,7 +521,7 @@ fn add_targets(
Some(package_dir) => {
let target_dir = package_dir.join("tests");
test_files_added = true;
Some(get_nested_integration_test_files(&target_dir, &target_dir))
get_nested_integration_test_files(&target_dir, &target_dir)
}
}
} else {
Expand All @@ -537,27 +534,33 @@ fn add_targets(
// Returns a `Vec` containing `PathBuf`s of nested .rs files within subdirectories
// of the `tests` directory for a given package.
// https://github.com/rust-lang/rustfmt/issues/1820
fn get_nested_integration_test_files(path: &Path, root_dir: &Path) -> Vec<PathBuf> {
fn get_nested_integration_test_files(path: &Path, root_dir: &Path) -> Option<Vec<PathBuf>> {
let mut files = vec![];
if path.is_dir() {
for entry in fs::read_dir(path).expect(&format!(
"couldn't read directory {}",
path.to_str().unwrap()
)) {
let entry = entry.expect("couldn't get nested `DirEntry` in tests");
let parent = path;
let entry_path = entry.path();
if entry_path.is_dir() {
files.append(&mut get_nested_integration_test_files(
&entry_path,
&root_dir,
));
} else if entry_path.extension().map_or(false, |f| f == "rs") && parent != root_dir {
files.push(entry_path);
if let Ok(dir) = fs::read_dir(path) {
for dir_entry in dir {
if let Ok(entry) = dir_entry {
let parent = path;
let entry_path = entry.path();
if entry_path.is_dir() {
files.append(
&mut get_nested_integration_test_files(&entry_path, &root_dir)
.unwrap_or(vec![]),
);
} else if entry_path.extension().map_or(false, |f| f == "rs")
&& parent != root_dir
{
files.push(entry_path);
}
} else {
return None;
}
}
} else {
return None;
}
}
files
Some(files)
}

fn run_rustfmt(
Expand Down Expand Up @@ -870,7 +873,7 @@ mod cargo_fmt_tests {
fn returns_no_files_if_root_not_dir() {
let target_dir = PathBuf::from("tests/nested-test-files/no-test-dir/Cargo.toml");
assert_eq!(
Vec::new() as Vec<PathBuf>,
Some(Vec::new() as Vec<PathBuf>),
get_nested_integration_test_files(&target_dir, &target_dir),
)
}
Expand All @@ -879,7 +882,7 @@ mod cargo_fmt_tests {
fn returns_no_files_if_tests_has_no_nested_files() {
let target_dir = Path::new("tests/nested-test-files/only-root-level-tests/tests");
assert_eq!(
Vec::new() as Vec<PathBuf>,
Some(Vec::new() as Vec<PathBuf>),
get_nested_integration_test_files(&target_dir, &target_dir),
)
}
Expand All @@ -897,7 +900,7 @@ mod cargo_fmt_tests {
"tests/nested-test-files/root-and-nested-tests/tests/nested/other.rs",
);
assert_eq!(
vec![exp_baz, exp_foo_bar, exp_other],
Some(vec![exp_baz, exp_foo_bar, exp_other]),
get_nested_integration_test_files(&target_dir, &target_dir),
)
}
Expand Down

0 comments on commit 55d583f

Please sign in to comment.