Merge branch 'main' into main

This commit is contained in:
maxer137 2024-04-05 20:43:02 +00:00 committed by GitHub
commit 538f5ba6c2
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 43 additions and 19 deletions

View file

@ -53,7 +53,7 @@ that scripts can be easily transferred between platforms.
## Documentation ## Documentation
uutils has both user and developer documentation available: uutils has both user and developer documentation available:
- [User Manual](https://uutils.github.io/coreutils/book/) - [User Manual](https://uutils.github.io/coreutils/docs/)
- [Developer Documentation](https://docs.rs/crate/coreutils/) - [Developer Documentation](https://docs.rs/crate/coreutils/)
Both can also be generated locally, the instructions for that can be found in Both can also be generated locally, the instructions for that can be found in
@ -302,7 +302,7 @@ make PREFIX=/my/path uninstall
Below is the evolution of how many GNU tests uutils passes. A more detailed Below is the evolution of how many GNU tests uutils passes. A more detailed
breakdown of the GNU test results of the main branch can be found breakdown of the GNU test results of the main branch can be found
[in the user manual](https://uutils.github.io/coreutils/book/test_coverage.html). [in the user manual](https://uutils.github.io/coreutils/docs/test_coverage.html).
See <https://github.com/orgs/uutils/projects/1> for the main meta bugs See <https://github.com/orgs/uutils/projects/1> for the main meta bugs
(many are missing). (many are missing).

View file

@ -436,7 +436,10 @@ pub fn uu_app() -> Command {
.long(options::LENGTH) .long(options::LENGTH)
.value_parser(value_parser!(usize)) .value_parser(value_parser!(usize))
.short('l') .short('l')
.help("digest length in bits; must not exceed the max for the blake2 algorithm and must be a multiple of 8") .help(
"digest length in bits; must not exceed the max for the blake2 algorithm \
and must be a multiple of 8",
)
.action(ArgAction::Set), .action(ArgAction::Set),
) )
.arg( .arg(
@ -448,6 +451,7 @@ pub fn uu_app() -> Command {
.arg( .arg(
Arg::new(options::BASE64) Arg::new(options::BASE64)
.long(options::BASE64) .long(options::BASE64)
.short('b')
.help("emit a base64 digest, not hexadecimal") .help("emit a base64 digest, not hexadecimal")
.action(ArgAction::SetTrue) .action(ArgAction::SetTrue)
// Even though this could easily just override an earlier '--raw', // Even though this could easily just override an earlier '--raw',

View file

@ -379,8 +379,9 @@ fn test_base64_raw_conflicts() {
#[test] #[test]
fn test_base64_single_file() { fn test_base64_single_file() {
for algo in ALGOS { for algo in ALGOS {
for base64_option in ["--base64", "-b"] {
new_ucmd!() new_ucmd!()
.arg("--base64") .arg(base64_option)
.arg("lorem_ipsum.txt") .arg("lorem_ipsum.txt")
.arg(format!("--algorithm={algo}")) .arg(format!("--algorithm={algo}"))
.succeeds() .succeeds()
@ -388,6 +389,7 @@ fn test_base64_single_file() {
.stdout_is_fixture_bytes(format!("base64/{algo}_single_file.expected")); .stdout_is_fixture_bytes(format!("base64/{algo}_single_file.expected"));
} }
} }
}
#[test] #[test]
fn test_base64_multiple_files() { fn test_base64_multiple_files() {
new_ucmd!() new_ucmd!()

View file

@ -117,6 +117,17 @@ fn test_whitespace_with_char() {
.code_is(1); .code_is(1);
} }
#[test]
fn test_delimiter_with_byte_and_char() {
for conflicting_arg in ["-c", "-b"] {
new_ucmd!()
.args(&[conflicting_arg, COMPLEX_SEQUENCE.sequence, "-d="])
.fails()
.stderr_is("cut: invalid input: The '--delimiter' ('-d') option only usable if printing a sequence of fields\n")
.code_is(1);
}
}
#[test] #[test]
fn test_too_large() { fn test_too_large() {
new_ucmd!() new_ucmd!()
@ -289,6 +300,13 @@ fn test_multiple_mode_args() {
} }
} }
#[test]
fn test_no_argument() {
new_ucmd!().fails().stderr_is(
"cut: invalid usage: expects one of --fields (-f), --chars (-c) or --bytes (-b)\n",
);
}
#[test] #[test]
#[cfg(unix)] #[cfg(unix)]
fn test_8bit_non_utf8_delimiter() { fn test_8bit_non_utf8_delimiter() {