fix force rm: should suppress error if directory is not found (#11656)

# Description
Fix a breaking change which is introduced by #11621

`rm -f /tmp/aaa` shouldn't return error if `/tmp/aaa/` doesn't exist.

# User-Facing Changes
NaN

# Tests + Formatting
Done
This commit is contained in:
WindSoilder 2024-01-28 23:01:19 +08:00 committed by GitHub
parent 859f7b3dc7
commit 25b62c2ac3
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 20 additions and 8 deletions

View file

@ -254,7 +254,6 @@ fn rm(
}); });
} }
// let path = currentdir_path.join(target.item.as_ref());
match nu_engine::glob_from( match nu_engine::glob_from(
&target, &target,
&currentdir_path, &currentdir_path,
@ -302,13 +301,11 @@ fn rm(
} }
} }
Err(e) => { Err(e) => {
return Err(ShellError::GenericError { // glob_from may canonicalize path and return `DirectoryNotFound`
error: e.to_string(), // nushell should suppress the error if `--force` is used.
msg: e.to_string(), if !(force && matches!(e, ShellError::DirectoryNotFound { .. })) {
span: Some(target.span), return Err(e);
help: None, }
inner: vec![],
})
} }
}; };
} }

View file

@ -480,3 +480,18 @@ fn rm_files_inside_glob_metachars_dir() {
)); ));
}); });
} }
#[test]
fn force_rm_suppress_error() {
Playground::setup("force_rm_suppress_error", |dirs, sandbox| {
sandbox.with_files(vec![EmptyFile("test_file.txt")]);
// the second rm should suppress error.
let actual = nu!(
cwd: dirs.test(),
"rm test_file.txt; rm -f test_file.txt",
);
assert!(actual.err.is_empty());
});
}