2023-08-21 08:49:27 +00:00
|
|
|
// This file is part of the uutils coreutils package.
|
|
|
|
//
|
|
|
|
// For the full copyright and license information, please view the LICENSE
|
|
|
|
// file that was distributed with this source code.
|
2023-03-20 13:51:19 +00:00
|
|
|
use crate::common::util::TestScenario;
|
2020-05-05 21:15:50 +00:00
|
|
|
|
2022-09-10 16:38:14 +00:00
|
|
|
#[test]
|
|
|
|
fn test_invalid_arg() {
|
|
|
|
new_ucmd!().arg("--definitely-invalid").fails().code_is(1);
|
|
|
|
}
|
|
|
|
|
2024-11-14 21:04:17 +00:00
|
|
|
#[test]
|
|
|
|
fn test_invalid_input() {
|
|
|
|
new_ucmd!().arg(".").fails().code_is(1);
|
|
|
|
}
|
|
|
|
|
2020-05-05 21:15:50 +00:00
|
|
|
#[test]
|
|
|
|
fn test_fmt() {
|
2023-04-20 13:22:26 +00:00
|
|
|
new_ucmd!()
|
|
|
|
.arg("one-word-per-line.txt")
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is("this is a file with one word per line\n");
|
2020-05-05 21:15:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2023-04-20 13:22:26 +00:00
|
|
|
fn test_fmt_quick() {
|
2024-05-04 23:38:07 +00:00
|
|
|
for param in ["-q", "--quick", "-qq"] {
|
2023-04-20 13:22:26 +00:00
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", param])
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is("this is a file with one word per line\n");
|
|
|
|
}
|
2020-05-05 21:15:50 +00:00
|
|
|
}
|
|
|
|
|
2021-01-24 21:41:05 +00:00
|
|
|
#[test]
|
2023-04-20 13:22:26 +00:00
|
|
|
fn test_fmt_width() {
|
|
|
|
for param in ["-w", "--width"] {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", param, "10"])
|
|
|
|
.succeeds()
|
2024-03-19 05:23:45 +00:00
|
|
|
.stdout_is("this is a\nfile with\none word\nper line\n");
|
|
|
|
}
|
2024-05-04 23:38:07 +00:00
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", "-w50", "--width", "10"])
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is("this is a\nfile with\none word\nper line\n");
|
2024-03-19 05:23:45 +00:00
|
|
|
}
|
|
|
|
|
2024-05-05 15:50:08 +00:00
|
|
|
#[test]
|
|
|
|
fn test_fmt_width_invalid() {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", "-w", "apple"])
|
|
|
|
.fails()
|
|
|
|
.code_is(1)
|
|
|
|
.no_stdout()
|
|
|
|
.stderr_is("fmt: invalid width: 'apple'\n");
|
|
|
|
// an invalid width can be successfully overwritten later:
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", "-w", "apple", "-w10"])
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is("this is a\nfile with\none word\nper line\n");
|
|
|
|
}
|
|
|
|
|
2024-03-23 02:30:03 +00:00
|
|
|
#[test]
|
|
|
|
fn test_fmt_positional_width() {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["-10", "one-word-per-line.txt"])
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is("this is a\nfile with\none word\nper line\n");
|
|
|
|
}
|
|
|
|
|
2024-03-19 05:23:45 +00:00
|
|
|
#[test]
|
|
|
|
fn test_small_width() {
|
|
|
|
for width in ["0", "1", "2", "3"] {
|
|
|
|
for param in ["-w", "--width"] {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&[param, width, "one-word-per-line.txt"])
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is("this\nis\na\nfile\nwith\none\nword\nper\nline\n");
|
|
|
|
}
|
2023-04-20 13:22:26 +00:00
|
|
|
}
|
2021-01-24 21:41:05 +00:00
|
|
|
}
|
2023-04-20 13:22:26 +00:00
|
|
|
|
2021-05-05 21:12:17 +00:00
|
|
|
#[test]
|
2023-04-20 13:22:26 +00:00
|
|
|
fn test_fmt_width_too_big() {
|
|
|
|
for param in ["-w", "--width"] {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", param, "2501"])
|
|
|
|
.fails()
|
|
|
|
.code_is(1)
|
|
|
|
.stderr_is("fmt: invalid width: '2501': Numerical result out of range\n");
|
|
|
|
}
|
2024-05-04 23:38:07 +00:00
|
|
|
// However, as a temporary value it is okay:
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", "-w2501", "--width", "10"])
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is("this is a\nfile with\none word\nper line\n");
|
2020-05-05 21:15:50 +00:00
|
|
|
}
|
2023-08-14 13:44:55 +00:00
|
|
|
|
2023-09-28 08:50:56 +00:00
|
|
|
#[test]
|
|
|
|
fn test_fmt_invalid_width() {
|
|
|
|
for param in ["-w", "--width"] {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", param, "invalid"])
|
|
|
|
.fails()
|
|
|
|
.code_is(1)
|
2024-05-05 15:50:08 +00:00
|
|
|
.stderr_contains("invalid width: 'invalid'");
|
2023-09-28 08:50:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-23 02:30:03 +00:00
|
|
|
#[test]
|
|
|
|
fn test_fmt_positional_width_not_first() {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", "-10"])
|
|
|
|
.fails()
|
|
|
|
.code_is(1)
|
|
|
|
.stderr_contains("fmt: invalid option -- 1; -WIDTH is recognized only when it is the first\noption; use -w N instead");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_fmt_width_not_valid_number() {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["-25x", "one-word-per-line.txt"])
|
|
|
|
.fails()
|
|
|
|
.code_is(1)
|
|
|
|
.stderr_contains("fmt: invalid width: '25x'");
|
|
|
|
}
|
|
|
|
|
2024-05-04 23:38:07 +00:00
|
|
|
#[ignore = "our 'goal' algorithm is very different from GNU; fix this!"]
|
2023-08-14 13:44:55 +00:00
|
|
|
#[test]
|
|
|
|
fn test_fmt_goal() {
|
|
|
|
for param in ["-g", "--goal"] {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", param, "7"])
|
|
|
|
.succeeds()
|
2023-08-14 15:43:32 +00:00
|
|
|
.stdout_is("this is a\nfile with one\nword per line\n");
|
2023-08-14 13:44:55 +00:00
|
|
|
}
|
2024-05-04 23:38:07 +00:00
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", "-g40", "-g7"])
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is("this is a\nfile with one\nword per line\n");
|
2023-08-14 13:44:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_fmt_goal_too_big() {
|
|
|
|
for param in ["-g", "--goal"] {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", "--width=75", param, "76"])
|
|
|
|
.fails()
|
|
|
|
.code_is(1)
|
|
|
|
.stderr_is("fmt: GOAL cannot be greater than WIDTH.\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-20 09:26:11 +00:00
|
|
|
#[test]
|
|
|
|
fn test_fmt_goal_bigger_than_default_width_of_75() {
|
|
|
|
for param in ["-g", "--goal"] {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", param, "76"])
|
|
|
|
.fails()
|
|
|
|
.code_is(1)
|
|
|
|
.stderr_is("fmt: GOAL cannot be greater than WIDTH.\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-05-04 23:38:07 +00:00
|
|
|
#[ignore = "our 'goal' algorithm is very different from GNU; fix this!"]
|
|
|
|
#[test]
|
|
|
|
fn test_fmt_too_big_goal_sometimes_okay() {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", "--width=75", "-g76", "-g10"])
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is("this is a\nfile with one\nword per line\n");
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", "-g76", "-g10"])
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is("this is a\nfile with one\nword per line\n");
|
|
|
|
}
|
|
|
|
|
2024-05-05 10:47:52 +00:00
|
|
|
#[test]
|
|
|
|
fn test_fmt_goal_too_small_to_check_negative_minlength() {
|
|
|
|
for param in ["-g", "--goal"] {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", "--width=75", param, "10"])
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is("this is a file with one word per line\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-23 02:30:03 +00:00
|
|
|
#[test]
|
|
|
|
fn test_fmt_non_existent_file() {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["non-existing"])
|
|
|
|
.fails()
|
|
|
|
.code_is(1)
|
|
|
|
.stderr_is("fmt: cannot open 'non-existing' for reading: No such file or directory\n");
|
|
|
|
}
|
|
|
|
|
2023-09-28 08:50:56 +00:00
|
|
|
#[test]
|
|
|
|
fn test_fmt_invalid_goal() {
|
|
|
|
for param in ["-g", "--goal"] {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", param, "invalid"])
|
|
|
|
.fails()
|
|
|
|
.code_is(1)
|
2024-05-05 15:50:08 +00:00
|
|
|
// GNU complains about "invalid width", which is confusing.
|
|
|
|
// We intentionally deviate from GNU, and show a more helpful message:
|
|
|
|
.stderr_contains("invalid goal: 'invalid'");
|
2023-09-28 08:50:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-05-05 15:50:08 +00:00
|
|
|
#[test]
|
|
|
|
fn test_fmt_invalid_goal_override() {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", "-g", "apple", "-g", "74"])
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is("this is a file with one word per line\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_fmt_invalid_goal_width_priority() {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", "-g", "apple", "-w", "banana"])
|
|
|
|
.fails()
|
|
|
|
.code_is(1)
|
|
|
|
.no_stdout()
|
|
|
|
.stderr_is("fmt: invalid width: 'banana'\n");
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", "-w", "banana", "-g", "apple"])
|
|
|
|
.fails()
|
|
|
|
.code_is(1)
|
|
|
|
.no_stdout()
|
|
|
|
.stderr_is("fmt: invalid width: 'banana'\n");
|
|
|
|
}
|
|
|
|
|
2023-08-14 13:44:55 +00:00
|
|
|
#[test]
|
|
|
|
fn test_fmt_set_goal_not_contain_width() {
|
|
|
|
for param in ["-g", "--goal"] {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&["one-word-per-line.txt", param, "74"])
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is("this is a file with one word per line\n");
|
|
|
|
}
|
|
|
|
}
|
2024-05-05 02:56:12 +00:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn split_does_not_reflow() {
|
|
|
|
for arg in ["-s", "-ss", "--split-only"] {
|
|
|
|
new_ucmd!()
|
|
|
|
.arg("one-word-per-line.txt")
|
|
|
|
.arg(arg)
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is_fixture("one-word-per-line.txt");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn prefix_minus() {
|
|
|
|
for prefix_args in [
|
|
|
|
vec!["-p-"],
|
|
|
|
vec!["-p", "-"],
|
|
|
|
vec!["--prefix=-"],
|
|
|
|
vec!["--prefix", "-"],
|
|
|
|
vec!["--pref=-"],
|
|
|
|
vec!["--pref", "-"],
|
|
|
|
// Test self-overriding:
|
|
|
|
vec!["--prefix==", "--prefix=-"],
|
|
|
|
] {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&prefix_args)
|
|
|
|
.arg("prefixed-one-word-per-line.txt")
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is_fixture("prefixed-one-word-per-line_p-.txt");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn prefix_equal() {
|
|
|
|
for prefix_args in [
|
|
|
|
// FIXME: #6353 vec!["-p="],
|
|
|
|
vec!["-p", "="],
|
|
|
|
vec!["--prefix=="],
|
|
|
|
vec!["--prefix", "="],
|
|
|
|
vec!["--pref=="],
|
|
|
|
vec!["--pref", "="],
|
|
|
|
// Test self-overriding:
|
|
|
|
vec!["--prefix=-", "--prefix=="],
|
|
|
|
] {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&prefix_args)
|
|
|
|
.arg("prefixed-one-word-per-line.txt")
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is_fixture("prefixed-one-word-per-line_p=.txt");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn prefix_equal_skip_prefix_equal_two() {
|
|
|
|
for prefix_args in [
|
|
|
|
// FIXME: #6353 vec!["--prefix==", "-P=2"],
|
|
|
|
vec!["--prefix==", "-P", "=2"],
|
|
|
|
vec!["--prefix==", "--skip-prefix==2"],
|
|
|
|
vec!["--prefix==", "--skip-prefix", "=2"],
|
|
|
|
vec!["--prefix==", "--skip-pref==2"],
|
|
|
|
vec!["--prefix==", "--skip-pref", "=2"],
|
|
|
|
// Test self-overriding:
|
|
|
|
vec!["--prefix==", "--skip-pref", "asdf", "-P", "=2"],
|
|
|
|
] {
|
|
|
|
new_ucmd!()
|
|
|
|
.args(&prefix_args)
|
|
|
|
.arg("prefixed-one-word-per-line.txt")
|
|
|
|
.succeeds()
|
|
|
|
.stdout_is_fixture("prefixed-one-word-per-line_p=_P=2.txt");
|
|
|
|
}
|
|
|
|
}
|