mirror of
https://github.com/RGBCube/uutils-coreutils
synced 2025-07-28 11:37:44 +00:00
Add tests for mktemp tmpdir flags
And set overrides_with for tmpdir flags. Tests were copied from #4275 Co-authored-by: David Matos <davidmatos06@gmail.com>
This commit is contained in:
parent
b77a08c134
commit
6262a3e9d9
2 changed files with 61 additions and 0 deletions
|
@ -428,6 +428,7 @@ pub fn uu_app() -> Command {
|
||||||
.num_args(0..=1)
|
.num_args(0..=1)
|
||||||
// Require an equals to avoid ambiguity if no tmpdir is supplied
|
// Require an equals to avoid ambiguity if no tmpdir is supplied
|
||||||
.require_equals(true)
|
.require_equals(true)
|
||||||
|
.overrides_with(OPT_P)
|
||||||
.value_parser(ValueParser::path_buf())
|
.value_parser(ValueParser::path_buf())
|
||||||
.value_hint(clap::ValueHint::DirPath),
|
.value_hint(clap::ValueHint::DirPath),
|
||||||
)
|
)
|
||||||
|
|
|
@ -901,3 +901,63 @@ fn test_t_ensure_tmpdir_has_higher_priority_than_p() {
|
||||||
println!("stdout = {stdout}");
|
println!("stdout = {stdout}");
|
||||||
assert!(stdout.contains(&pathname));
|
assert!(stdout.contains(&pathname));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_missing_xs_tmpdir_template() {
|
||||||
|
let scene = TestScenario::new(util_name!());
|
||||||
|
scene
|
||||||
|
.ucmd()
|
||||||
|
.arg("--tmpdir")
|
||||||
|
.arg(TEST_TEMPLATE3)
|
||||||
|
.fails()
|
||||||
|
.no_stdout()
|
||||||
|
.stderr_contains("too few X's in template");
|
||||||
|
scene
|
||||||
|
.ucmd()
|
||||||
|
.arg("--tmpdir=foobar")
|
||||||
|
.fails()
|
||||||
|
.no_stdout()
|
||||||
|
.stderr_contains("failed to create file via template");
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_both_tmpdir_flags_present() {
|
||||||
|
let scene = TestScenario::new(util_name!());
|
||||||
|
scene
|
||||||
|
.ucmd()
|
||||||
|
.arg("-p")
|
||||||
|
.arg(".")
|
||||||
|
.arg("--tmpdir")
|
||||||
|
.arg("foobarXXXX")
|
||||||
|
.succeeds()
|
||||||
|
.no_stderr()
|
||||||
|
.stdout_contains("/tmp/foobar");
|
||||||
|
scene
|
||||||
|
.ucmd()
|
||||||
|
.arg("-p")
|
||||||
|
.arg(".")
|
||||||
|
.arg("--tmpdir=foobarXXXX")
|
||||||
|
.fails()
|
||||||
|
.no_stdout()
|
||||||
|
.stderr_contains("failed to create file via template");
|
||||||
|
scene
|
||||||
|
.ucmd()
|
||||||
|
.arg("--tmpdir")
|
||||||
|
.arg("foobarXXXX")
|
||||||
|
.arg("-p")
|
||||||
|
.arg(".")
|
||||||
|
.succeeds()
|
||||||
|
.no_stderr()
|
||||||
|
.stdout_contains("./foobar");
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_missing_short_tmpdir_flag() {
|
||||||
|
let scene = TestScenario::new(util_name!());
|
||||||
|
scene
|
||||||
|
.ucmd()
|
||||||
|
.arg("-p")
|
||||||
|
.fails()
|
||||||
|
.no_stdout()
|
||||||
|
.stderr_contains("a value is required for '-p <DIR>' but none was supplied");
|
||||||
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue