mirror of
https://github.com/nushell/nushell
synced 2025-01-14 14:14:13 +00:00
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:
parent
859f7b3dc7
commit
25b62c2ac3
2 changed files with 20 additions and 8 deletions
|
@ -254,7 +254,6 @@ fn rm(
|
|||
});
|
||||
}
|
||||
|
||||
// let path = currentdir_path.join(target.item.as_ref());
|
||||
match nu_engine::glob_from(
|
||||
&target,
|
||||
¤tdir_path,
|
||||
|
@ -302,13 +301,11 @@ fn rm(
|
|||
}
|
||||
}
|
||||
Err(e) => {
|
||||
return Err(ShellError::GenericError {
|
||||
error: e.to_string(),
|
||||
msg: e.to_string(),
|
||||
span: Some(target.span),
|
||||
help: None,
|
||||
inner: vec![],
|
||||
})
|
||||
// glob_from may canonicalize path and return `DirectoryNotFound`
|
||||
// nushell should suppress the error if `--force` is used.
|
||||
if !(force && matches!(e, ShellError::DirectoryNotFound { .. })) {
|
||||
return Err(e);
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
|
|
|
@ -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());
|
||||
});
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue