use crate::common::util::*; #[cfg(not(windows))] use std::os::unix::fs::PermissionsExt; static TEST_DIR1: &str = "mkdir_test1"; static TEST_DIR2: &str = "mkdir_test2"; static TEST_DIR3: &str = "mkdir_test3"; static TEST_DIR4: &str = "mkdir_test4/mkdir_test4_1"; static TEST_DIR5: &str = "mkdir_test5/mkdir_test5_1"; static TEST_DIR6: &str = "mkdir_test6"; static TEST_FILE7: &str = "mkdir_test7"; static TEST_DIR8: &str = "mkdir_test8/mkdir_test8_1/mkdir_test8_2"; static TEST_DIR9: &str = "mkdir_test9/../mkdir_test9_1/../mkdir_test9_2"; static TEST_DIR10: &str = "mkdir_test10/."; static TEST_DIR11: &str = "mkdir_test11/.."; #[test] fn test_mkdir_mkdir() { new_ucmd!().arg(TEST_DIR1).succeeds(); } #[test] fn test_mkdir_verbose() { let expected = "mkdir: created directory 'mkdir_test1'\n"; new_ucmd!() .arg(TEST_DIR1) .arg("-v") .run() .stdout_is(expected); } #[test] fn test_mkdir_dup_dir() { let scene = TestScenario::new(util_name!()); scene.ucmd().arg(TEST_DIR2).succeeds(); scene.ucmd().arg(TEST_DIR2).fails(); } #[test] fn test_mkdir_mode() { new_ucmd!().arg("-m").arg("755").arg(TEST_DIR3).succeeds(); } #[test] fn test_mkdir_parent() { let scene = TestScenario::new(util_name!()); scene.ucmd().arg("-p").arg(TEST_DIR4).succeeds(); scene.ucmd().arg("-p").arg(TEST_DIR4).succeeds(); scene.ucmd().arg("--parent").arg(TEST_DIR4).succeeds(); scene.ucmd().arg("--parents").arg(TEST_DIR4).succeeds(); } #[test] fn test_mkdir_no_parent() { new_ucmd!().arg(TEST_DIR5).fails(); } #[test] fn test_mkdir_dup_dir_parent() { let scene = TestScenario::new(util_name!()); scene.ucmd().arg(TEST_DIR6).succeeds(); scene.ucmd().arg("-p").arg(TEST_DIR6).succeeds(); } #[test] fn test_mkdir_dup_file() { let scene = TestScenario::new(util_name!()); scene.fixtures.touch(TEST_FILE7); scene.ucmd().arg(TEST_FILE7).fails(); // mkdir should fail for a file even if -p is specified. scene.ucmd().arg("-p").arg(TEST_FILE7).fails(); } #[test] #[cfg(not(windows))] fn test_symbolic_mode() { let (at, mut ucmd) = at_and_ucmd!(); ucmd.arg("-m").arg("a=rwx").arg(TEST_DIR1).succeeds(); let perms = at.metadata(TEST_DIR1).permissions().mode(); assert_eq!(perms, 0o40777); } #[test] #[cfg(not(windows))] fn test_symbolic_alteration() { let (at, mut ucmd) = at_and_ucmd!(); ucmd.arg("-m").arg("-w").arg(TEST_DIR1).succeeds(); let perms = at.metadata(TEST_DIR1).permissions().mode(); assert_eq!(perms, 0o40555); } #[test] #[cfg(not(windows))] fn test_multi_symbolic() { let (at, mut ucmd) = at_and_ucmd!(); ucmd.arg("-m") .arg("u=rwx,g=rx,o=") .arg(TEST_DIR1) .succeeds(); let perms = at.metadata(TEST_DIR1).permissions().mode(); assert_eq!(perms, 0o40750); } #[test] fn test_recursive_reporting() { new_ucmd!() .arg("-p") .arg("-v") .arg(TEST_DIR8) .succeeds() .stdout_contains("created directory 'mkdir_test8'") .stdout_contains("created directory 'mkdir_test8/mkdir_test8_1'") .stdout_contains("created directory 'mkdir_test8/mkdir_test8_1/mkdir_test8_2'"); new_ucmd!().arg("-v").arg(TEST_DIR8).fails().no_stdout(); new_ucmd!() .arg("-p") .arg("-v") .arg(TEST_DIR9) .succeeds() .stdout_contains("created directory 'mkdir_test9'") .stdout_contains("created directory 'mkdir_test9/../mkdir_test9_1'") .stdout_contains("created directory 'mkdir_test9/../mkdir_test9_1/../mkdir_test9_2'"); } #[test] fn test_mkdir_trailing_dot() { let scene2 = TestScenario::new("ls"); new_ucmd!() .arg("-p") .arg("-v") .arg("mkdir_test10-2") .succeeds(); new_ucmd!() .arg("-p") .arg("-v") .arg(TEST_DIR10) .succeeds() .stdout_contains("created directory 'mkdir_test10'"); new_ucmd!() .arg("-p") .arg("-v") .arg(TEST_DIR11) .succeeds() .stdout_contains("created directory 'mkdir_test11'"); let result = scene2.cmd("ls").arg("-al").run(); println!("ls dest {}", result.stdout_str()); }