diff --git a/src/uu/mktemp/src/mktemp.rs b/src/uu/mktemp/src/mktemp.rs index 78e36874ea6..6a848b7ad19 100644 --- a/src/uu/mktemp/src/mktemp.rs +++ b/src/uu/mktemp/src/mktemp.rs @@ -224,6 +224,11 @@ fn find_last_contiguous_block_of_xs(s: &str) -> Option<(usize, usize)> { impl Params { fn from(options: Options) -> Result { + // The template argument must end in 'X' if a suffix option is given. + if options.suffix.is_some() && !options.template.ends_with('X') { + return Err(MkTempError::MustEndInX(options.template)); + } + // Get the start and end indices of the randomized part of the template. // // For example, if the template is "abcXXXXyz", then `i` is 3 and `j` is 7. @@ -285,9 +290,6 @@ impl Params { if suffix.contains(MAIN_SEPARATOR) { return Err(MkTempError::SuffixContainsDirSeparator(suffix)); } - if !suffix_from_template.is_empty() && !suffix_from_option.is_empty() { - return Err(MkTempError::MustEndInX(options.template)); - } // The number of random characters in the template. // diff --git a/tests/by-util/test_mktemp.rs b/tests/by-util/test_mktemp.rs index df630e715a4..79ff9271d6a 100644 --- a/tests/by-util/test_mktemp.rs +++ b/tests/by-util/test_mktemp.rs @@ -619,3 +619,25 @@ fn test_three_contiguous_wildcard_blocks() { assert_matches_template!(template, filename); assert!(at.file_exists(filename)); } + +/// Test that template must end in X even if `--suffix` is the empty string. +#[test] +fn test_suffix_must_end_in_x() { + new_ucmd!() + .args(&["--suffix=", "aXXXb"]) + .fails() + .stderr_is("mktemp: with --suffix, template 'aXXXb' must end in X\n"); +} + +#[test] +fn test_suffix_empty_template() { + new_ucmd!() + .args(&["--suffix=aXXXb", ""]) + .fails() + .stderr_is("mktemp: with --suffix, template '' must end in X\n"); + + new_ucmd!() + .args(&["-d", "--suffix=aXXXb", ""]) + .fails() + .stderr_is("mktemp: with --suffix, template '' must end in X\n"); +}