extern crate assert_cmd; extern crate predicates; use assert_cmd::prelude::*; use assert_fs::prelude::*; use predicates::prelude::*; use std::process::Command; #[cfg(unix)] use std::os::unix::fs; #[test] fn test_runs_okay() { cmd().assert().success(); } #[test] fn test_list_empty_directory() { cmd() .arg(tempdir().path()) .assert() .stdout(predicate::eq("")); } #[test] fn test_list_almost_all_empty_directory() { let matched = ""; cmd() .arg("--almost-all") .arg(tempdir().path()) .assert() .stdout(predicate::eq(matched)); cmd() .arg("-A") .arg(tempdir().path()) .assert() .stdout(predicate::eq(matched)); } #[test] fn test_list_all_empty_directory() { let matched = "\\.\n\\.\\.\n$"; cmd() .arg("--all") .arg(tempdir().path()) .assert() .stdout(predicate::str::is_match(matched).unwrap()); cmd() .arg("-a") .arg(tempdir().path()) .assert() .stdout(predicate::str::is_match(matched).unwrap()); } #[test] fn test_list_populated_directory() { let dir = tempdir(); dir.child("one").touch().unwrap(); dir.child("two").touch().unwrap(); cmd() .arg(dir.path()) .assert() .stdout(predicate::str::is_match("one\ntwo\n$").unwrap()); } #[test] fn test_list_almost_all_populated_directory() { let dir = tempdir(); dir.child("one").touch().unwrap(); dir.child("two").touch().unwrap(); cmd() .arg("--almost-all") .arg(dir.path()) .assert() .stdout(predicate::str::is_match("one\ntwo\n$").unwrap()); } #[test] fn test_list_all_populated_directory() { let dir = tempdir(); dir.child("one").touch().unwrap(); dir.child("two").touch().unwrap(); cmd() .arg("--all") .arg(dir.path()) .assert() .stdout(predicate::str::is_match("\\.\n\\.\\.\none\ntwo\n$").unwrap()); } #[test] fn test_list_inode_populated_directory() { let dir = tempdir(); dir.child("one").touch().unwrap(); dir.child("two").touch().unwrap(); #[cfg(unix)] let matched = "\\d+ one\n\\d+ two\n$"; #[cfg(windows)] let matched = "- one\n\\- two\n$"; cmd() .arg("--inode") .arg(dir.path()) .assert() .stdout(predicate::str::is_match(matched).unwrap()); cmd() .arg("-i") .arg(dir.path()) .assert() .stdout(predicate::str::is_match(matched).unwrap()); } #[test] fn test_list_block_inode_populated_directory() { let dir = tempdir(); dir.child("one").touch().unwrap(); dir.child("two").touch().unwrap(); #[cfg(unix)] let matched = "\\d+ one\n\\d+ two\n$"; #[cfg(windows)] let matched = "- one\n\\- two\n$"; cmd() .arg("--blocks") .arg("inode,name") .arg(dir.path()) .assert() .stdout(predicate::str::is_match(matched).unwrap()); } #[test] fn test_list_inode_with_long_ok() { let dir = tempdir(); cmd().arg("-i").arg("-l").arg(dir.path()).assert().success(); } #[cfg(unix)] #[test] fn test_list_broken_link_ok() { let dir = tempdir(); let broken_link = dir.path().join("broken-softlink"); let matched = "No such file or directory"; fs::symlink("not-existed-file", &broken_link).unwrap(); cmd() .arg(&broken_link) .assert() .stderr(predicate::str::contains(matched).not()); cmd() .arg("-l") .arg(broken_link) .assert() .stderr(predicate::str::contains(matched).not()); } #[cfg(unix)] #[test] fn test_nosymlink_on_non_long() { let dir = tempdir(); dir.child("target").touch().unwrap(); let link = dir.path().join("link"); let link_icon = "⇒"; fs::symlink("target", &link).unwrap(); cmd() .arg("-l") .arg(&link) .assert() .stdout(predicate::str::contains(link_icon)); cmd() .arg(&link) .assert() .stdout(predicate::str::contains(link_icon).not()); } #[cfg(unix)] #[test] fn test_dereference_link_right_type_and_no_link() { let dir = tempdir(); dir.child("target").touch().unwrap(); let link = dir.path().join("link"); let file_type = ".rw"; let link_icon = "⇒"; fs::symlink("target", &link).unwrap(); cmd() .arg("-l") .arg("--dereference") .arg(&link) .assert() .stdout(predicate::str::starts_with(file_type)) .stdout(predicate::str::contains(link_icon).not()); cmd() .arg("-l") .arg("-L") .arg(link) .assert() .stdout(predicate::str::starts_with(file_type)) .stdout(predicate::str::contains(link_icon).not()); } fn cmd() -> Command { Command::cargo_bin(env!("CARGO_PKG_NAME")).unwrap() } fn tempdir() -> assert_fs::TempDir { assert_fs::TempDir::new().unwrap() }