mirror of
https://github.com/uutils/coreutils
synced 2025-01-08 11:19:03 +00:00
982fb682e9
tests/tail: * test_stdin_redirect_file:. Test fails now when assert_alive()! The follow test `tail -f < file` where file's content is `foo` fails with: Assertion failed. Expected 'tail' to be running but exited with status=exit status: 0 I also tried on the command line and can confirm that tail isn't runnning when following by descriptor. The test is deactivated until the implementation is fixed. * test_follow_stdin_descriptor * test_follow_stdin_explicit_indefinitely. * test_follow_single * test_follow_non_utf8_bytes * test_follow_multiple * test_follow_name_multiple * test_follow_invalid_pid * test_single_big_args * test_retry3 * test_retry4 * test_retry5 * test_retry7 * test_retry8 * test_retry9 * test_follow_descriptor_vs_rename1 * test_follow_descriptor_vs_rename2 * test_follow_name_retry_headers * test_follow_name_remove * test_follow_name_truncate1 * test_follow_name_truncate2 * test_follow_name_truncate3 * test_follow_name_truncate4 * test_follow_truncate_fast * test_follow_name_move_create1 * test_follow_name_move_create2 * test_follow_name_move1 * test_follow_name_move2 * test_follow_name_move_retry1 * test_follow_name_move_retry2 * test_follow_inotify_only_regular * test_fifo * test_illegal_seek tests/cat: * test_dev_full * test_dev_full_show_all * test_dev_random * test_fifo_symlink tests/dd: * test_random_73k_test_lazy_fullblock * test_sync_delayed_reader tests/factor: * test_parallel tests/rm: * test_rm_force_prompts_order * test_rm_descend_directory * test_rm_prompts tests/seq: * the helper run method tests/sort: * test_sigpipe_panic tests/tee: * the helper run_tee method tests/tty: * test_tty module tests/yes: * the helper run method
743 lines
17 KiB
Rust
743 lines
17 KiB
Rust
// spell-checker:ignore lmnop xlmnop
|
||
use crate::common::util::*;
|
||
use std::process::Stdio;
|
||
|
||
#[test]
|
||
fn test_invalid_arg() {
|
||
new_ucmd!().arg("--definitely-invalid").fails().code_is(1);
|
||
}
|
||
|
||
#[test]
|
||
fn test_hex_rejects_sign_after_identifier() {
|
||
new_ucmd!()
|
||
.args(&["0x-123ABC"])
|
||
.fails()
|
||
.no_stdout()
|
||
.stderr_contains("invalid floating point argument: '0x-123ABC'")
|
||
.stderr_contains("for more information.");
|
||
new_ucmd!()
|
||
.args(&["0x+123ABC"])
|
||
.fails()
|
||
.no_stdout()
|
||
.stderr_contains("invalid floating point argument: '0x+123ABC'")
|
||
.stderr_contains("for more information.");
|
||
new_ucmd!()
|
||
.args(&["-0x-123ABC"])
|
||
.fails()
|
||
.no_stdout()
|
||
.stderr_contains("which wasn't expected, or isn't valid in this context")
|
||
.stderr_contains("For more information try '--help'");
|
||
new_ucmd!()
|
||
.args(&["-0x+123ABC"])
|
||
.fails()
|
||
.no_stdout()
|
||
.stderr_contains("which wasn't expected, or isn't valid in this context")
|
||
.stderr_contains("For more information try '--help'");
|
||
}
|
||
|
||
#[test]
|
||
fn test_hex_lowercase_uppercase() {
|
||
new_ucmd!()
|
||
.args(&["0xa", "0xA"])
|
||
.succeeds()
|
||
.stdout_is("10\n");
|
||
new_ucmd!()
|
||
.args(&["0Xa", "0XA"])
|
||
.succeeds()
|
||
.stdout_is("10\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_hex_big_number() {
|
||
new_ucmd!()
|
||
.args(&[
|
||
"0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF",
|
||
"0x100000000000000000000000000000000",
|
||
])
|
||
.succeeds()
|
||
.stdout_is(
|
||
"340282366920938463463374607431768211455\n340282366920938463463374607431768211456\n",
|
||
);
|
||
}
|
||
|
||
#[test]
|
||
fn test_hex_identifier_in_wrong_place() {
|
||
new_ucmd!()
|
||
.args(&["1234ABCD0x"])
|
||
.fails()
|
||
.no_stdout()
|
||
.stderr_contains("invalid floating point argument: '1234ABCD0x'")
|
||
.stderr_contains("for more information.");
|
||
}
|
||
|
||
#[test]
|
||
fn test_rejects_nan() {
|
||
new_ucmd!()
|
||
.arg("NaN")
|
||
.fails()
|
||
.usage_error("invalid 'not-a-number' argument: 'NaN'");
|
||
}
|
||
|
||
#[test]
|
||
fn test_rejects_non_floats() {
|
||
new_ucmd!()
|
||
.arg("foo")
|
||
.fails()
|
||
.usage_error("invalid floating point argument: 'foo'");
|
||
}
|
||
|
||
#[test]
|
||
fn test_accepts_option_argument_directly() {
|
||
new_ucmd!()
|
||
.arg("-s,")
|
||
.arg("2")
|
||
.succeeds()
|
||
.stdout_is("1,2\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_option_with_detected_negative_argument() {
|
||
new_ucmd!()
|
||
.arg("-s,")
|
||
.args(&["-1", "2"])
|
||
.succeeds()
|
||
.stdout_is("-1,0,1,2\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_negative_number_as_separator() {
|
||
new_ucmd!()
|
||
.arg("-s")
|
||
.args(&["-1", "2"])
|
||
.succeeds()
|
||
.stdout_is("1-12\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_invalid_float() {
|
||
new_ucmd!()
|
||
.args(&["1e2.3"])
|
||
.fails()
|
||
.no_stdout()
|
||
.stderr_contains("invalid floating point argument: '1e2.3'")
|
||
.stderr_contains("for more information.");
|
||
new_ucmd!()
|
||
.args(&["1e2.3", "2"])
|
||
.fails()
|
||
.no_stdout()
|
||
.stderr_contains("invalid floating point argument: '1e2.3'")
|
||
.stderr_contains("for more information.");
|
||
new_ucmd!()
|
||
.args(&["1", "1e2.3"])
|
||
.fails()
|
||
.no_stdout()
|
||
.stderr_contains("invalid floating point argument: '1e2.3'")
|
||
.stderr_contains("for more information.");
|
||
new_ucmd!()
|
||
.args(&["1e2.3", "2", "3"])
|
||
.fails()
|
||
.no_stdout()
|
||
.stderr_contains("invalid floating point argument: '1e2.3'")
|
||
.stderr_contains("for more information.");
|
||
new_ucmd!()
|
||
.args(&["1", "1e2.3", "3"])
|
||
.fails()
|
||
.no_stdout()
|
||
.stderr_contains("invalid floating point argument: '1e2.3'")
|
||
.stderr_contains("for more information.");
|
||
new_ucmd!()
|
||
.args(&["1", "2", "1e2.3"])
|
||
.fails()
|
||
.no_stdout()
|
||
.stderr_contains("invalid floating point argument: '1e2.3'")
|
||
.stderr_contains("for more information.");
|
||
}
|
||
|
||
#[test]
|
||
fn test_width_invalid_float() {
|
||
new_ucmd!()
|
||
.args(&["-w", "1e2.3"])
|
||
.fails()
|
||
.no_stdout()
|
||
.stderr_contains("invalid floating point argument: '1e2.3'")
|
||
.stderr_contains("for more information.");
|
||
}
|
||
|
||
// ---- Tests for the big integer based path ----
|
||
|
||
#[test]
|
||
fn test_count_up() {
|
||
new_ucmd!()
|
||
.args(&["10"])
|
||
.run()
|
||
.stdout_is("1\n2\n3\n4\n5\n6\n7\n8\n9\n10\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_count_down() {
|
||
new_ucmd!()
|
||
.args(&["--", "5", "-1", "1"])
|
||
.run()
|
||
.stdout_is("5\n4\n3\n2\n1\n");
|
||
new_ucmd!()
|
||
.args(&["5", "-1", "1"])
|
||
.run()
|
||
.stdout_is("5\n4\n3\n2\n1\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_separator_and_terminator() {
|
||
new_ucmd!()
|
||
.args(&["-s", ",", "-t", "!", "2", "6"])
|
||
.run()
|
||
.stdout_is("2,3,4,5,6!");
|
||
new_ucmd!()
|
||
.args(&["-s", ",", "2", "6"])
|
||
.run()
|
||
.stdout_is("2,3,4,5,6\n");
|
||
new_ucmd!()
|
||
.args(&["-s", "\n", "2", "6"])
|
||
.run()
|
||
.stdout_is("2\n3\n4\n5\n6\n");
|
||
new_ucmd!()
|
||
.args(&["-s", "\\n", "2", "6"])
|
||
.run()
|
||
.stdout_is("2\\n3\\n4\\n5\\n6\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_equalize_widths() {
|
||
new_ucmd!()
|
||
.args(&["-w", "5", "10"])
|
||
.run()
|
||
.stdout_is("05\n06\n07\n08\n09\n10\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_seq_wrong_arg() {
|
||
new_ucmd!().args(&["-w", "5", "10", "33", "32"]).fails();
|
||
}
|
||
|
||
#[test]
|
||
fn test_zero_step() {
|
||
new_ucmd!().args(&["10", "0", "32"]).fails();
|
||
}
|
||
|
||
#[test]
|
||
fn test_big_numbers() {
|
||
new_ucmd!()
|
||
.args(&[
|
||
"1000000000000000000000000000",
|
||
"1000000000000000000000000001",
|
||
])
|
||
.succeeds()
|
||
.stdout_only("1000000000000000000000000000\n1000000000000000000000000001\n");
|
||
}
|
||
|
||
// ---- Tests for the floating point based path ----
|
||
|
||
#[test]
|
||
fn test_count_up_floats() {
|
||
new_ucmd!()
|
||
.args(&["10.0"])
|
||
.run()
|
||
.stdout_is("1\n2\n3\n4\n5\n6\n7\n8\n9\n10\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_count_down_floats() {
|
||
new_ucmd!()
|
||
.args(&["--", "5", "-1.0", "1"])
|
||
.run()
|
||
.stdout_is("5.0\n4.0\n3.0\n2.0\n1.0\n");
|
||
new_ucmd!()
|
||
.args(&["5", "-1", "1.0"])
|
||
.run()
|
||
.stdout_is("5\n4\n3\n2\n1\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_separator_and_terminator_floats() {
|
||
new_ucmd!()
|
||
.args(&["-s", ",", "-t", "!", "2.0", "6"])
|
||
.run()
|
||
.stdout_is("2.0,3.0,4.0,5.0,6.0!");
|
||
}
|
||
|
||
#[test]
|
||
fn test_equalize_widths_floats() {
|
||
new_ucmd!()
|
||
.args(&["-w", "5", "10.0"])
|
||
.run()
|
||
.stdout_is("05\n06\n07\n08\n09\n10\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_seq_wrong_arg_floats() {
|
||
new_ucmd!().args(&["-w", "5", "10.0", "33", "32"]).fails();
|
||
}
|
||
|
||
#[test]
|
||
fn test_zero_step_floats() {
|
||
new_ucmd!().args(&["10.0", "0", "32"]).fails();
|
||
}
|
||
|
||
#[test]
|
||
fn test_preserve_negative_zero_start() {
|
||
new_ucmd!()
|
||
.args(&["-0", "1"])
|
||
.succeeds()
|
||
.stdout_is("-0\n1\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-0", "1", "2"])
|
||
.succeeds()
|
||
.stdout_is("-0\n1\n2\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-0", "1", "2.0"])
|
||
.succeeds()
|
||
.stdout_is("-0\n1\n2\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
#[test]
|
||
fn test_drop_negative_zero_end() {
|
||
new_ucmd!()
|
||
.args(&["1", "-1", "-0"])
|
||
.succeeds()
|
||
.stdout_is("1\n0\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
#[test]
|
||
fn test_width_scientific_notation() {
|
||
new_ucmd!()
|
||
.args(&["-w", "999", "1e3"])
|
||
.succeeds()
|
||
.stdout_is("0999\n1000\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
#[test]
|
||
fn test_width_negative_zero() {
|
||
new_ucmd!()
|
||
.args(&["-w", "-0", "1"])
|
||
.succeeds()
|
||
.stdout_is("-0\n01\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0", "1", "2"])
|
||
.succeeds()
|
||
.stdout_is("-0\n01\n02\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0", "1", "2.0"])
|
||
.succeeds()
|
||
.stdout_is("-0\n01\n02\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
#[test]
|
||
fn test_width_negative_zero_decimal_notation() {
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.0", "1"])
|
||
.succeeds()
|
||
.stdout_is("-0.0\n01.0\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.0", "1.0"])
|
||
.succeeds()
|
||
.stdout_is("-0.0\n01.0\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.0", "1", "2"])
|
||
.succeeds()
|
||
.stdout_is("-0.0\n01.0\n02.0\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.0", "1", "2.0"])
|
||
.succeeds()
|
||
.stdout_is("-0.0\n01.0\n02.0\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.0", "1.0", "2"])
|
||
.succeeds()
|
||
.stdout_is("-0.0\n01.0\n02.0\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.0", "1.0", "2.0"])
|
||
.succeeds()
|
||
.stdout_is("-0.0\n01.0\n02.0\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
#[test]
|
||
fn test_width_negative_zero_scientific_notation() {
|
||
new_ucmd!()
|
||
.args(&["-w", "-0e0", "1"])
|
||
.succeeds()
|
||
.stdout_is("-0\n01\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0e0", "1", "2"])
|
||
.succeeds()
|
||
.stdout_is("-0\n01\n02\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0e0", "1", "2.0"])
|
||
.succeeds()
|
||
.stdout_is("-0\n01\n02\n")
|
||
.no_stderr();
|
||
|
||
new_ucmd!()
|
||
.args(&["-w", "-0e+1", "1"])
|
||
.succeeds()
|
||
.stdout_is("-00\n001\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0e+1", "1", "2"])
|
||
.succeeds()
|
||
.stdout_is("-00\n001\n002\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0e+1", "1", "2.0"])
|
||
.succeeds()
|
||
.stdout_is("-00\n001\n002\n")
|
||
.no_stderr();
|
||
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.000e0", "1"])
|
||
.succeeds()
|
||
.stdout_is("-0.000\n01.000\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.000e0", "1", "2"])
|
||
.succeeds()
|
||
.stdout_is("-0.000\n01.000\n02.000\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.000e0", "1", "2.0"])
|
||
.succeeds()
|
||
.stdout_is("-0.000\n01.000\n02.000\n")
|
||
.no_stderr();
|
||
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.000e-2", "1"])
|
||
.succeeds()
|
||
.stdout_is("-0.00000\n01.00000\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.000e-2", "1", "2"])
|
||
.succeeds()
|
||
.stdout_is("-0.00000\n01.00000\n02.00000\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.000e-2", "1", "2.0"])
|
||
.succeeds()
|
||
.stdout_is("-0.00000\n01.00000\n02.00000\n")
|
||
.no_stderr();
|
||
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.000e5", "1"])
|
||
.succeeds()
|
||
.stdout_is("-000000\n0000001\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.000e5", "1", "2"])
|
||
.succeeds()
|
||
.stdout_is("-000000\n0000001\n0000002\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.000e5", "1", "2.0"])
|
||
.succeeds()
|
||
.stdout_is("-000000\n0000001\n0000002\n")
|
||
.no_stderr();
|
||
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.000e5", "1"])
|
||
.succeeds()
|
||
.stdout_is("-000000\n0000001\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.000e5", "1", "2"])
|
||
.succeeds()
|
||
.stdout_is("-000000\n0000001\n0000002\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.000e5", "1", "2.0"])
|
||
.succeeds()
|
||
.stdout_is("-000000\n0000001\n0000002\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
#[test]
|
||
fn test_width_decimal_scientific_notation_increment() {
|
||
new_ucmd!()
|
||
.args(&["-w", ".1", "1e-2", ".11"])
|
||
.succeeds()
|
||
.stdout_is("0.10\n0.11\n")
|
||
.no_stderr();
|
||
|
||
new_ucmd!()
|
||
.args(&["-w", ".0", "1.500e-1", ".2"])
|
||
.succeeds()
|
||
.stdout_is("0.0000\n0.1500\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
/// Test that trailing zeros in the start argument contribute to precision.
|
||
#[test]
|
||
fn test_width_decimal_scientific_notation_trailing_zeros_start() {
|
||
new_ucmd!()
|
||
.args(&["-w", ".1000", "1e-2", ".11"])
|
||
.succeeds()
|
||
.stdout_is("0.1000\n0.1100\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
/// Test that trailing zeros in the increment argument contribute to precision.
|
||
#[test]
|
||
fn test_width_decimal_scientific_notation_trailing_zeros_increment() {
|
||
new_ucmd!()
|
||
.args(&["-w", "1e-1", "0.0100", ".11"])
|
||
.succeeds()
|
||
.stdout_is("0.1000\n0.1100\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
#[test]
|
||
fn test_width_negative_decimal_notation() {
|
||
new_ucmd!()
|
||
.args(&["-w", "-.1", ".1", ".11"])
|
||
.succeeds()
|
||
.stdout_is("-0.1\n00.0\n00.1\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
#[test]
|
||
fn test_width_negative_scientific_notation() {
|
||
new_ucmd!()
|
||
.args(&["-w", "-1e-3", "1"])
|
||
.succeeds()
|
||
.stdout_is("-0.001\n00.999\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-1.e-3", "1"])
|
||
.succeeds()
|
||
.stdout_is("-0.001\n00.999\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-1.0e-4", "1"])
|
||
.succeeds()
|
||
.stdout_is("-0.00010\n00.99990\n")
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-.1e2", "10", "100"])
|
||
.succeeds()
|
||
.stdout_is(
|
||
"-010
|
||
0000
|
||
0010
|
||
0020
|
||
0030
|
||
0040
|
||
0050
|
||
0060
|
||
0070
|
||
0080
|
||
0090
|
||
0100
|
||
",
|
||
)
|
||
.no_stderr();
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.1e2", "10", "100"])
|
||
.succeeds()
|
||
.stdout_is(
|
||
"-010
|
||
0000
|
||
0010
|
||
0020
|
||
0030
|
||
0040
|
||
0050
|
||
0060
|
||
0070
|
||
0080
|
||
0090
|
||
0100
|
||
",
|
||
)
|
||
.no_stderr();
|
||
}
|
||
|
||
/// Test that trailing zeros in the end argument do not contribute to width.
|
||
#[test]
|
||
fn test_width_decimal_scientific_notation_trailing_zeros_end() {
|
||
new_ucmd!()
|
||
.args(&["-w", "1e-1", "1e-2", ".1100"])
|
||
.succeeds()
|
||
.stdout_is("0.10\n0.11\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
#[test]
|
||
fn test_width_floats() {
|
||
new_ucmd!()
|
||
.args(&["-w", "9.0", "10.0"])
|
||
.succeeds()
|
||
.stdout_is("09.0\n10.0\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
// TODO This is duplicated from `test_yes.rs`; refactor them.
|
||
/// Run `seq`, capture some of the output, close the pipe, and verify it.
|
||
fn run(args: &[&str], expected: &[u8]) {
|
||
let mut cmd = new_ucmd!();
|
||
let mut child = cmd.args(args).set_stdout(Stdio::piped()).run_no_wait();
|
||
let buf = child.stdout_exact_bytes(expected.len());
|
||
child.close_stdout();
|
||
child.wait().unwrap().success();
|
||
assert_eq!(buf.as_slice(), expected);
|
||
}
|
||
|
||
#[test]
|
||
fn test_neg_inf() {
|
||
run(&["--", "-inf", "0"], b"-inf\n-inf\n-inf\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_inf() {
|
||
run(&["inf"], b"1\n2\n3\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_inf_width() {
|
||
run(
|
||
&["-w", "1.000", "inf", "inf"],
|
||
b"1.000\n inf\n inf\n inf\n",
|
||
);
|
||
}
|
||
|
||
#[test]
|
||
fn test_neg_inf_width() {
|
||
run(
|
||
&["-w", "1.000", "-inf", "-inf"],
|
||
b"1.000\n -inf\n -inf\n -inf\n",
|
||
);
|
||
}
|
||
|
||
#[test]
|
||
fn test_ignore_leading_whitespace() {
|
||
new_ucmd!()
|
||
.arg(" 1")
|
||
.succeeds()
|
||
.stdout_is("1\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
#[test]
|
||
fn test_trailing_whitespace_error() {
|
||
// In some locales, the GNU error message has curly quotes (‘)
|
||
// instead of straight quotes ('). We just test the straight single
|
||
// quotes.
|
||
new_ucmd!()
|
||
.arg("1 ")
|
||
.fails()
|
||
.usage_error("invalid floating point argument: '1 '");
|
||
}
|
||
|
||
#[test]
|
||
fn test_negative_zero_int_start_float_increment() {
|
||
new_ucmd!()
|
||
.args(&["-0", "0.1", "0.1"])
|
||
.succeeds()
|
||
.stdout_is("-0.0\n0.1\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
#[test]
|
||
fn test_float_precision_increment() {
|
||
new_ucmd!()
|
||
.args(&["999", "0.1", "1000.1"])
|
||
.succeeds()
|
||
.stdout_is(
|
||
"999.0
|
||
999.1
|
||
999.2
|
||
999.3
|
||
999.4
|
||
999.5
|
||
999.6
|
||
999.7
|
||
999.8
|
||
999.9
|
||
1000.0
|
||
1000.1
|
||
",
|
||
)
|
||
.no_stderr();
|
||
}
|
||
|
||
/// Test for floating point precision issues.
|
||
#[test]
|
||
fn test_negative_increment_decimal() {
|
||
new_ucmd!()
|
||
.args(&["0.1", "-0.1", "-0.2"])
|
||
.succeeds()
|
||
.stdout_is("0.1\n0.0\n-0.1\n-0.2\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
#[test]
|
||
fn test_zero_not_first() {
|
||
new_ucmd!()
|
||
.args(&["-w", "-0.1", "0.1", "0.1"])
|
||
.succeeds()
|
||
.stdout_is("-0.1\n00.0\n00.1\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
#[test]
|
||
fn test_rounding_end() {
|
||
new_ucmd!()
|
||
.args(&["1", "-1", "0.1"])
|
||
.succeeds()
|
||
.stdout_is("1\n")
|
||
.no_stderr();
|
||
}
|
||
|
||
#[test]
|
||
fn test_parse_error_float() {
|
||
new_ucmd!()
|
||
.arg("lmnop")
|
||
.fails()
|
||
.usage_error("invalid floating point argument: 'lmnop'");
|
||
}
|
||
|
||
#[test]
|
||
fn test_parse_error_hex() {
|
||
new_ucmd!()
|
||
.arg("0xlmnop")
|
||
.fails()
|
||
.usage_error("invalid hexadecimal argument: '0xlmnop'");
|
||
}
|
||
|
||
#[test]
|
||
fn test_format_option() {
|
||
new_ucmd!()
|
||
.args(&["-f", "%.2f", "0.0", "0.1", "0.5"])
|
||
.succeeds()
|
||
.stdout_only("0.00\n0.10\n0.20\n0.30\n0.40\n0.50\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_invalid_zero_increment_value() {
|
||
new_ucmd!()
|
||
.args(&["0", "0", "1"])
|
||
.fails()
|
||
.no_stdout()
|
||
.stderr_contains("invalid Zero increment value: '0'")
|
||
.stderr_contains("for more information.");
|
||
}
|