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(
&target,
&currentdir_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);
}
}
};
}

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());
});
}