rm: fix for -d to match GNU's output #1769

This commit is contained in:
Jan Scheer 2021-03-18 14:46:56 +01:00
parent 99be7a3172
commit 58b9372dbe
2 changed files with 36 additions and 7 deletions

View file

@ -305,17 +305,29 @@ fn remove_dir(path: &Path, options: &Options) -> bool {
true
};
if response {
if let Ok(mut read_dir) = fs::read_dir(path) {
if options.dir && read_dir.next().is_none() {
match fs::remove_dir(path) {
Ok(_) => {
if options.verbose {
println!("removed '{}'", path.display());
println!("removed directory '{}'", path.display());
}
}
Err(e) => {
show_error!("removing '{}': {}", path.display(), e);
show_error!("cannot remove '{}': {}", path.display(), e);
return true;
}
}
} else {
// directory can be read but is not empty
show_error!("cannot remove '{}': Directory not empty", path.display());
return true;
}
} else {
// GNU's rm shows this message if directory is empty but not readable
show_error!("cannot remove '{}': Directory not empty", path.display());
return true;
}
}
false

View file

@ -115,6 +115,23 @@ fn test_rm_empty_directory() {
assert!(!at.dir_exists(dir));
}
#[test]
fn test_rm_non_empty_directory() {
let (at, mut ucmd) = at_and_ucmd!();
let dir = "test_rm_non_empty_dir";
let file_a = &format!("{}/test_rm_non_empty_file_a", dir);
at.mkdir(dir);
at.touch(file_a);
let result = ucmd.arg("-d").arg(dir).fails();
assert!(result
.stderr
.contains(&format!("cannot remove '{}': Directory not empty", dir)));
assert!(at.file_exists(file_a));
assert!(at.dir_exists(dir));
}
#[test]
fn test_rm_recursive() {
let (at, mut ucmd) = at_and_ucmd!();