mirror of
https://github.com/uutils/coreutils
synced 2024-11-16 09:48:03 +00:00
refactor tests (#1982)
This commit is contained in:
parent
0ea35f3fbc
commit
646c6cacbc
25 changed files with 373 additions and 521 deletions
|
@ -91,10 +91,15 @@ fn tac(filenames: Vec<String>, before: bool, _: bool, separator: &str) -> i32 {
|
||||||
} else {
|
} else {
|
||||||
let path = Path::new(filename);
|
let path = Path::new(filename);
|
||||||
if path.is_dir() || path.metadata().is_err() {
|
if path.is_dir() || path.metadata().is_err() {
|
||||||
show_error!(
|
if path.is_dir() {
|
||||||
"failed to open '{}' for reading: No such file or directory",
|
show_error!("dir: read error: Invalid argument");
|
||||||
filename
|
} else {
|
||||||
);
|
show_error!(
|
||||||
|
"failed to open '{}' for reading: No such file or directory",
|
||||||
|
filename
|
||||||
|
);
|
||||||
|
}
|
||||||
|
exit_code = 1;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
match File::open(path) {
|
match File::open(path) {
|
||||||
|
|
|
@ -47,7 +47,7 @@ fn run_single_test(test: &TestCase, at: AtPath, mut ucmd: UCommand) {
|
||||||
ucmd.arg(arg);
|
ucmd.arg(arg);
|
||||||
}
|
}
|
||||||
let r = ucmd.run();
|
let r = ucmd.run();
|
||||||
if !r.success {
|
if !r.succeeded() {
|
||||||
println!("{}", r.stderr_str());
|
println!("{}", r.stderr_str());
|
||||||
panic!("{:?}: failed", ucmd.raw);
|
panic!("{:?}: failed", ucmd.raw);
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,14 +4,11 @@ use crate::common::util::*;
|
||||||
fn test_missing_operand() {
|
fn test_missing_operand() {
|
||||||
let result = new_ucmd!().run();
|
let result = new_ucmd!().run();
|
||||||
|
|
||||||
assert_eq!(
|
assert!(result
|
||||||
true,
|
.stderr_str()
|
||||||
result
|
.starts_with("error: The following required arguments were not provided"));
|
||||||
.stderr
|
|
||||||
.starts_with("error: The following required arguments were not provided")
|
|
||||||
);
|
|
||||||
|
|
||||||
assert_eq!(true, result.stderr.contains("<newroot>"));
|
assert!(result.stderr_str().contains("<newroot>"));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -20,14 +17,11 @@ fn test_enter_chroot_fails() {
|
||||||
|
|
||||||
at.mkdir("jail");
|
at.mkdir("jail");
|
||||||
|
|
||||||
let result = ucmd.arg("jail").run();
|
let result = ucmd.arg("jail").fails();
|
||||||
|
|
||||||
assert_eq!(
|
assert!(result
|
||||||
true,
|
.stderr_str()
|
||||||
result.stderr.starts_with(
|
.starts_with("chroot: error: cannot chroot to jail: Operation not permitted (os error 1)"));
|
||||||
"chroot: error: cannot chroot to jail: Operation not permitted (os error 1)"
|
|
||||||
)
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -47,19 +41,18 @@ fn test_invalid_user_spec() {
|
||||||
|
|
||||||
at.mkdir("a");
|
at.mkdir("a");
|
||||||
|
|
||||||
let result = ucmd.arg("a").arg("--userspec=ARABA:").run();
|
let result = ucmd.arg("a").arg("--userspec=ARABA:").fails();
|
||||||
|
|
||||||
assert_eq!(
|
assert!(result
|
||||||
true,
|
.stderr_str()
|
||||||
result.stderr.starts_with("chroot: error: invalid userspec")
|
.starts_with("chroot: error: invalid userspec"));
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_preference_of_userspec() {
|
fn test_preference_of_userspec() {
|
||||||
let scene = TestScenario::new(util_name!());
|
let scene = TestScenario::new(util_name!());
|
||||||
let result = scene.cmd("whoami").run();
|
let result = scene.cmd("whoami").run();
|
||||||
if is_ci() && result.stderr.contains("No such user/group") {
|
if is_ci() && result.stderr_str().contains("No such user/group") {
|
||||||
// In the CI, some server are failing to return whoami.
|
// In the CI, some server are failing to return whoami.
|
||||||
// As seems to be a configuration issue, ignoring it
|
// As seems to be a configuration issue, ignoring it
|
||||||
return;
|
return;
|
||||||
|
@ -73,7 +66,7 @@ fn test_preference_of_userspec() {
|
||||||
println!("result.stdout = {}", result.stdout_str());
|
println!("result.stdout = {}", result.stdout_str());
|
||||||
println!("result.stderr = {}", result.stderr_str());
|
println!("result.stderr = {}", result.stderr_str());
|
||||||
|
|
||||||
if is_ci() && result.stderr.contains("cannot find name for user ID") {
|
if is_ci() && result.stderr_str().contains("cannot find name for user ID") {
|
||||||
// In the CI, some server are failing to return id.
|
// In the CI, some server are failing to return id.
|
||||||
// As seems to be a configuration issue, ignoring it
|
// As seems to be a configuration issue, ignoring it
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -42,13 +42,9 @@ static TEST_MOUNT_OTHER_FILESYSTEM_FILE: &str = "mount/DO_NOT_copy_me.txt";
|
||||||
fn test_cp_cp() {
|
fn test_cp_cp() {
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
// Invoke our binary to make the copy.
|
// Invoke our binary to make the copy.
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg(TEST_HELLO_WORLD_DEST)
|
.arg(TEST_HELLO_WORLD_DEST)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
// Check that the exit code represents a successful copy.
|
|
||||||
assert!(result.success);
|
|
||||||
|
|
||||||
// Check the content of the destination file that was copied.
|
// Check the content of the destination file that was copied.
|
||||||
assert_eq!(at.read(TEST_HELLO_WORLD_DEST), "Hello, World!\n");
|
assert_eq!(at.read(TEST_HELLO_WORLD_DEST), "Hello, World!\n");
|
||||||
|
@ -57,12 +53,9 @@ fn test_cp_cp() {
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_existing_target() {
|
fn test_cp_existing_target() {
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg(TEST_EXISTING_FILE)
|
.arg(TEST_EXISTING_FILE)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
|
|
||||||
// Check the content of the destination file
|
// Check the content of the destination file
|
||||||
assert_eq!(at.read(TEST_EXISTING_FILE), "Hello, World!\n");
|
assert_eq!(at.read(TEST_EXISTING_FILE), "Hello, World!\n");
|
||||||
|
@ -74,52 +67,41 @@ fn test_cp_existing_target() {
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_duplicate_files() {
|
fn test_cp_duplicate_files() {
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_COPY_TO_FOLDER)
|
.arg(TEST_COPY_TO_FOLDER)
|
||||||
.run();
|
.succeeds()
|
||||||
|
.stderr_contains("specified more than once");
|
||||||
assert!(result.success);
|
|
||||||
assert!(result.stderr.contains("specified more than once"));
|
|
||||||
assert_eq!(at.read(TEST_COPY_TO_FOLDER_FILE), "Hello, World!\n");
|
assert_eq!(at.read(TEST_COPY_TO_FOLDER_FILE), "Hello, World!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_multiple_files_target_is_file() {
|
fn test_cp_multiple_files_target_is_file() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!()
|
||||||
let result = ucmd
|
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_EXISTING_FILE)
|
.arg(TEST_EXISTING_FILE)
|
||||||
.run();
|
.fails()
|
||||||
|
.stderr_contains("not a directory");
|
||||||
assert!(!result.success);
|
|
||||||
assert!(result.stderr.contains("not a directory"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_directory_not_recursive() {
|
fn test_cp_directory_not_recursive() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!()
|
||||||
let result = ucmd
|
|
||||||
.arg(TEST_COPY_TO_FOLDER)
|
.arg(TEST_COPY_TO_FOLDER)
|
||||||
.arg(TEST_HELLO_WORLD_DEST)
|
.arg(TEST_HELLO_WORLD_DEST)
|
||||||
.run();
|
.fails()
|
||||||
|
.stderr_contains("omitting directory");
|
||||||
assert!(!result.success);
|
|
||||||
assert!(result.stderr.contains("omitting directory"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_multiple_files() {
|
fn test_cp_multiple_files() {
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
||||||
.arg(TEST_COPY_TO_FOLDER)
|
.arg(TEST_COPY_TO_FOLDER)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert_eq!(at.read(TEST_COPY_TO_FOLDER_FILE), "Hello, World!\n");
|
assert_eq!(at.read(TEST_COPY_TO_FOLDER_FILE), "Hello, World!\n");
|
||||||
assert_eq!(at.read(TEST_HOW_ARE_YOU_DEST), "How are you?\n");
|
assert_eq!(at.read(TEST_HOW_ARE_YOU_DEST), "How are you?\n");
|
||||||
}
|
}
|
||||||
|
@ -129,14 +111,11 @@ fn test_cp_multiple_files() {
|
||||||
#[cfg(not(macos))]
|
#[cfg(not(macos))]
|
||||||
fn test_cp_recurse() {
|
fn test_cp_recurse() {
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
|
ucmd.arg("-r")
|
||||||
let result = ucmd
|
|
||||||
.arg("-r")
|
|
||||||
.arg(TEST_COPY_FROM_FOLDER)
|
.arg(TEST_COPY_FROM_FOLDER)
|
||||||
.arg(TEST_COPY_TO_FOLDER_NEW)
|
.arg(TEST_COPY_TO_FOLDER_NEW)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
// Check the content of the destination file that was copied.
|
// Check the content of the destination file that was copied.
|
||||||
assert_eq!(at.read(TEST_COPY_TO_FOLDER_NEW_FILE), "Hello, World!\n");
|
assert_eq!(at.read(TEST_COPY_TO_FOLDER_NEW_FILE), "Hello, World!\n");
|
||||||
}
|
}
|
||||||
|
@ -144,14 +123,10 @@ fn test_cp_recurse() {
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_with_dirs_t() {
|
fn test_cp_with_dirs_t() {
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
|
ucmd.arg("-t")
|
||||||
//using -t option
|
|
||||||
let result_to_dir_t = ucmd
|
|
||||||
.arg("-t")
|
|
||||||
.arg(TEST_COPY_TO_FOLDER)
|
.arg(TEST_COPY_TO_FOLDER)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.run();
|
.succeeds();
|
||||||
assert!(result_to_dir_t.success);
|
|
||||||
assert_eq!(at.read(TEST_COPY_TO_FOLDER_FILE), "Hello, World!\n");
|
assert_eq!(at.read(TEST_COPY_TO_FOLDER_FILE), "Hello, World!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -162,63 +137,52 @@ fn test_cp_with_dirs() {
|
||||||
let scene = TestScenario::new(util_name!());
|
let scene = TestScenario::new(util_name!());
|
||||||
let at = &scene.fixtures;
|
let at = &scene.fixtures;
|
||||||
|
|
||||||
//using -t option
|
scene
|
||||||
let result_to_dir = scene
|
|
||||||
.ucmd()
|
.ucmd()
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_COPY_TO_FOLDER)
|
.arg(TEST_COPY_TO_FOLDER)
|
||||||
.run();
|
.succeeds();
|
||||||
assert!(result_to_dir.success);
|
|
||||||
assert_eq!(at.read(TEST_COPY_TO_FOLDER_FILE), "Hello, World!\n");
|
assert_eq!(at.read(TEST_COPY_TO_FOLDER_FILE), "Hello, World!\n");
|
||||||
|
|
||||||
let result_from_dir = scene
|
scene
|
||||||
.ucmd()
|
.ucmd()
|
||||||
.arg(TEST_COPY_FROM_FOLDER_FILE)
|
.arg(TEST_COPY_FROM_FOLDER_FILE)
|
||||||
.arg(TEST_HELLO_WORLD_DEST)
|
.arg(TEST_HELLO_WORLD_DEST)
|
||||||
.run();
|
.succeeds();
|
||||||
assert!(result_from_dir.success);
|
|
||||||
assert_eq!(at.read(TEST_HELLO_WORLD_DEST), "Hello, World!\n");
|
assert_eq!(at.read(TEST_HELLO_WORLD_DEST), "Hello, World!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_arg_target_directory() {
|
fn test_cp_arg_target_directory() {
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg("-t")
|
.arg("-t")
|
||||||
.arg(TEST_COPY_TO_FOLDER)
|
.arg(TEST_COPY_TO_FOLDER)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert_eq!(at.read(TEST_COPY_TO_FOLDER_FILE), "Hello, World!\n");
|
assert_eq!(at.read(TEST_COPY_TO_FOLDER_FILE), "Hello, World!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_arg_no_target_directory() {
|
fn test_cp_arg_no_target_directory() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!()
|
||||||
let result = ucmd
|
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg("-v")
|
.arg("-v")
|
||||||
.arg("-T")
|
.arg("-T")
|
||||||
.arg(TEST_COPY_TO_FOLDER)
|
.arg(TEST_COPY_TO_FOLDER)
|
||||||
.run();
|
.fails()
|
||||||
|
.stderr_contains("cannot overwrite directory");
|
||||||
assert!(!result.success);
|
|
||||||
assert!(result.stderr.contains("cannot overwrite directory"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_arg_interactive() {
|
fn test_cp_arg_interactive() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!()
|
||||||
let result = ucmd
|
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
||||||
.arg("-i")
|
.arg("-i")
|
||||||
.pipe_in("N\n")
|
.pipe_in("N\n")
|
||||||
.run();
|
.succeeds()
|
||||||
|
.stderr_contains("Not overwriting");
|
||||||
assert!(result.success);
|
|
||||||
assert!(result.stderr.contains("Not overwriting"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -227,39 +191,33 @@ fn test_cp_arg_link() {
|
||||||
use std::os::linux::fs::MetadataExt;
|
use std::os::linux::fs::MetadataExt;
|
||||||
|
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg("--link")
|
.arg("--link")
|
||||||
.arg(TEST_HELLO_WORLD_DEST)
|
.arg(TEST_HELLO_WORLD_DEST)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert_eq!(at.metadata(TEST_HELLO_WORLD_SOURCE).st_nlink(), 2);
|
assert_eq!(at.metadata(TEST_HELLO_WORLD_SOURCE).st_nlink(), 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_arg_symlink() {
|
fn test_cp_arg_symlink() {
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg("--symbolic-link")
|
.arg("--symbolic-link")
|
||||||
.arg(TEST_HELLO_WORLD_DEST)
|
.arg(TEST_HELLO_WORLD_DEST)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert!(at.is_symlink(TEST_HELLO_WORLD_DEST));
|
assert!(at.is_symlink(TEST_HELLO_WORLD_DEST));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_arg_no_clobber() {
|
fn test_cp_arg_no_clobber() {
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg("--no-clobber")
|
.arg("--no-clobber")
|
||||||
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert_eq!(at.read(TEST_HOW_ARE_YOU_SOURCE), "How are you?\n");
|
assert_eq!(at.read(TEST_HOW_ARE_YOU_SOURCE), "How are you?\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -267,34 +225,31 @@ fn test_cp_arg_no_clobber() {
|
||||||
fn test_cp_arg_no_clobber_twice() {
|
fn test_cp_arg_no_clobber_twice() {
|
||||||
let scene = TestScenario::new(util_name!());
|
let scene = TestScenario::new(util_name!());
|
||||||
let at = &scene.fixtures;
|
let at = &scene.fixtures;
|
||||||
|
|
||||||
at.touch("source.txt");
|
at.touch("source.txt");
|
||||||
let result = scene
|
scene
|
||||||
.ucmd()
|
.ucmd()
|
||||||
.arg("--no-clobber")
|
.arg("--no-clobber")
|
||||||
.arg("source.txt")
|
.arg("source.txt")
|
||||||
.arg("dest.txt")
|
.arg("dest.txt")
|
||||||
.run();
|
.succeeds()
|
||||||
|
.no_stderr();
|
||||||
|
|
||||||
println!("stderr = {:?}", result.stderr_str());
|
|
||||||
println!("stdout = {:?}", result.stdout_str());
|
|
||||||
assert!(result.success);
|
|
||||||
assert!(result.stderr.is_empty());
|
|
||||||
assert_eq!(at.read("source.txt"), "");
|
assert_eq!(at.read("source.txt"), "");
|
||||||
|
|
||||||
at.append("source.txt", "some-content");
|
at.append("source.txt", "some-content");
|
||||||
let result = scene
|
scene
|
||||||
.ucmd()
|
.ucmd()
|
||||||
.arg("--no-clobber")
|
.arg("--no-clobber")
|
||||||
.arg("source.txt")
|
.arg("source.txt")
|
||||||
.arg("dest.txt")
|
.arg("dest.txt")
|
||||||
.run();
|
.succeeds()
|
||||||
|
.stdout_does_not_contain("Not overwriting");
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert_eq!(at.read("source.txt"), "some-content");
|
assert_eq!(at.read("source.txt"), "some-content");
|
||||||
// Should be empty as the "no-clobber" should keep
|
// Should be empty as the "no-clobber" should keep
|
||||||
// the previous version
|
// the previous version
|
||||||
assert_eq!(at.read("dest.txt"), "");
|
assert_eq!(at.read("dest.txt"), "");
|
||||||
assert!(!result.stderr.contains("Not overwriting"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -311,16 +266,11 @@ fn test_cp_arg_force() {
|
||||||
permissions.set_readonly(true);
|
permissions.set_readonly(true);
|
||||||
set_permissions(at.plus(TEST_HELLO_WORLD_DEST), permissions).unwrap();
|
set_permissions(at.plus(TEST_HELLO_WORLD_DEST), permissions).unwrap();
|
||||||
|
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg("--force")
|
.arg("--force")
|
||||||
.arg(TEST_HELLO_WORLD_DEST)
|
.arg(TEST_HELLO_WORLD_DEST)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
println!("{:?}", result.stderr_str());
|
|
||||||
println!("{:?}", result.stdout_str());
|
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert_eq!(at.read(TEST_HELLO_WORLD_DEST), "Hello, World!\n");
|
assert_eq!(at.read(TEST_HELLO_WORLD_DEST), "Hello, World!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -342,13 +292,11 @@ fn test_cp_arg_remove_destination() {
|
||||||
permissions.set_readonly(true);
|
permissions.set_readonly(true);
|
||||||
set_permissions(at.plus(TEST_HELLO_WORLD_DEST), permissions).unwrap();
|
set_permissions(at.plus(TEST_HELLO_WORLD_DEST), permissions).unwrap();
|
||||||
|
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg("--remove-destination")
|
.arg("--remove-destination")
|
||||||
.arg(TEST_HELLO_WORLD_DEST)
|
.arg(TEST_HELLO_WORLD_DEST)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert_eq!(at.read(TEST_HELLO_WORLD_DEST), "Hello, World!\n");
|
assert_eq!(at.read(TEST_HELLO_WORLD_DEST), "Hello, World!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -356,13 +304,11 @@ fn test_cp_arg_remove_destination() {
|
||||||
fn test_cp_arg_backup() {
|
fn test_cp_arg_backup() {
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
|
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg("--backup")
|
.arg("--backup")
|
||||||
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert_eq!(at.read(TEST_HOW_ARE_YOU_SOURCE), "Hello, World!\n");
|
assert_eq!(at.read(TEST_HOW_ARE_YOU_SOURCE), "Hello, World!\n");
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
at.read(&*format!("{}~", TEST_HOW_ARE_YOU_SOURCE)),
|
at.read(&*format!("{}~", TEST_HOW_ARE_YOU_SOURCE)),
|
||||||
|
@ -374,14 +320,12 @@ fn test_cp_arg_backup() {
|
||||||
fn test_cp_arg_suffix() {
|
fn test_cp_arg_suffix() {
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
|
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg("--suffix")
|
.arg("--suffix")
|
||||||
.arg(".bak")
|
.arg(".bak")
|
||||||
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert_eq!(at.read(TEST_HOW_ARE_YOU_SOURCE), "Hello, World!\n");
|
assert_eq!(at.read(TEST_HOW_ARE_YOU_SOURCE), "Hello, World!\n");
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
at.read(&*format!("{}.bak", TEST_HOW_ARE_YOU_SOURCE)),
|
at.read(&*format!("{}.bak", TEST_HOW_ARE_YOU_SOURCE)),
|
||||||
|
@ -391,9 +335,8 @@ fn test_cp_arg_suffix() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_deref_conflicting_options() {
|
fn test_cp_deref_conflicting_options() {
|
||||||
let (_at, mut ucmd) = at_and_ucmd!();
|
new_ucmd!()
|
||||||
|
.arg("-LP")
|
||||||
ucmd.arg("-LP")
|
|
||||||
.arg(TEST_COPY_TO_FOLDER)
|
.arg(TEST_COPY_TO_FOLDER)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.fails();
|
.fails();
|
||||||
|
@ -401,8 +344,7 @@ fn test_cp_deref_conflicting_options() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_deref() {
|
fn test_cp_deref() {
|
||||||
let scene = TestScenario::new(util_name!());
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
let at = &scene.fixtures;
|
|
||||||
|
|
||||||
#[cfg(not(windows))]
|
#[cfg(not(windows))]
|
||||||
let _r = fs::symlink(
|
let _r = fs::symlink(
|
||||||
|
@ -415,16 +357,12 @@ fn test_cp_deref() {
|
||||||
at.subdir.join(TEST_HELLO_WORLD_SOURCE_SYMLINK),
|
at.subdir.join(TEST_HELLO_WORLD_SOURCE_SYMLINK),
|
||||||
);
|
);
|
||||||
//using -L option
|
//using -L option
|
||||||
let result = scene
|
ucmd.arg("-L")
|
||||||
.ucmd()
|
|
||||||
.arg("-L")
|
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE_SYMLINK)
|
.arg(TEST_HELLO_WORLD_SOURCE_SYMLINK)
|
||||||
.arg(TEST_COPY_TO_FOLDER)
|
.arg(TEST_COPY_TO_FOLDER)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
// Check that the exit code represents a successful copy.
|
|
||||||
assert!(result.success);
|
|
||||||
let path_to_new_symlink = at
|
let path_to_new_symlink = at
|
||||||
.subdir
|
.subdir
|
||||||
.join(TEST_COPY_TO_FOLDER)
|
.join(TEST_COPY_TO_FOLDER)
|
||||||
|
@ -444,8 +382,7 @@ fn test_cp_deref() {
|
||||||
}
|
}
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_no_deref() {
|
fn test_cp_no_deref() {
|
||||||
let scene = TestScenario::new(util_name!());
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
let at = &scene.fixtures;
|
|
||||||
|
|
||||||
#[cfg(not(windows))]
|
#[cfg(not(windows))]
|
||||||
let _r = fs::symlink(
|
let _r = fs::symlink(
|
||||||
|
@ -458,16 +395,12 @@ fn test_cp_no_deref() {
|
||||||
at.subdir.join(TEST_HELLO_WORLD_SOURCE_SYMLINK),
|
at.subdir.join(TEST_HELLO_WORLD_SOURCE_SYMLINK),
|
||||||
);
|
);
|
||||||
//using -P option
|
//using -P option
|
||||||
let result = scene
|
ucmd.arg("-P")
|
||||||
.ucmd()
|
|
||||||
.arg("-P")
|
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE_SYMLINK)
|
.arg(TEST_HELLO_WORLD_SOURCE_SYMLINK)
|
||||||
.arg(TEST_COPY_TO_FOLDER)
|
.arg(TEST_COPY_TO_FOLDER)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
// Check that the exit code represents a successful copy.
|
|
||||||
assert!(result.success);
|
|
||||||
let path_to_new_symlink = at
|
let path_to_new_symlink = at
|
||||||
.subdir
|
.subdir
|
||||||
.join(TEST_COPY_TO_FOLDER)
|
.join(TEST_COPY_TO_FOLDER)
|
||||||
|
@ -490,14 +423,10 @@ fn test_cp_strip_trailing_slashes() {
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
|
|
||||||
//using --strip-trailing-slashes option
|
//using --strip-trailing-slashes option
|
||||||
let result = ucmd
|
ucmd.arg("--strip-trailing-slashes")
|
||||||
.arg("--strip-trailing-slashes")
|
|
||||||
.arg(format!("{}/", TEST_HELLO_WORLD_SOURCE))
|
.arg(format!("{}/", TEST_HELLO_WORLD_SOURCE))
|
||||||
.arg(TEST_HELLO_WORLD_DEST)
|
.arg(TEST_HELLO_WORLD_DEST)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
// Check that the exit code represents a successful copy.
|
|
||||||
assert!(result.success);
|
|
||||||
|
|
||||||
// Check the content of the destination file that was copied.
|
// Check the content of the destination file that was copied.
|
||||||
assert_eq!(at.read(TEST_HELLO_WORLD_DEST), "Hello, World!\n");
|
assert_eq!(at.read(TEST_HELLO_WORLD_DEST), "Hello, World!\n");
|
||||||
|
@ -507,14 +436,11 @@ fn test_cp_strip_trailing_slashes() {
|
||||||
fn test_cp_parents() {
|
fn test_cp_parents() {
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
|
|
||||||
let result = ucmd
|
ucmd.arg("--parents")
|
||||||
.arg("--parents")
|
|
||||||
.arg(TEST_COPY_FROM_FOLDER_FILE)
|
.arg(TEST_COPY_FROM_FOLDER_FILE)
|
||||||
.arg(TEST_COPY_TO_FOLDER)
|
.arg(TEST_COPY_TO_FOLDER)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
// Check the content of the destination file that was copied.
|
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
at.read(&format!(
|
at.read(&format!(
|
||||||
"{}/{}",
|
"{}/{}",
|
||||||
|
@ -528,14 +454,12 @@ fn test_cp_parents() {
|
||||||
fn test_cp_parents_multiple_files() {
|
fn test_cp_parents_multiple_files() {
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
let (at, mut ucmd) = at_and_ucmd!();
|
||||||
|
|
||||||
let result = ucmd
|
ucmd.arg("--parents")
|
||||||
.arg("--parents")
|
|
||||||
.arg(TEST_COPY_FROM_FOLDER_FILE)
|
.arg(TEST_COPY_FROM_FOLDER_FILE)
|
||||||
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
||||||
.arg(TEST_COPY_TO_FOLDER)
|
.arg(TEST_COPY_TO_FOLDER)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
at.read(&format!(
|
at.read(&format!(
|
||||||
"{}/{}",
|
"{}/{}",
|
||||||
|
@ -554,20 +478,12 @@ fn test_cp_parents_multiple_files() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_cp_parents_dest_not_directory() {
|
fn test_cp_parents_dest_not_directory() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!()
|
||||||
|
|
||||||
let result = ucmd
|
|
||||||
.arg("--parents")
|
.arg("--parents")
|
||||||
.arg(TEST_COPY_FROM_FOLDER_FILE)
|
.arg(TEST_COPY_FROM_FOLDER_FILE)
|
||||||
.arg(TEST_HELLO_WORLD_DEST)
|
.arg(TEST_HELLO_WORLD_DEST)
|
||||||
.run();
|
.fails()
|
||||||
println!("{:?}", result);
|
.stderr_contains("with --parents, the destination must be a directory");
|
||||||
|
|
||||||
// Check that we did not succeed in copying.
|
|
||||||
assert!(!result.success);
|
|
||||||
assert!(result
|
|
||||||
.stderr
|
|
||||||
.contains("with --parents, the destination must be a directory"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -594,18 +510,14 @@ fn test_cp_deref_folder_to_folder() {
|
||||||
assert!(env::set_current_dir(&cwd).is_ok());
|
assert!(env::set_current_dir(&cwd).is_ok());
|
||||||
|
|
||||||
//using -P -R option
|
//using -P -R option
|
||||||
let result = scene
|
scene
|
||||||
.ucmd()
|
.ucmd()
|
||||||
.arg("-L")
|
.arg("-L")
|
||||||
.arg("-R")
|
.arg("-R")
|
||||||
.arg("-v")
|
.arg("-v")
|
||||||
.arg(TEST_COPY_FROM_FOLDER)
|
.arg(TEST_COPY_FROM_FOLDER)
|
||||||
.arg(TEST_COPY_TO_FOLDER_NEW)
|
.arg(TEST_COPY_TO_FOLDER_NEW)
|
||||||
.run();
|
.succeeds();
|
||||||
println!("cp output {}", result.stdout_str());
|
|
||||||
|
|
||||||
// Check that the exit code represents a successful copy.
|
|
||||||
assert!(result.success);
|
|
||||||
|
|
||||||
#[cfg(not(windows))]
|
#[cfg(not(windows))]
|
||||||
{
|
{
|
||||||
|
@ -698,18 +610,14 @@ fn test_cp_no_deref_folder_to_folder() {
|
||||||
assert!(env::set_current_dir(&cwd).is_ok());
|
assert!(env::set_current_dir(&cwd).is_ok());
|
||||||
|
|
||||||
//using -P -R option
|
//using -P -R option
|
||||||
let result = scene
|
scene
|
||||||
.ucmd()
|
.ucmd()
|
||||||
.arg("-P")
|
.arg("-P")
|
||||||
.arg("-R")
|
.arg("-R")
|
||||||
.arg("-v")
|
.arg("-v")
|
||||||
.arg(TEST_COPY_FROM_FOLDER)
|
.arg(TEST_COPY_FROM_FOLDER)
|
||||||
.arg(TEST_COPY_TO_FOLDER_NEW)
|
.arg(TEST_COPY_TO_FOLDER_NEW)
|
||||||
.run();
|
.succeeds();
|
||||||
println!("cp output {}", result.stdout_str());
|
|
||||||
|
|
||||||
// Check that the exit code represents a successful copy.
|
|
||||||
assert!(result.success);
|
|
||||||
|
|
||||||
#[cfg(not(windows))]
|
#[cfg(not(windows))]
|
||||||
{
|
{
|
||||||
|
@ -791,13 +699,11 @@ fn test_cp_archive() {
|
||||||
previous,
|
previous,
|
||||||
)
|
)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg("--archive")
|
.arg("--archive")
|
||||||
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert_eq!(at.read(TEST_HOW_ARE_YOU_SOURCE), "Hello, World!\n");
|
assert_eq!(at.read(TEST_HOW_ARE_YOU_SOURCE), "Hello, World!\n");
|
||||||
|
|
||||||
let metadata = std_fs::metadata(at.subdir.join(TEST_HELLO_WORLD_SOURCE)).unwrap();
|
let metadata = std_fs::metadata(at.subdir.join(TEST_HELLO_WORLD_SOURCE)).unwrap();
|
||||||
|
@ -807,11 +713,10 @@ fn test_cp_archive() {
|
||||||
let creation2 = metadata2.modified().unwrap();
|
let creation2 = metadata2.modified().unwrap();
|
||||||
|
|
||||||
let scene2 = TestScenario::new("ls");
|
let scene2 = TestScenario::new("ls");
|
||||||
let result = scene2.cmd("ls").arg("-al").arg(at.subdir).run();
|
let result = scene2.cmd("ls").arg("-al").arg(at.subdir).succeeds();
|
||||||
|
|
||||||
println!("ls dest {}", result.stdout_str());
|
println!("ls dest {}", result.stdout_str());
|
||||||
assert_eq!(creation, creation2);
|
assert_eq!(creation, creation2);
|
||||||
assert!(result.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -850,11 +755,10 @@ fn test_cp_archive_recursive() {
|
||||||
// Back to the initial cwd (breaks the other tests)
|
// Back to the initial cwd (breaks the other tests)
|
||||||
assert!(env::set_current_dir(&cwd).is_ok());
|
assert!(env::set_current_dir(&cwd).is_ok());
|
||||||
|
|
||||||
let resultg = ucmd
|
ucmd.arg("--archive")
|
||||||
.arg("--archive")
|
|
||||||
.arg(TEST_COPY_TO_FOLDER)
|
.arg(TEST_COPY_TO_FOLDER)
|
||||||
.arg(TEST_COPY_TO_FOLDER_NEW)
|
.arg(TEST_COPY_TO_FOLDER_NEW)
|
||||||
.run();
|
.fails(); // fails for now
|
||||||
|
|
||||||
let scene2 = TestScenario::new("ls");
|
let scene2 = TestScenario::new("ls");
|
||||||
let result = scene2
|
let result = scene2
|
||||||
|
@ -865,7 +769,6 @@ fn test_cp_archive_recursive() {
|
||||||
|
|
||||||
println!("ls dest {}", result.stdout_str());
|
println!("ls dest {}", result.stdout_str());
|
||||||
|
|
||||||
let scene2 = TestScenario::new("ls");
|
|
||||||
let result = scene2
|
let result = scene2
|
||||||
.cmd("ls")
|
.cmd("ls")
|
||||||
.arg("-al")
|
.arg("-al")
|
||||||
|
@ -910,9 +813,6 @@ fn test_cp_archive_recursive() {
|
||||||
.join("2.link")
|
.join("2.link")
|
||||||
.to_string_lossy()
|
.to_string_lossy()
|
||||||
));
|
));
|
||||||
|
|
||||||
// fails for now
|
|
||||||
assert!(resultg.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -928,13 +828,11 @@ fn test_cp_preserve_timestamps() {
|
||||||
previous,
|
previous,
|
||||||
)
|
)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg("--preserve=timestamps")
|
.arg("--preserve=timestamps")
|
||||||
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert_eq!(at.read(TEST_HOW_ARE_YOU_SOURCE), "Hello, World!\n");
|
assert_eq!(at.read(TEST_HOW_ARE_YOU_SOURCE), "Hello, World!\n");
|
||||||
|
|
||||||
let metadata = std_fs::metadata(at.subdir.join(TEST_HELLO_WORLD_SOURCE)).unwrap();
|
let metadata = std_fs::metadata(at.subdir.join(TEST_HELLO_WORLD_SOURCE)).unwrap();
|
||||||
|
@ -948,7 +846,6 @@ fn test_cp_preserve_timestamps() {
|
||||||
|
|
||||||
println!("ls dest {}", result.stdout_str());
|
println!("ls dest {}", result.stdout_str());
|
||||||
assert_eq!(creation, creation2);
|
assert_eq!(creation, creation2);
|
||||||
assert!(result.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -966,13 +863,11 @@ fn test_cp_dont_preserve_timestamps() {
|
||||||
.unwrap();
|
.unwrap();
|
||||||
sleep(Duration::from_secs(3));
|
sleep(Duration::from_secs(3));
|
||||||
|
|
||||||
let result = ucmd
|
ucmd.arg(TEST_HELLO_WORLD_SOURCE)
|
||||||
.arg(TEST_HELLO_WORLD_SOURCE)
|
|
||||||
.arg("--no-preserve=timestamps")
|
.arg("--no-preserve=timestamps")
|
||||||
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
.arg(TEST_HOW_ARE_YOU_SOURCE)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert_eq!(at.read(TEST_HOW_ARE_YOU_SOURCE), "Hello, World!\n");
|
assert_eq!(at.read(TEST_HOW_ARE_YOU_SOURCE), "Hello, World!\n");
|
||||||
|
|
||||||
let metadata = std_fs::metadata(at.subdir.join(TEST_HELLO_WORLD_SOURCE)).unwrap();
|
let metadata = std_fs::metadata(at.subdir.join(TEST_HELLO_WORLD_SOURCE)).unwrap();
|
||||||
|
@ -992,7 +887,6 @@ fn test_cp_dont_preserve_timestamps() {
|
||||||
// Some margins with time check
|
// Some margins with time check
|
||||||
assert!(res.as_secs() > 3595);
|
assert!(res.as_secs() > 3595);
|
||||||
assert!(res.as_secs() < 3605);
|
assert!(res.as_secs() < 3605);
|
||||||
assert!(result.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -1017,7 +911,7 @@ fn test_cp_one_file_system() {
|
||||||
let scene = TestScenario::new(util_name!());
|
let scene = TestScenario::new(util_name!());
|
||||||
|
|
||||||
// Test must be run as root (or with `sudo -E`)
|
// Test must be run as root (or with `sudo -E`)
|
||||||
if scene.cmd("whoami").run().stdout != "root\n" {
|
if scene.cmd("whoami").run().stdout_str() != "root\n" {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1042,17 +936,16 @@ fn test_cp_one_file_system() {
|
||||||
at_src.touch(TEST_MOUNT_OTHER_FILESYSTEM_FILE);
|
at_src.touch(TEST_MOUNT_OTHER_FILESYSTEM_FILE);
|
||||||
|
|
||||||
// Begin testing -x flag
|
// Begin testing -x flag
|
||||||
let result = scene
|
scene
|
||||||
.ucmd()
|
.ucmd()
|
||||||
.arg("-rx")
|
.arg("-rx")
|
||||||
.arg(TEST_MOUNT_COPY_FROM_FOLDER)
|
.arg(TEST_MOUNT_COPY_FROM_FOLDER)
|
||||||
.arg(TEST_COPY_TO_FOLDER_NEW)
|
.arg(TEST_COPY_TO_FOLDER_NEW)
|
||||||
.run();
|
.succeeds();
|
||||||
|
|
||||||
// Ditch the mount before the asserts
|
// Ditch the mount before the asserts
|
||||||
scene.cmd("umount").arg(mountpoint_path).succeeds();
|
scene.cmd("umount").arg(mountpoint_path).succeeds();
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
assert!(!at_dst.file_exists(TEST_MOUNT_OTHER_FILESYSTEM_FILE));
|
assert!(!at_dst.file_exists(TEST_MOUNT_OTHER_FILESYSTEM_FILE));
|
||||||
// Check if the other files were copied from the source folder hirerarchy
|
// Check if the other files were copied from the source folder hirerarchy
|
||||||
for entry in WalkDir::new(at_src.as_string()) {
|
for entry in WalkDir::new(at_src.as_string()) {
|
||||||
|
|
|
@ -7,174 +7,147 @@ use rust_users::*;
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_date_email() {
|
fn test_date_email() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!().arg("--rfc-email").succeeds();
|
||||||
let result = ucmd.arg("--rfc-email").run();
|
|
||||||
assert!(result.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_date_email2() {
|
fn test_date_email2() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!().arg("-R").succeeds();
|
||||||
let result = ucmd.arg("-R").run();
|
|
||||||
assert!(result.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_date_rfc_3339() {
|
fn test_date_rfc_3339() {
|
||||||
let scene = TestScenario::new(util_name!());
|
let scene = TestScenario::new(util_name!());
|
||||||
|
|
||||||
let mut result = scene.ucmd().arg("--rfc-3339=ns").succeeds();
|
let rfc_regexp = concat!(
|
||||||
|
r#"(\d+)-(0[1-9]|1[012])-(0[1-9]|[12]\d|3[01])\s([01]\d|2[0-3]):"#,
|
||||||
|
r#"([0-5]\d):([0-5]\d|60)(\.\d+)?(([Zz])|([\+|\-]([01]\d|2[0-3])))"#
|
||||||
|
);
|
||||||
|
let re = Regex::new(rfc_regexp).unwrap();
|
||||||
|
|
||||||
// Check that the output matches the regexp
|
// Check that the output matches the regexp
|
||||||
let rfc_regexp = r"(\d+)-(0[1-9]|1[012])-(0[1-9]|[12]\d|3[01])\s([01]\d|2[0-3]):([0-5]\d):([0-5]\d|60)(\.\d+)?(([Zz])|([\+|\-]([01]\d|2[0-3])))";
|
scene
|
||||||
let re = Regex::new(rfc_regexp).unwrap();
|
.ucmd()
|
||||||
assert!(re.is_match(&result.stdout_str().trim()));
|
.arg("--rfc-3339=ns")
|
||||||
|
.succeeds()
|
||||||
|
.stdout_matches(&re);
|
||||||
|
|
||||||
result = scene.ucmd().arg("--rfc-3339=seconds").succeeds();
|
scene
|
||||||
|
.ucmd()
|
||||||
// Check that the output matches the regexp
|
.arg("--rfc-3339=seconds")
|
||||||
let re = Regex::new(rfc_regexp).unwrap();
|
.succeeds()
|
||||||
assert!(re.is_match(&result.stdout_str().trim()));
|
.stdout_matches(&re);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_date_rfc_8601() {
|
fn test_date_rfc_8601() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!().arg("--iso-8601=ns").succeeds();
|
||||||
let result = ucmd.arg("--iso-8601=ns").run();
|
|
||||||
assert!(result.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_date_rfc_8601_second() {
|
fn test_date_rfc_8601_second() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!().arg("--iso-8601=second").succeeds();
|
||||||
let result = ucmd.arg("--iso-8601=second").run();
|
|
||||||
assert!(result.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_date_utc() {
|
fn test_date_utc() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!().arg("--utc").succeeds();
|
||||||
let result = ucmd.arg("--utc").run();
|
|
||||||
assert!(result.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_date_universal() {
|
fn test_date_universal() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!().arg("--universal").succeeds();
|
||||||
let result = ucmd.arg("--universal").run();
|
|
||||||
assert!(result.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_date_format_y() {
|
fn test_date_format_y() {
|
||||||
let scene = TestScenario::new(util_name!());
|
let scene = TestScenario::new(util_name!());
|
||||||
|
|
||||||
let mut result = scene.ucmd().arg("+%Y").succeeds();
|
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
let mut re = Regex::new(r"^\d{4}$").unwrap();
|
let mut re = Regex::new(r"^\d{4}$").unwrap();
|
||||||
assert!(re.is_match(&result.stdout_str().trim()));
|
scene.ucmd().arg("+%Y").succeeds().stdout_matches(&re);
|
||||||
|
|
||||||
result = scene.ucmd().arg("+%y").succeeds();
|
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
re = Regex::new(r"^\d{2}$").unwrap();
|
re = Regex::new(r"^\d{2}$").unwrap();
|
||||||
assert!(re.is_match(&result.stdout_str().trim()));
|
scene.ucmd().arg("+%y").succeeds().stdout_matches(&re);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_date_format_m() {
|
fn test_date_format_m() {
|
||||||
let scene = TestScenario::new(util_name!());
|
let scene = TestScenario::new(util_name!());
|
||||||
|
|
||||||
let mut result = scene.ucmd().arg("+%b").succeeds();
|
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
let mut re = Regex::new(r"\S+").unwrap();
|
let mut re = Regex::new(r"\S+").unwrap();
|
||||||
assert!(re.is_match(&result.stdout_str().trim()));
|
scene.ucmd().arg("+%b").succeeds().stdout_matches(&re);
|
||||||
|
|
||||||
result = scene.ucmd().arg("+%m").succeeds();
|
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
re = Regex::new(r"^\d{2}$").unwrap();
|
re = Regex::new(r"^\d{2}$").unwrap();
|
||||||
assert!(re.is_match(&result.stdout_str().trim()));
|
scene.ucmd().arg("+%m").succeeds().stdout_matches(&re);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_date_format_day() {
|
fn test_date_format_day() {
|
||||||
let scene = TestScenario::new(util_name!());
|
let scene = TestScenario::new(util_name!());
|
||||||
|
|
||||||
let mut result = scene.ucmd().arg("+%a").succeeds();
|
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
let mut re = Regex::new(r"\S+").unwrap();
|
let mut re = Regex::new(r"\S+").unwrap();
|
||||||
assert!(re.is_match(&result.stdout_str().trim()));
|
scene.ucmd().arg("+%a").succeeds().stdout_matches(&re);
|
||||||
|
|
||||||
result = scene.ucmd().arg("+%A").succeeds();
|
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
|
|
||||||
re = Regex::new(r"\S+").unwrap();
|
re = Regex::new(r"\S+").unwrap();
|
||||||
assert!(re.is_match(&result.stdout_str().trim()));
|
scene.ucmd().arg("+%A").succeeds().stdout_matches(&re);
|
||||||
|
|
||||||
result = scene.ucmd().arg("+%u").succeeds();
|
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
re = Regex::new(r"^\d{1}$").unwrap();
|
re = Regex::new(r"^\d{1}$").unwrap();
|
||||||
assert!(re.is_match(&result.stdout_str().trim()));
|
scene.ucmd().arg("+%u").succeeds().stdout_matches(&re);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_date_format_full_day() {
|
fn test_date_format_full_day() {
|
||||||
let scene = TestScenario::new(util_name!());
|
|
||||||
|
|
||||||
let result = scene.ucmd().arg("+'%a %Y-%m-%d'").succeeds();
|
|
||||||
|
|
||||||
assert!(result.success);
|
|
||||||
let re = Regex::new(r"\S+ \d{4}-\d{2}-\d{2}").unwrap();
|
let re = Regex::new(r"\S+ \d{4}-\d{2}-\d{2}").unwrap();
|
||||||
assert!(re.is_match(&result.stdout_str().trim()));
|
new_ucmd!()
|
||||||
|
.arg("+'%a %Y-%m-%d'")
|
||||||
|
.succeeds()
|
||||||
|
.stdout_matches(&re);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
#[cfg(all(unix, not(target_os = "macos")))]
|
#[cfg(all(unix, not(target_os = "macos")))]
|
||||||
fn test_date_set_valid() {
|
fn test_date_set_valid() {
|
||||||
if get_effective_uid() == 0 {
|
if get_effective_uid() == 0 {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!()
|
||||||
let result = ucmd
|
|
||||||
.arg("--set")
|
.arg("--set")
|
||||||
.arg("2020-03-12 13:30:00+08:00")
|
.arg("2020-03-12 13:30:00+08:00")
|
||||||
.succeeds();
|
.succeeds()
|
||||||
result.no_stdout().no_stderr();
|
.no_stdout()
|
||||||
|
.no_stderr();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
#[cfg(any(windows, all(unix, not(target_os = "macos"))))]
|
#[cfg(any(windows, all(unix, not(target_os = "macos"))))]
|
||||||
fn test_date_set_invalid() {
|
fn test_date_set_invalid() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
let result = new_ucmd!().arg("--set").arg("123abcd").fails();
|
||||||
let result = ucmd.arg("--set").arg("123abcd").fails();
|
result.no_stdout();
|
||||||
let result = result.no_stdout();
|
assert!(result.stderr_str().starts_with("date: invalid date "));
|
||||||
assert!(result.stderr.starts_with("date: invalid date "));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
#[cfg(all(unix, not(target_os = "macos")))]
|
#[cfg(all(unix, not(target_os = "macos")))]
|
||||||
fn test_date_set_permissions_error() {
|
fn test_date_set_permissions_error() {
|
||||||
if !(get_effective_uid() == 0 || is_wsl()) {
|
if !(get_effective_uid() == 0 || is_wsl()) {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
let result = new_ucmd!()
|
||||||
let result = ucmd.arg("--set").arg("2020-03-11 21:45:00+08:00").fails();
|
.arg("--set")
|
||||||
let result = result.no_stdout();
|
.arg("2020-03-11 21:45:00+08:00")
|
||||||
assert!(result.stderr.starts_with("date: cannot set date: "));
|
.fails();
|
||||||
|
result.no_stdout();
|
||||||
|
assert!(result.stderr_str().starts_with("date: cannot set date: "));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
#[cfg(target_os = "macos")]
|
#[cfg(target_os = "macos")]
|
||||||
fn test_date_set_mac_unavailable() {
|
fn test_date_set_mac_unavailable() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
let result = new_ucmd!()
|
||||||
let result = ucmd.arg("--set").arg("2020-03-11 21:45:00+08:00").fails();
|
.arg("--set")
|
||||||
let result = result.no_stdout();
|
.arg("2020-03-11 21:45:00+08:00")
|
||||||
|
.fails();
|
||||||
|
result.no_stdout();
|
||||||
assert!(result
|
assert!(result
|
||||||
.stderr
|
.stderr_str()
|
||||||
.starts_with("date: setting the date is not supported by macOS"));
|
.starts_with("date: setting the date is not supported by macOS"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -183,13 +156,12 @@ fn test_date_set_mac_unavailable() {
|
||||||
/// TODO: expected to fail currently; change to succeeds() when required.
|
/// TODO: expected to fail currently; change to succeeds() when required.
|
||||||
fn test_date_set_valid_2() {
|
fn test_date_set_valid_2() {
|
||||||
if get_effective_uid() == 0 {
|
if get_effective_uid() == 0 {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
let result = new_ucmd!()
|
||||||
let result = ucmd
|
|
||||||
.arg("--set")
|
.arg("--set")
|
||||||
.arg("Sat 20 Mar 2021 14:53:01 AWST")
|
.arg("Sat 20 Mar 2021 14:53:01 AWST")
|
||||||
.fails();
|
.fails();
|
||||||
let result = result.no_stdout();
|
result.no_stdout();
|
||||||
assert!(result.stderr.starts_with("date: invalid date "));
|
assert!(result.stderr_str().starts_with("date: invalid date "));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -198,13 +170,12 @@ fn test_date_set_valid_2() {
|
||||||
/// TODO: expected to fail currently; change to succeeds() when required.
|
/// TODO: expected to fail currently; change to succeeds() when required.
|
||||||
fn test_date_set_valid_3() {
|
fn test_date_set_valid_3() {
|
||||||
if get_effective_uid() == 0 {
|
if get_effective_uid() == 0 {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
let result = new_ucmd!()
|
||||||
let result = ucmd
|
|
||||||
.arg("--set")
|
.arg("--set")
|
||||||
.arg("Sat 20 Mar 2021 14:53:01") // Local timezone
|
.arg("Sat 20 Mar 2021 14:53:01") // Local timezone
|
||||||
.fails();
|
.fails();
|
||||||
let result = result.no_stdout();
|
result.no_stdout();
|
||||||
assert!(result.stderr.starts_with("date: invalid date "));
|
assert!(result.stderr_str().starts_with("date: invalid date "));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -213,12 +184,11 @@ fn test_date_set_valid_3() {
|
||||||
/// TODO: expected to fail currently; change to succeeds() when required.
|
/// TODO: expected to fail currently; change to succeeds() when required.
|
||||||
fn test_date_set_valid_4() {
|
fn test_date_set_valid_4() {
|
||||||
if get_effective_uid() == 0 {
|
if get_effective_uid() == 0 {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
let result = new_ucmd!()
|
||||||
let result = ucmd
|
|
||||||
.arg("--set")
|
.arg("--set")
|
||||||
.arg("2020-03-11 21:45:00") // Local timezone
|
.arg("2020-03-11 21:45:00") // Local timezone
|
||||||
.fails();
|
.fails();
|
||||||
let result = result.no_stdout();
|
result.no_stdout();
|
||||||
assert!(result.stderr.starts_with("date: invalid date "));
|
assert!(result.stderr_str().starts_with("date: invalid date "));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,30 +2,22 @@ use crate::common::util::*;
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_df_compatible_no_size_arg() {
|
fn test_df_compatible_no_size_arg() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!().arg("-a").succeeds();
|
||||||
let result = ucmd.arg("-a").run();
|
|
||||||
assert!(result.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_df_compatible() {
|
fn test_df_compatible() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!().arg("-ah").succeeds();
|
||||||
let result = ucmd.arg("-ah").run();
|
|
||||||
assert!(result.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_df_compatible_type() {
|
fn test_df_compatible_type() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!().arg("-aT").succeeds();
|
||||||
let result = ucmd.arg("-aT").run();
|
|
||||||
assert!(result.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_df_compatible_si() {
|
fn test_df_compatible_si() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!().arg("-aH").succeeds();
|
||||||
let result = ucmd.arg("-aH").run();
|
|
||||||
assert!(result.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// ToDO: more tests...
|
// ToDO: more tests...
|
||||||
|
|
|
@ -220,26 +220,36 @@ fn test_du_time() {
|
||||||
.arg("date_test")
|
.arg("date_test")
|
||||||
.succeeds()
|
.succeeds()
|
||||||
.stdout_only("0\t2015-05-15 00:00\tdate_test\n");
|
.stdout_only("0\t2015-05-15 00:00\tdate_test\n");
|
||||||
|
|
||||||
// cleanup by removing test file
|
|
||||||
scene.cmd("rm").arg("date_test").succeeds(); // TODO: is this necessary?
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(not(target_os = "windows"))]
|
#[cfg(not(target_os = "windows"))]
|
||||||
#[cfg(feature = "chmod")]
|
#[cfg(feature = "chmod")]
|
||||||
#[test]
|
#[test]
|
||||||
fn test_du_no_permission() {
|
fn test_du_no_permission() {
|
||||||
let ts = TestScenario::new(util_name!());
|
let scene = TestScenario::new(util_name!());
|
||||||
|
let at = &scene.fixtures;
|
||||||
|
|
||||||
let _chmod = ts.ccmd("chmod").arg("-r").arg(SUB_DIR_LINKS).succeeds();
|
at.mkdir_all(SUB_DIR_LINKS);
|
||||||
let result = ts.ucmd().arg(SUB_DIR_LINKS).succeeds();
|
|
||||||
|
|
||||||
ts.ccmd("chmod").arg("+r").arg(SUB_DIR_LINKS).run();
|
scene.ccmd("chmod").arg("-r").arg(SUB_DIR_LINKS).succeeds();
|
||||||
|
|
||||||
assert_eq!(
|
let result = scene.ucmd().arg(SUB_DIR_LINKS).run(); // TODO: replace with ".fails()" once `du` is fixed
|
||||||
result.stderr_str(),
|
result.stderr_contains(
|
||||||
"du: cannot read directory ‘subdir/links‘: Permission denied (os error 13)\n"
|
"du: cannot read directory ‘subdir/links‘: Permission denied (os error 13)",
|
||||||
);
|
);
|
||||||
|
|
||||||
|
#[cfg(target_os = "linux")]
|
||||||
|
{
|
||||||
|
let result_reference = scene.cmd("du").arg(SUB_DIR_LINKS).fails();
|
||||||
|
if result_reference
|
||||||
|
.stderr_str()
|
||||||
|
.contains("du: cannot read directory 'subdir/links': Permission denied")
|
||||||
|
{
|
||||||
|
assert_eq!(result.stdout_str(), result_reference.stdout_str());
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
_du_no_permission(result.stdout_str());
|
_du_no_permission(result.stdout_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -140,8 +140,11 @@ fn test_unset_variable() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_fail_null_with_program() {
|
fn test_fail_null_with_program() {
|
||||||
let out = new_ucmd!().arg("--null").arg("cd").fails().stderr;
|
new_ucmd!()
|
||||||
assert!(out.contains("cannot specify --null (-0) with command"));
|
.arg("--null")
|
||||||
|
.arg("cd")
|
||||||
|
.fails()
|
||||||
|
.stderr_contains("cannot specify --null (-0) with command");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(not(windows))]
|
#[cfg(not(windows))]
|
||||||
|
|
|
@ -29,7 +29,7 @@ fn test_fmt_w_too_big() {
|
||||||
.run();
|
.run();
|
||||||
//.stdout_is_fixture("call_graph.expected");
|
//.stdout_is_fixture("call_graph.expected");
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
result.stderr.trim(),
|
result.stderr_str().trim(),
|
||||||
"fmt: error: invalid width: '2501': Numerical result out of range"
|
"fmt: error: invalid width: '2501': Numerical result out of range"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@ fn test_groups() {
|
||||||
// As seems to be a configuration issue, ignoring it
|
// As seems to be a configuration issue, ignoring it
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
assert!(result.success);
|
result.success();
|
||||||
assert!(!result.stdout_str().trim().is_empty());
|
assert!(!result.stdout_str().trim().is_empty());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -30,16 +30,12 @@ fn test_groups_arg() {
|
||||||
|
|
||||||
println!("result.stdout = {}", result.stdout_str());
|
println!("result.stdout = {}", result.stdout_str());
|
||||||
println!("result.stderr = {}", result.stderr_str());
|
println!("result.stderr = {}", result.stderr_str());
|
||||||
assert!(result.success);
|
result.success();
|
||||||
assert!(!result.stdout_str().is_empty());
|
assert!(!result.stdout_str().is_empty());
|
||||||
let username = result.stdout_str().trim();
|
let username = result.stdout_str().trim();
|
||||||
|
|
||||||
// call groups with the user name to check that we
|
// call groups with the user name to check that we
|
||||||
// are getting something
|
// are getting something
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
new_ucmd!().arg(username).succeeds();
|
||||||
let result = ucmd.arg(username).run();
|
|
||||||
println!("result.stdout = {}", result.stdout_str());
|
|
||||||
println!("result.stderr = {}", result.stderr_str());
|
|
||||||
assert!(result.success);
|
|
||||||
assert!(!result.stdout_str().is_empty());
|
assert!(!result.stdout_str().is_empty());
|
||||||
}
|
}
|
||||||
|
|
|
@ -156,14 +156,10 @@ fn test_negative_zero_bytes() {
|
||||||
}
|
}
|
||||||
#[test]
|
#[test]
|
||||||
fn test_no_such_file_or_directory() {
|
fn test_no_such_file_or_directory() {
|
||||||
let result = new_ucmd!().arg("no_such_file.toml").run();
|
new_ucmd!()
|
||||||
|
.arg("no_such_file.toml")
|
||||||
assert_eq!(
|
.fails()
|
||||||
true,
|
.stderr_contains("cannot open 'no_such_file.toml' for reading: No such file or directory");
|
||||||
result
|
|
||||||
.stderr
|
|
||||||
.contains("cannot open 'no_such_file.toml' for reading: No such file or directory")
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// there was a bug not caught by previous tests
|
// there was a bug not caught by previous tests
|
||||||
|
|
|
@ -11,12 +11,10 @@ use std::thread::sleep;
|
||||||
fn test_install_help() {
|
fn test_install_help() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
let (_, mut ucmd) = at_and_ucmd!();
|
||||||
|
|
||||||
assert!(ucmd
|
ucmd.arg("--help")
|
||||||
.arg("--help")
|
|
||||||
.succeeds()
|
.succeeds()
|
||||||
.no_stderr()
|
.no_stderr()
|
||||||
.stdout
|
.stdout_contains("FLAGS:");
|
||||||
.contains("FLAGS:"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -59,13 +57,11 @@ fn test_install_failing_not_dir() {
|
||||||
at.touch(file1);
|
at.touch(file1);
|
||||||
at.touch(file2);
|
at.touch(file2);
|
||||||
at.touch(file3);
|
at.touch(file3);
|
||||||
assert!(ucmd
|
ucmd.arg(file1)
|
||||||
.arg(file1)
|
|
||||||
.arg(file2)
|
.arg(file2)
|
||||||
.arg(file3)
|
.arg(file3)
|
||||||
.fails()
|
.fails()
|
||||||
.stderr
|
.stderr_contains("not a directory");
|
||||||
.contains("not a directory"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -77,13 +73,11 @@ fn test_install_unimplemented_arg() {
|
||||||
|
|
||||||
at.touch(file);
|
at.touch(file);
|
||||||
at.mkdir(dir);
|
at.mkdir(dir);
|
||||||
assert!(ucmd
|
ucmd.arg(context_arg)
|
||||||
.arg(context_arg)
|
|
||||||
.arg(file)
|
.arg(file)
|
||||||
.arg(dir)
|
.arg(dir)
|
||||||
.fails()
|
.fails()
|
||||||
.stderr
|
.stderr_contains("Unimplemented");
|
||||||
.contains("Unimplemented"));
|
|
||||||
|
|
||||||
assert!(!at.file_exists(&format!("{}/{}", dir, file)));
|
assert!(!at.file_exists(&format!("{}/{}", dir, file)));
|
||||||
}
|
}
|
||||||
|
@ -231,13 +225,11 @@ fn test_install_mode_failing() {
|
||||||
|
|
||||||
at.touch(file);
|
at.touch(file);
|
||||||
at.mkdir(dir);
|
at.mkdir(dir);
|
||||||
assert!(ucmd
|
ucmd.arg(file)
|
||||||
.arg(file)
|
|
||||||
.arg(dir)
|
.arg(dir)
|
||||||
.arg(mode_arg)
|
.arg(mode_arg)
|
||||||
.fails()
|
.fails()
|
||||||
.stderr
|
.stderr_contains("Invalid mode string: invalid digit found in string");
|
||||||
.contains("Invalid mode string: invalid digit found in string"));
|
|
||||||
|
|
||||||
let dest_file = &format!("{}/{}", dir, file);
|
let dest_file = &format!("{}/{}", dir, file);
|
||||||
assert!(at.file_exists(file));
|
assert!(at.file_exists(file));
|
||||||
|
@ -336,7 +328,7 @@ fn test_install_target_new_file_with_owner() {
|
||||||
.arg(format!("{}/{}", dir, file))
|
.arg(format!("{}/{}", dir, file))
|
||||||
.run();
|
.run();
|
||||||
|
|
||||||
if is_ci() && result.stderr.contains("error: no such user:") {
|
if is_ci() && result.stderr_str().contains("error: no such user:") {
|
||||||
// In the CI, some server are failing to return the user id.
|
// In the CI, some server are failing to return the user id.
|
||||||
// As seems to be a configuration issue, ignoring it
|
// As seems to be a configuration issue, ignoring it
|
||||||
return;
|
return;
|
||||||
|
@ -619,35 +611,27 @@ fn test_install_and_strip_with_program() {
|
||||||
#[test]
|
#[test]
|
||||||
#[cfg(not(windows))]
|
#[cfg(not(windows))]
|
||||||
fn test_install_and_strip_with_invalid_program() {
|
fn test_install_and_strip_with_invalid_program() {
|
||||||
let scene = TestScenario::new(util_name!());
|
new_ucmd!()
|
||||||
|
|
||||||
let stderr = scene
|
|
||||||
.ucmd()
|
|
||||||
.arg("-s")
|
.arg("-s")
|
||||||
.arg("--strip-program")
|
.arg("--strip-program")
|
||||||
.arg("/bin/date")
|
.arg("/bin/date")
|
||||||
.arg(strip_source_file())
|
.arg(strip_source_file())
|
||||||
.arg(STRIP_TARGET_FILE)
|
.arg(STRIP_TARGET_FILE)
|
||||||
.fails()
|
.fails()
|
||||||
.stderr;
|
.stderr_contains("strip program failed");
|
||||||
assert!(stderr.contains("strip program failed"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
#[cfg(not(windows))]
|
#[cfg(not(windows))]
|
||||||
fn test_install_and_strip_with_non_existent_program() {
|
fn test_install_and_strip_with_non_existent_program() {
|
||||||
let scene = TestScenario::new(util_name!());
|
new_ucmd!()
|
||||||
|
|
||||||
let stderr = scene
|
|
||||||
.ucmd()
|
|
||||||
.arg("-s")
|
.arg("-s")
|
||||||
.arg("--strip-program")
|
.arg("--strip-program")
|
||||||
.arg("/usr/bin/non_existent_program")
|
.arg("/usr/bin/non_existent_program")
|
||||||
.arg(strip_source_file())
|
.arg(strip_source_file())
|
||||||
.arg(STRIP_TARGET_FILE)
|
.arg(STRIP_TARGET_FILE)
|
||||||
.fails()
|
.fails()
|
||||||
.stderr;
|
.stderr_contains("No such file or directory");
|
||||||
assert!(stderr.contains("No such file or directory"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -299,13 +299,11 @@ fn test_symlink_overwrite_dir_fail() {
|
||||||
at.touch(path_a);
|
at.touch(path_a);
|
||||||
at.mkdir(path_b);
|
at.mkdir(path_b);
|
||||||
|
|
||||||
assert!(
|
assert!(!ucmd
|
||||||
ucmd.args(&["-s", "-T", path_a, path_b])
|
.args(&["-s", "-T", path_a, path_b])
|
||||||
.fails()
|
.fails()
|
||||||
.stderr
|
.stderr_str()
|
||||||
.len()
|
.is_empty());
|
||||||
> 0
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -358,7 +356,11 @@ fn test_symlink_target_only() {
|
||||||
|
|
||||||
at.mkdir(dir);
|
at.mkdir(dir);
|
||||||
|
|
||||||
assert!(ucmd.args(&["-s", "-t", dir]).fails().stderr.len() > 0);
|
assert!(!ucmd
|
||||||
|
.args(&["-s", "-t", dir])
|
||||||
|
.fails()
|
||||||
|
.stderr_str()
|
||||||
|
.is_empty());
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -103,6 +103,14 @@ fn test_ls_width() {
|
||||||
.succeeds()
|
.succeeds()
|
||||||
.stdout_only("test-width-1\ntest-width-2\ntest-width-3\ntest-width-4\n");
|
.stdout_only("test-width-1\ntest-width-2\ntest-width-3\ntest-width-4\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for option in &["-w 1a", "-w=1a", "--width=1a", "--width 1a"] {
|
||||||
|
scene
|
||||||
|
.ucmd()
|
||||||
|
.args(&option.split(" ").collect::<Vec<_>>())
|
||||||
|
.fails()
|
||||||
|
.stderr_only("ls: error: invalid line width: ‘1a’");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -19,8 +19,7 @@ fn test_create_one_fifo_with_invalid_mode() {
|
||||||
.arg("-m")
|
.arg("-m")
|
||||||
.arg("invalid")
|
.arg("invalid")
|
||||||
.fails()
|
.fails()
|
||||||
.stderr
|
.stderr_contains("invalid mode");
|
||||||
.contains("invalid mode");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -2,18 +2,15 @@ use crate::common::util::*;
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_more_no_arg() {
|
fn test_more_no_arg() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
// stderr = more: Reading from stdin isn't supported yet.
|
||||||
let result = ucmd.run();
|
new_ucmd!().fails();
|
||||||
assert!(!result.success);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_more_dir_arg() {
|
fn test_more_dir_arg() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
let result = new_ucmd!().arg(".").run();
|
||||||
ucmd.arg(".");
|
result.failure();
|
||||||
let result = ucmd.run();
|
|
||||||
assert!(!result.success);
|
|
||||||
const EXPECTED_ERROR_MESSAGE: &str =
|
const EXPECTED_ERROR_MESSAGE: &str =
|
||||||
"more: '.' is a directory.\nTry 'more --help' for more information.";
|
"more: '.' is a directory.\nTry 'more --help' for more information.";
|
||||||
assert_eq!(result.stderr.trim(), EXPECTED_ERROR_MESSAGE);
|
assert_eq!(result.stderr_str().trim(), EXPECTED_ERROR_MESSAGE);
|
||||||
}
|
}
|
||||||
|
|
|
@ -476,16 +476,9 @@ fn test_mv_overwrite_nonempty_dir() {
|
||||||
// GNU: "mv: cannot move ‘a’ to ‘b’: Directory not empty"
|
// GNU: "mv: cannot move ‘a’ to ‘b’: Directory not empty"
|
||||||
|
|
||||||
// Verbose output for the move should not be shown on failure
|
// Verbose output for the move should not be shown on failure
|
||||||
assert!(
|
let result = ucmd.arg("-vT").arg(dir_a).arg(dir_b).fails();
|
||||||
ucmd.arg("-vT")
|
result.no_stdout();
|
||||||
.arg(dir_a)
|
assert!(!result.stderr_str().is_empty());
|
||||||
.arg(dir_b)
|
|
||||||
.fails()
|
|
||||||
.no_stdout()
|
|
||||||
.stderr
|
|
||||||
.len()
|
|
||||||
> 0
|
|
||||||
);
|
|
||||||
|
|
||||||
assert!(at.dir_exists(dir_a));
|
assert!(at.dir_exists(dir_a));
|
||||||
assert!(at.dir_exists(dir_b));
|
assert!(at.dir_exists(dir_b));
|
||||||
|
@ -526,15 +519,15 @@ fn test_mv_errors() {
|
||||||
|
|
||||||
// $ mv -T -t a b
|
// $ mv -T -t a b
|
||||||
// mv: cannot combine --target-directory (-t) and --no-target-directory (-T)
|
// mv: cannot combine --target-directory (-t) and --no-target-directory (-T)
|
||||||
let result = scene
|
scene
|
||||||
.ucmd()
|
.ucmd()
|
||||||
.arg("-T")
|
.arg("-T")
|
||||||
.arg("-t")
|
.arg("-t")
|
||||||
.arg(dir)
|
.arg(dir)
|
||||||
.arg(file_a)
|
.arg(file_a)
|
||||||
.arg(file_b)
|
.arg(file_b)
|
||||||
.fails();
|
.fails()
|
||||||
assert!(result.stderr.contains("cannot be used with"));
|
.stderr_contains("cannot be used with");
|
||||||
|
|
||||||
// $ at.touch file && at.mkdir dir
|
// $ at.touch file && at.mkdir dir
|
||||||
// $ mv -T file dir
|
// $ mv -T file dir
|
||||||
|
@ -553,7 +546,13 @@ fn test_mv_errors() {
|
||||||
// $ at.mkdir dir && at.touch file
|
// $ at.mkdir dir && at.touch file
|
||||||
// $ mv dir file
|
// $ mv dir file
|
||||||
// err == mv: cannot overwrite non-directory ‘file’ with directory ‘dir’
|
// err == mv: cannot overwrite non-directory ‘file’ with directory ‘dir’
|
||||||
assert!(scene.ucmd().arg(dir).arg(file_a).fails().stderr.len() > 0);
|
assert!(!scene
|
||||||
|
.ucmd()
|
||||||
|
.arg(dir)
|
||||||
|
.arg(file_a)
|
||||||
|
.fails()
|
||||||
|
.stderr_str()
|
||||||
|
.is_empty());
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -16,7 +16,7 @@ fn test_negative_adjustment() {
|
||||||
|
|
||||||
let res = new_ucmd!().args(&["-n", "-1", "true"]).run();
|
let res = new_ucmd!().args(&["-n", "-1", "true"]).run();
|
||||||
assert!(res
|
assert!(res
|
||||||
.stderr
|
.stderr_str()
|
||||||
.starts_with("nice: warning: setpriority: Permission denied"));
|
.starts_with("nice: warning: setpriority: Permission denied"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -9,35 +9,28 @@ fn test_output_is_random_permutation() {
|
||||||
.collect::<Vec<String>>()
|
.collect::<Vec<String>>()
|
||||||
.join("\n");
|
.join("\n");
|
||||||
|
|
||||||
let result = new_ucmd!()
|
let result = new_ucmd!().pipe_in(input.as_bytes()).succeeds();
|
||||||
.pipe_in(input.as_bytes())
|
result.no_stderr();
|
||||||
.succeeds()
|
|
||||||
.no_stderr()
|
|
||||||
.stdout
|
|
||||||
.clone();
|
|
||||||
|
|
||||||
let mut result_seq: Vec<i32> = result
|
let mut result_seq: Vec<i32> = result
|
||||||
|
.stdout_str()
|
||||||
.split("\n")
|
.split("\n")
|
||||||
.filter(|x| !x.is_empty())
|
.filter(|x| !x.is_empty())
|
||||||
.map(|x| x.parse().unwrap())
|
.map(|x| x.parse().unwrap())
|
||||||
.collect();
|
.collect();
|
||||||
result_seq.sort();
|
result_seq.sort();
|
||||||
assert_ne!(result, input, "Output is not randomised");
|
assert_ne!(result.stdout_str(), input, "Output is not randomised");
|
||||||
assert_eq!(result_seq, input_seq, "Output is not a permutation");
|
assert_eq!(result_seq, input_seq, "Output is not a permutation");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_zero_termination() {
|
fn test_zero_termination() {
|
||||||
let input_seq = vec![1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
|
let input_seq = vec![1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
|
||||||
let result = new_ucmd!()
|
let result = new_ucmd!().arg("-z").arg("-i1-10").succeeds();
|
||||||
.arg("-z")
|
result.no_stderr();
|
||||||
.arg("-i1-10")
|
|
||||||
.succeeds()
|
|
||||||
.no_stderr()
|
|
||||||
.stdout
|
|
||||||
.clone();
|
|
||||||
|
|
||||||
let mut result_seq: Vec<i32> = result
|
let mut result_seq: Vec<i32> = result
|
||||||
|
.stdout_str()
|
||||||
.split("\0")
|
.split("\0")
|
||||||
.filter(|x| !x.is_empty())
|
.filter(|x| !x.is_empty())
|
||||||
.map(|x| x.parse().unwrap())
|
.map(|x| x.parse().unwrap())
|
||||||
|
@ -57,12 +50,11 @@ fn test_echo() {
|
||||||
.map(|x| x.to_string())
|
.map(|x| x.to_string())
|
||||||
.collect::<Vec<String>>(),
|
.collect::<Vec<String>>(),
|
||||||
)
|
)
|
||||||
.succeeds()
|
.succeeds();
|
||||||
.no_stderr()
|
result.no_stderr();
|
||||||
.stdout
|
|
||||||
.clone();
|
|
||||||
|
|
||||||
let mut result_seq: Vec<i32> = result
|
let mut result_seq: Vec<i32> = result
|
||||||
|
.stdout_str()
|
||||||
.split("\n")
|
.split("\n")
|
||||||
.filter(|x| !x.is_empty())
|
.filter(|x| !x.is_empty())
|
||||||
.map(|x| x.parse().unwrap())
|
.map(|x| x.parse().unwrap())
|
||||||
|
@ -84,12 +76,11 @@ fn test_head_count() {
|
||||||
let result = new_ucmd!()
|
let result = new_ucmd!()
|
||||||
.args(&["-n", &repeat_limit.to_string()])
|
.args(&["-n", &repeat_limit.to_string()])
|
||||||
.pipe_in(input.as_bytes())
|
.pipe_in(input.as_bytes())
|
||||||
.succeeds()
|
.succeeds();
|
||||||
.no_stderr()
|
result.no_stderr();
|
||||||
.stdout
|
|
||||||
.clone();
|
|
||||||
|
|
||||||
let mut result_seq: Vec<i32> = result
|
let mut result_seq: Vec<i32> = result
|
||||||
|
.stdout_str()
|
||||||
.split("\n")
|
.split("\n")
|
||||||
.filter(|x| !x.is_empty())
|
.filter(|x| !x.is_empty())
|
||||||
.map(|x| x.parse().unwrap())
|
.map(|x| x.parse().unwrap())
|
||||||
|
@ -99,7 +90,7 @@ fn test_head_count() {
|
||||||
assert!(
|
assert!(
|
||||||
result_seq.iter().all(|x| input_seq.contains(x)),
|
result_seq.iter().all(|x| input_seq.contains(x)),
|
||||||
"Output includes element not from input: {}",
|
"Output includes element not from input: {}",
|
||||||
result
|
result.stdout_str()
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -117,12 +108,11 @@ fn test_repeat() {
|
||||||
.arg("-r")
|
.arg("-r")
|
||||||
.args(&["-n", &repeat_limit.to_string()])
|
.args(&["-n", &repeat_limit.to_string()])
|
||||||
.pipe_in(input.as_bytes())
|
.pipe_in(input.as_bytes())
|
||||||
.succeeds()
|
.succeeds();
|
||||||
.no_stderr()
|
result.no_stderr();
|
||||||
.stdout
|
|
||||||
.clone();
|
|
||||||
|
|
||||||
let result_seq: Vec<i32> = result
|
let result_seq: Vec<i32> = result
|
||||||
|
.stdout_str()
|
||||||
.split("\n")
|
.split("\n")
|
||||||
.filter(|x| !x.is_empty())
|
.filter(|x| !x.is_empty())
|
||||||
.map(|x| x.parse().unwrap())
|
.map(|x| x.parse().unwrap())
|
||||||
|
@ -146,14 +136,11 @@ fn test_repeat() {
|
||||||
fn test_file_input() {
|
fn test_file_input() {
|
||||||
let expected_seq = vec![11, 12, 13, 14, 15, 16, 17, 18, 19, 20];
|
let expected_seq = vec![11, 12, 13, 14, 15, 16, 17, 18, 19, 20];
|
||||||
|
|
||||||
let result = new_ucmd!()
|
let result = new_ucmd!().arg("file_input.txt").succeeds();
|
||||||
.arg("file_input.txt")
|
result.no_stderr();
|
||||||
.succeeds()
|
|
||||||
.no_stderr()
|
|
||||||
.stdout
|
|
||||||
.clone();
|
|
||||||
|
|
||||||
let mut result_seq: Vec<i32> = result
|
let mut result_seq: Vec<i32> = result
|
||||||
|
.stdout_str()
|
||||||
.split("\n")
|
.split("\n")
|
||||||
.filter(|x| !x.is_empty())
|
.filter(|x| !x.is_empty())
|
||||||
.map(|x| x.parse().unwrap())
|
.map(|x| x.parse().unwrap())
|
||||||
|
@ -164,52 +151,50 @@ fn test_file_input() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_shuf_echo_and_input_range_not_allowed() {
|
fn test_shuf_echo_and_input_range_not_allowed() {
|
||||||
let result = new_ucmd!().args(&["-e", "0", "-i", "0-2"]).run();
|
new_ucmd!()
|
||||||
|
.args(&["-e", "0", "-i", "0-2"])
|
||||||
assert!(!result.success);
|
.fails()
|
||||||
assert!(result
|
.stderr_contains(
|
||||||
.stderr
|
"The argument '--input-range <LO-HI>' cannot be used with '--echo <ARG>...'",
|
||||||
.contains("The argument '--input-range <LO-HI>' cannot be used with '--echo <ARG>...'"));
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_shuf_input_range_and_file_not_allowed() {
|
fn test_shuf_input_range_and_file_not_allowed() {
|
||||||
let result = new_ucmd!().args(&["-i", "0-9", "file"]).run();
|
new_ucmd!()
|
||||||
|
.args(&["-i", "0-9", "file"])
|
||||||
assert!(!result.success);
|
.fails()
|
||||||
assert!(result
|
.stderr_contains("The argument '<file>' cannot be used with '--input-range <LO-HI>'");
|
||||||
.stderr
|
|
||||||
.contains("The argument '<file>' cannot be used with '--input-range <LO-HI>'"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_shuf_invalid_input_range_one() {
|
fn test_shuf_invalid_input_range_one() {
|
||||||
let result = new_ucmd!().args(&["-i", "0"]).run();
|
new_ucmd!()
|
||||||
|
.args(&["-i", "0"])
|
||||||
assert!(!result.success);
|
.fails()
|
||||||
assert!(result.stderr.contains("invalid input range"));
|
.stderr_contains("invalid input range");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_shuf_invalid_input_range_two() {
|
fn test_shuf_invalid_input_range_two() {
|
||||||
let result = new_ucmd!().args(&["-i", "a-9"]).run();
|
new_ucmd!()
|
||||||
|
.args(&["-i", "a-9"])
|
||||||
assert!(!result.success);
|
.fails()
|
||||||
assert!(result.stderr.contains("invalid input range: 'a'"));
|
.stderr_contains("invalid input range: 'a'");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_shuf_invalid_input_range_three() {
|
fn test_shuf_invalid_input_range_three() {
|
||||||
let result = new_ucmd!().args(&["-i", "0-b"]).run();
|
new_ucmd!()
|
||||||
|
.args(&["-i", "0-b"])
|
||||||
assert!(!result.success);
|
.fails()
|
||||||
assert!(result.stderr.contains("invalid input range: 'b'"));
|
.stderr_contains("invalid input range: 'b'");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_shuf_invalid_input_line_count() {
|
fn test_shuf_invalid_input_line_count() {
|
||||||
let result = new_ucmd!().args(&["-n", "a"]).run();
|
new_ucmd!()
|
||||||
|
.args(&["-n", "a"])
|
||||||
assert!(!result.success);
|
.fails()
|
||||||
assert!(result.stderr.contains("invalid line count: 'a'"));
|
.stderr_contains("invalid line count: 'a'");
|
||||||
}
|
}
|
||||||
|
|
|
@ -337,5 +337,5 @@ fn expected_result(args: &[&str]) -> String {
|
||||||
.env("LANGUAGE", "C")
|
.env("LANGUAGE", "C")
|
||||||
.args(args)
|
.args(args)
|
||||||
.run()
|
.run()
|
||||||
.stdout
|
.stdout_move_str()
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,18 +52,19 @@ fn test_single_non_newline_separator_before() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_invalid_input() {
|
fn test_invalid_input() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
let scene = TestScenario::new(util_name!());
|
||||||
|
let at = &scene.fixtures;
|
||||||
|
|
||||||
ucmd.arg("b")
|
scene
|
||||||
.run()
|
.ucmd()
|
||||||
.stderr
|
.arg("b")
|
||||||
.contains("tac: error: failed to open 'b' for reading");
|
.fails()
|
||||||
|
.stderr_contains("failed to open 'b' for reading: No such file or directory");
|
||||||
let (at, mut ucmd) = at_and_ucmd!();
|
|
||||||
|
|
||||||
at.mkdir("a");
|
at.mkdir("a");
|
||||||
ucmd.arg("a")
|
scene
|
||||||
.run()
|
.ucmd()
|
||||||
.stderr
|
.arg("a")
|
||||||
.contains("tac: error: failed to read 'a'");
|
.fails()
|
||||||
|
.stderr_contains("dir: read error: Invalid argument");
|
||||||
}
|
}
|
||||||
|
|
|
@ -120,19 +120,15 @@ fn test_truncate_with_set1_shorter_than_set2() {
|
||||||
#[test]
|
#[test]
|
||||||
fn missing_args_fails() {
|
fn missing_args_fails() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
let (_, mut ucmd) = at_and_ucmd!();
|
||||||
let result = ucmd.run();
|
ucmd.fails().stderr_contains("missing operand");
|
||||||
|
|
||||||
assert!(!result.success);
|
|
||||||
assert!(result.stderr.contains("missing operand"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn missing_required_second_arg_fails() {
|
fn missing_required_second_arg_fails() {
|
||||||
let (_, mut ucmd) = at_and_ucmd!();
|
let (_, mut ucmd) = at_and_ucmd!();
|
||||||
let result = ucmd.args(&["foo"]).run();
|
ucmd.args(&["foo"])
|
||||||
|
.fails()
|
||||||
assert!(!result.success);
|
.stderr_contains("missing operand after");
|
||||||
assert!(result.stderr.contains("missing operand after"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -18,33 +18,35 @@ fn test_sort_self_loop() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_no_such_file() {
|
fn test_no_such_file() {
|
||||||
let result = new_ucmd!().arg("invalid_file_txt").run();
|
new_ucmd!()
|
||||||
|
.arg("invalid_file_txt")
|
||||||
assert_eq!(true, result.stderr.contains("No such file or directory"));
|
.fails()
|
||||||
|
.stderr_contains("No such file or directory");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_version_flag() {
|
fn test_version_flag() {
|
||||||
let version_short = new_ucmd!().arg("-V").run();
|
let version_short = new_ucmd!().arg("-V").succeeds();
|
||||||
let version_long = new_ucmd!().arg("--version").run();
|
let version_long = new_ucmd!().arg("--version").succeeds();
|
||||||
|
|
||||||
assert_eq!(version_short.stdout(), version_long.stdout());
|
assert_eq!(version_short.stdout_str(), version_long.stdout_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_help_flag() {
|
fn test_help_flag() {
|
||||||
let help_short = new_ucmd!().arg("-h").run();
|
let help_short = new_ucmd!().arg("-h").succeeds();
|
||||||
let help_long = new_ucmd!().arg("--help").run();
|
let help_long = new_ucmd!().arg("--help").succeeds();
|
||||||
|
|
||||||
assert_eq!(help_short.stdout(), help_long.stdout());
|
assert_eq!(help_short.stdout_str(), help_long.stdout_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_multiple_arguments() {
|
fn test_multiple_arguments() {
|
||||||
let result = new_ucmd!()
|
new_ucmd!()
|
||||||
.arg("call_graph.txt")
|
.arg("call_graph.txt")
|
||||||
.arg("invalid_file.txt")
|
.arg("invalid_file")
|
||||||
.run();
|
.fails()
|
||||||
|
.stderr_contains(
|
||||||
assert_eq!(true, result.stderr.contains("error: Found argument 'invalid_file.txt' which wasn't expected, or isn't valid in this context"))
|
"Found argument 'invalid_file' which wasn't expected, or isn't valid in this context",
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,7 +23,7 @@ fn test_heading() {
|
||||||
for opt in vec!["-H"] {
|
for opt in vec!["-H"] {
|
||||||
// allow whitespace variation
|
// allow whitespace variation
|
||||||
// * minor whitespace differences occur between platform built-in outputs; specifically number of TABs between "TIME" and "COMMENT" may be variant
|
// * minor whitespace differences occur between platform built-in outputs; specifically number of TABs between "TIME" and "COMMENT" may be variant
|
||||||
let actual = new_ucmd!().arg(opt).run().stdout;
|
let actual = new_ucmd!().arg(opt).run().stdout_move_str();
|
||||||
let expect = expected_result(opt);
|
let expect = expected_result(opt);
|
||||||
println!("actual: {:?}", actual);
|
println!("actual: {:?}", actual);
|
||||||
println!("expect: {:?}", expect);
|
println!("expect: {:?}", expect);
|
||||||
|
@ -80,5 +80,5 @@ fn expected_result(arg: &str) -> String {
|
||||||
.env("LANGUAGE", "C")
|
.env("LANGUAGE", "C")
|
||||||
.args(&[arg])
|
.args(&[arg])
|
||||||
.run()
|
.run()
|
||||||
.stdout
|
.stdout_move_str()
|
||||||
}
|
}
|
||||||
|
|
|
@ -74,11 +74,11 @@ pub struct CmdResult {
|
||||||
code: Option<i32>,
|
code: Option<i32>,
|
||||||
/// zero-exit from running the Command?
|
/// zero-exit from running the Command?
|
||||||
/// see [`success`]
|
/// see [`success`]
|
||||||
pub success: bool,
|
success: bool,
|
||||||
/// captured standard output after running the Command
|
/// captured standard output after running the Command
|
||||||
pub stdout: String,
|
stdout: String,
|
||||||
/// captured standard error after running the Command
|
/// captured standard error after running the Command
|
||||||
pub stderr: String,
|
stderr: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl CmdResult {
|
impl CmdResult {
|
||||||
|
@ -329,14 +329,14 @@ impl CmdResult {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn stdout_matches(&self, regex: ®ex::Regex) -> &CmdResult {
|
pub fn stdout_matches(&self, regex: ®ex::Regex) -> &CmdResult {
|
||||||
if !regex.is_match(self.stdout_str()) {
|
if !regex.is_match(self.stdout_str().trim()) {
|
||||||
panic!("Stdout does not match regex:\n{}", self.stdout_str())
|
panic!("Stdout does not match regex:\n{}", self.stdout_str())
|
||||||
}
|
}
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn stdout_does_not_match(&self, regex: ®ex::Regex) -> &CmdResult {
|
pub fn stdout_does_not_match(&self, regex: ®ex::Regex) -> &CmdResult {
|
||||||
if regex.is_match(self.stdout_str()) {
|
if regex.is_match(self.stdout_str().trim()) {
|
||||||
panic!("Stdout matches regex:\n{}", self.stdout_str())
|
panic!("Stdout matches regex:\n{}", self.stdout_str())
|
||||||
}
|
}
|
||||||
self
|
self
|
||||||
|
@ -696,8 +696,11 @@ pub struct UCommand {
|
||||||
comm_string: String,
|
comm_string: String,
|
||||||
tmpd: Option<Rc<TempDir>>,
|
tmpd: Option<Rc<TempDir>>,
|
||||||
has_run: bool,
|
has_run: bool,
|
||||||
stdin: Option<Vec<u8>>,
|
|
||||||
ignore_stdin_write_error: bool,
|
ignore_stdin_write_error: bool,
|
||||||
|
stdin: Option<Stdio>,
|
||||||
|
stdout: Option<Stdio>,
|
||||||
|
stderr: Option<Stdio>,
|
||||||
|
bytes_into_stdin: Option<Vec<u8>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl UCommand {
|
impl UCommand {
|
||||||
|
@ -726,8 +729,11 @@ impl UCommand {
|
||||||
cmd
|
cmd
|
||||||
},
|
},
|
||||||
comm_string: String::from(arg.as_ref().to_str().unwrap()),
|
comm_string: String::from(arg.as_ref().to_str().unwrap()),
|
||||||
stdin: None,
|
|
||||||
ignore_stdin_write_error: false,
|
ignore_stdin_write_error: false,
|
||||||
|
bytes_into_stdin: None,
|
||||||
|
stdin: None,
|
||||||
|
stdout: None,
|
||||||
|
stderr: None,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -738,6 +744,21 @@ impl UCommand {
|
||||||
ucmd
|
ucmd
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn set_stdin<T: Into<Stdio>>(&mut self, stdin: T) -> &mut UCommand {
|
||||||
|
self.stdin = Some(stdin.into());
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn set_stdout<T: Into<Stdio>>(&mut self, stdout: T) -> &mut UCommand {
|
||||||
|
self.stdout = Some(stdout.into());
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn set_stderr<T: Into<Stdio>>(&mut self, stderr: T) -> &mut UCommand {
|
||||||
|
self.stderr = Some(stderr.into());
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
/// Add a parameter to the invocation. Path arguments are treated relative
|
/// Add a parameter to the invocation. Path arguments are treated relative
|
||||||
/// to the test environment directory.
|
/// to the test environment directory.
|
||||||
pub fn arg<S: AsRef<OsStr>>(&mut self, arg: S) -> &mut UCommand {
|
pub fn arg<S: AsRef<OsStr>>(&mut self, arg: S) -> &mut UCommand {
|
||||||
|
@ -767,10 +788,10 @@ impl UCommand {
|
||||||
|
|
||||||
/// provides stdinput to feed in to the command when spawned
|
/// provides stdinput to feed in to the command when spawned
|
||||||
pub fn pipe_in<T: Into<Vec<u8>>>(&mut self, input: T) -> &mut UCommand {
|
pub fn pipe_in<T: Into<Vec<u8>>>(&mut self, input: T) -> &mut UCommand {
|
||||||
if self.stdin.is_some() {
|
if self.bytes_into_stdin.is_some() {
|
||||||
panic!("{}", MULTIPLE_STDIN_MEANINGLESS);
|
panic!("{}", MULTIPLE_STDIN_MEANINGLESS);
|
||||||
}
|
}
|
||||||
self.stdin = Some(input.into());
|
self.bytes_into_stdin = Some(input.into());
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -784,7 +805,7 @@ impl UCommand {
|
||||||
/// This is typically useful to test non-standard workflows
|
/// This is typically useful to test non-standard workflows
|
||||||
/// like feeding something to a command that does not read it
|
/// like feeding something to a command that does not read it
|
||||||
pub fn ignore_stdin_write_error(&mut self) -> &mut UCommand {
|
pub fn ignore_stdin_write_error(&mut self) -> &mut UCommand {
|
||||||
if self.stdin.is_none() {
|
if self.bytes_into_stdin.is_none() {
|
||||||
panic!("{}", NO_STDIN_MEANINGLESS);
|
panic!("{}", NO_STDIN_MEANINGLESS);
|
||||||
}
|
}
|
||||||
self.ignore_stdin_write_error = true;
|
self.ignore_stdin_write_error = true;
|
||||||
|
@ -813,13 +834,13 @@ impl UCommand {
|
||||||
log_info("run", &self.comm_string);
|
log_info("run", &self.comm_string);
|
||||||
let mut child = self
|
let mut child = self
|
||||||
.raw
|
.raw
|
||||||
.stdin(Stdio::piped())
|
.stdin(self.stdin.take().unwrap_or_else(|| Stdio::piped()))
|
||||||
.stdout(Stdio::piped())
|
.stdout(self.stdout.take().unwrap_or_else(|| Stdio::piped()))
|
||||||
.stderr(Stdio::piped())
|
.stderr(self.stderr.take().unwrap_or_else(|| Stdio::piped()))
|
||||||
.spawn()
|
.spawn()
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
if let Some(ref input) = self.stdin {
|
if let Some(ref input) = self.bytes_into_stdin {
|
||||||
let write_result = child
|
let write_result = child
|
||||||
.stdin
|
.stdin
|
||||||
.take()
|
.take()
|
||||||
|
|
Loading…
Reference in a new issue