From d1b2d29528b7794b41e66fc2136e395a02f8529b Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Thu, 30 May 2024 05:59:35 +0200 Subject: Merging upstream version 1.73.0+dfsg1. Signed-off-by: Daniel Baumann --- vendor/fs_extra/tests/lib.rs | 3883 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 3883 insertions(+) create mode 100644 vendor/fs_extra/tests/lib.rs (limited to 'vendor/fs_extra/tests/lib.rs') diff --git a/vendor/fs_extra/tests/lib.rs b/vendor/fs_extra/tests/lib.rs new file mode 100644 index 000000000..2d8bfd024 --- /dev/null +++ b/vendor/fs_extra/tests/lib.rs @@ -0,0 +1,3883 @@ +use std::fs::read_dir; +use std::path::Path; +use std::sync::mpsc::{self, TryRecvError}; +use std::thread; + +extern crate fs_extra; +use fs_extra::error::*; +use fs_extra::*; + +fn files_eq(file1: P, file2: Q) -> bool +where + P: AsRef, + Q: AsRef, +{ + let content1 = fs_extra::file::read_to_string(file1).unwrap(); + let content2 = fs_extra::file::read_to_string(file2).unwrap(); + content1 == content2 +} + +fn compare_dir(path_from: P, path_to: Q) -> bool +where + P: AsRef, + Q: AsRef, +{ + let mut path_to = path_to.as_ref().to_path_buf(); + match path_from.as_ref().components().last() { + None => panic!("Invalid folder from"), + Some(dir_name) => { + path_to.push(dir_name.as_os_str()); + if !path_to.exists() { + return false; + } + } + } + + for entry in read_dir(&path_from).unwrap() { + let entry = entry.unwrap(); + let path = entry.path(); + if path.is_dir() { + if !compare_dir(path, &path_to) { + return false; + } + } else { + let mut path_to = path_to.to_path_buf(); + match path.file_name() { + None => panic!("No file name"), + Some(file_name) => { + path_to.push(file_name); + if !path_to.exists() { + return false; + } else if !files_eq(&path, path_to.clone()) { + return false; + } + } + } + } + } + + true +} + +const TEST_FOLDER: &'static str = "./tests/temp/lib"; + +#[test] +fn it_copy_work() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_work"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(!dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(!sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(!file1.1.exists()); + assert!(!file2.1.exists()); + assert!(!file3.1.exists()); + assert!(!file4.1.exists()); + assert!(!file5.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let options = dir::CopyOptions::new(); + let result = copy_items(&from_paths, &path_to, &options).unwrap(); + + assert_eq!(40, result); + assert!(compare_dir(&dir1.0, &path_to)); + assert!(compare_dir(&dir2.0, &path_to)); + assert!(files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file2.0, &file2.1)); +} + +#[test] +fn it_copy_source_not_exist() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_source_not_exist"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + assert!(!dir1.0.exists()); + assert!(!dir1.1.exists()); + assert!(!dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(!sub.0.exists()); + assert!(!sub.1.exists()); + + assert!(!file1.0.exists()); + assert!(!file1.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + + let options = dir::CopyOptions::new(); + match copy_items(&from_paths, &path_to, &options) { + Ok(_) => panic!("Should be a error!"), + Err(err) => match err.kind { + ErrorKind::NotFound => {} + _ => {} + }, + }; +} + +#[test] +fn it_copy_exist_overwrite() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_exist_overwrite"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let mut options = dir::CopyOptions::new(); + options.overwrite = true; + let result = copy_items(&from_paths, &path_to, &options).unwrap(); + + assert_eq!(40, result); + assert!(compare_dir(&dir1.0, &path_to)); + assert!(compare_dir(&dir2.0, &path_to)); + assert!(files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file2.0, &file2.1)); +} + +#[test] +fn it_copy_exist_not_overwrite() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_exist_not_overwrite"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let options = dir::CopyOptions::new(); + match copy_items(&from_paths, &path_to, &options) { + Ok(_) => panic!("Should be a error!"), + Err(err) => match err.kind { + ErrorKind::AlreadyExists => {} + _ => panic!(format!("{}", err.to_string())), + }, + }; +} + +#[test] +fn it_copy_exist_skip() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_exist_skip"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let mut options = dir::CopyOptions::new(); + options.skip_exist = true; + let result = copy_items(&from_paths, &path_to, &options).unwrap(); + + assert_eq!(16, result); + assert!(!compare_dir(&dir1.0, &path_to)); + assert!(compare_dir(&dir2.0, &path_to)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file2.0, &file2.1)); +} + +#[test] +fn it_copy_exist_overwrite_and_skip_exist() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_exist_overwrite_and_skip_exist"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let mut options = dir::CopyOptions::new(); + options.overwrite = true; + options.skip_exist = true; + let result = copy_items(&from_paths, &path_to, &options).unwrap(); + + assert_eq!(40, result); + assert!(compare_dir(&dir1.0, &path_to)); + assert!(compare_dir(&dir2.0, &path_to)); + assert!(files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file2.0, &file2.1)); +} + +#[test] +fn it_copy_using_first_levels() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_using_first_levels"); + let path_to = test_dir.join("out"); + let d_level_1 = (test_dir.join("d_level_1"), path_to.join("d_level_1")); + let d_level_2 = (d_level_1.0.join("d_level_2"), d_level_1.1.join("d_level_2")); + let d_level_3 = (d_level_2.0.join("d_level_3"), d_level_2.1.join("d_level_3")); + let d_level_4 = (d_level_3.0.join("d_level_4"), d_level_3.1.join("d_level_4")); + let d_level_5 = (d_level_4.0.join("d_level_5"), d_level_4.1.join("d_level_5")); + + let d2_level_1 = (test_dir.join("d2_level_1"), path_to.join("d2_level_1")); + let d2_level_2 = ( + d_level_1.0.join("d2_level_2"), + d_level_1.1.join("d2_level_2"), + ); + let d2_level_3 = ( + d_level_2.0.join("d2_level_3"), + d_level_2.1.join("d2_level_3"), + ); + let d2_level_4 = ( + d_level_3.0.join("d2_level_4"), + d_level_3.1.join("d2_level_4"), + ); + let d2_level_5 = ( + d_level_4.0.join("d2_level_5"), + d_level_4.1.join("d2_level_5"), + ); + + let d3_level_1 = (test_dir.join("d3_level_1"), path_to.join("d3_level_1")); + + let file1 = (d_level_1.0.join("file1.txt"), d_level_1.1.join("file1.txt")); + let file2 = (d_level_2.0.join("file2.txt"), d_level_2.1.join("file2.txt")); + let file3 = (d_level_3.0.join("file3.txt"), d_level_3.1.join("file3.txt")); + let file4 = (d_level_4.0.join("file4.txt"), d_level_4.1.join("file4.txt")); + let file5 = (d_level_5.0.join("file5.txt"), d_level_5.1.join("file5.txt")); + + let file21 = ( + d2_level_1.0.join("file21.txt"), + d2_level_1.1.join("file21.txt"), + ); + let file22 = ( + d2_level_2.0.join("file22.txt"), + d2_level_2.1.join("file22.txt"), + ); + let file23 = ( + d2_level_3.0.join("file23.txt"), + d2_level_3.1.join("file23.txt"), + ); + let file24 = ( + d2_level_4.0.join("file24.txt"), + d2_level_4.1.join("file24.txt"), + ); + let file25 = ( + d2_level_5.0.join("file25.txt"), + d2_level_5.1.join("file25.txt"), + ); + + let file31 = ( + d3_level_1.0.join("file31.txt"), + d3_level_1.1.join("file31.txt"), + ); + + dir::create_all(&d_level_1.0, true).unwrap(); + dir::create_all(&d_level_2.0, true).unwrap(); + dir::create_all(&d_level_3.0, true).unwrap(); + dir::create_all(&d_level_4.0, true).unwrap(); + dir::create_all(&d_level_5.0, true).unwrap(); + dir::create_all(&path_to, true).unwrap(); + + dir::create_all(&d2_level_1.0, true).unwrap(); + dir::create_all(&d2_level_2.0, true).unwrap(); + dir::create_all(&d2_level_3.0, true).unwrap(); + dir::create_all(&d2_level_4.0, true).unwrap(); + dir::create_all(&d2_level_5.0, true).unwrap(); + + dir::create_all(&d3_level_1.0, true).unwrap(); + + assert!(path_to.exists()); + assert!(d_level_1.0.exists()); + assert!(d_level_2.0.exists()); + assert!(d_level_3.0.exists()); + assert!(d_level_4.0.exists()); + assert!(d_level_5.0.exists()); + + assert!(d2_level_1.0.exists()); + assert!(d2_level_2.0.exists()); + assert!(d2_level_3.0.exists()); + assert!(d2_level_4.0.exists()); + assert!(d2_level_5.0.exists()); + + assert!(d3_level_1.0.exists()); + + assert!(!d_level_1.1.exists()); + assert!(!d_level_2.1.exists()); + assert!(!d_level_3.1.exists()); + assert!(!d_level_4.1.exists()); + assert!(!d_level_5.1.exists()); + + assert!(!d2_level_1.1.exists()); + assert!(!d2_level_2.1.exists()); + assert!(!d2_level_3.1.exists()); + assert!(!d2_level_4.1.exists()); + assert!(!d2_level_5.1.exists()); + + assert!(!d3_level_1.1.exists()); + + fs_extra::file::write_all(&file1.0, "content1").unwrap(); + fs_extra::file::write_all(&file2.0, "content2").unwrap(); + fs_extra::file::write_all(&file3.0, "content3").unwrap(); + fs_extra::file::write_all(&file4.0, "content4").unwrap(); + fs_extra::file::write_all(&file5.0, "content5").unwrap(); + + fs_extra::file::write_all(&file21.0, "2content1").unwrap(); + fs_extra::file::write_all(&file22.0, "2content2").unwrap(); + fs_extra::file::write_all(&file23.0, "2content3").unwrap(); + fs_extra::file::write_all(&file24.0, "2content4").unwrap(); + fs_extra::file::write_all(&file25.0, "2content5").unwrap(); + + fs_extra::file::write_all(&file31.0, "3content1").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + + assert!(file21.0.exists()); + assert!(file22.0.exists()); + assert!(file23.0.exists()); + assert!(file24.0.exists()); + assert!(file25.0.exists()); + + assert!(file31.0.exists()); + + assert!(!file1.1.exists()); + assert!(!file2.1.exists()); + assert!(!file3.1.exists()); + assert!(!file4.1.exists()); + assert!(!file5.1.exists()); + + assert!(!file21.1.exists()); + assert!(!file22.1.exists()); + assert!(!file23.1.exists()); + assert!(!file24.1.exists()); + assert!(!file25.1.exists()); + + assert!(!file31.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(d_level_1.0.as_path()); + from_paths.push(d2_level_1.0.as_path()); + from_paths.push(d3_level_1.0.as_path()); + + let mut options = dir::CopyOptions::new(); + options.depth = 1; + let result = copy_items(&from_paths, path_to, &options).unwrap(); + + assert_eq!(26, result); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + + assert!(file21.0.exists()); + assert!(file22.0.exists()); + assert!(file23.0.exists()); + assert!(file24.0.exists()); + assert!(file25.0.exists()); + + assert!(file31.0.exists()); + + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(!file3.1.exists()); + assert!(!file4.1.exists()); + assert!(!file5.1.exists()); + + assert!(file21.1.exists()); + assert!(!file22.1.exists()); + assert!(!file23.1.exists()); + assert!(!file24.1.exists()); + assert!(!file25.1.exists()); + + assert!(file31.1.exists()); + assert!(files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file21.0, &file21.1)); + assert!(files_eq(&file31.0, &file31.1)); +} + +#[test] +fn it_copy_using_four_levels() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_using_four_levels"); + let path_to = test_dir.join("out"); + let d_level_1 = (test_dir.join("d_level_1"), path_to.join("d_level_1")); + let d_level_2 = (d_level_1.0.join("d_level_2"), d_level_1.1.join("d_level_2")); + let d_level_3 = (d_level_2.0.join("d_level_3"), d_level_2.1.join("d_level_3")); + let d_level_4 = (d_level_3.0.join("d_level_4"), d_level_3.1.join("d_level_4")); + let d_level_5 = (d_level_4.0.join("d_level_5"), d_level_4.1.join("d_level_5")); + + let d2_level_1 = (test_dir.join("d2_level_1"), path_to.join("d2_level_1")); + let d2_level_2 = ( + d_level_1.0.join("d2_level_2"), + d_level_1.1.join("d2_level_2"), + ); + let d2_level_3 = ( + d_level_2.0.join("d2_level_3"), + d_level_2.1.join("d2_level_3"), + ); + let d2_level_4 = ( + d_level_3.0.join("d2_level_4"), + d_level_3.1.join("d2_level_4"), + ); + let d2_level_5 = ( + d_level_4.0.join("d2_level_5"), + d_level_4.1.join("d2_level_5"), + ); + + let d3_level_1 = (test_dir.join("d3_level_1"), path_to.join("d3_level_1")); + + let file1 = (d_level_1.0.join("file1.txt"), d_level_1.1.join("file1.txt")); + let file2 = (d_level_2.0.join("file2.txt"), d_level_2.1.join("file2.txt")); + let file3 = (d_level_3.0.join("file3.txt"), d_level_3.1.join("file3.txt")); + let file4 = (d_level_4.0.join("file4.txt"), d_level_4.1.join("file4.txt")); + let file5 = (d_level_5.0.join("file5.txt"), d_level_5.1.join("file5.txt")); + + let file21 = ( + d2_level_1.0.join("file21.txt"), + d2_level_1.1.join("file21.txt"), + ); + let file22 = ( + d2_level_2.0.join("file22.txt"), + d2_level_2.1.join("file22.txt"), + ); + let file23 = ( + d2_level_3.0.join("file23.txt"), + d2_level_3.1.join("file23.txt"), + ); + let file24 = ( + d2_level_4.0.join("file24.txt"), + d2_level_4.1.join("file24.txt"), + ); + let file25 = ( + d2_level_5.0.join("file25.txt"), + d2_level_5.1.join("file25.txt"), + ); + + let file31 = ( + d3_level_1.0.join("file31.txt"), + d3_level_1.1.join("file31.txt"), + ); + + dir::create_all(&d_level_1.0, true).unwrap(); + dir::create_all(&d_level_2.0, true).unwrap(); + dir::create_all(&d_level_3.0, true).unwrap(); + dir::create_all(&d_level_4.0, true).unwrap(); + dir::create_all(&d_level_5.0, true).unwrap(); + dir::create_all(&path_to, true).unwrap(); + + dir::create_all(&d2_level_1.0, true).unwrap(); + dir::create_all(&d2_level_2.0, true).unwrap(); + dir::create_all(&d2_level_3.0, true).unwrap(); + dir::create_all(&d2_level_4.0, true).unwrap(); + dir::create_all(&d2_level_5.0, true).unwrap(); + + dir::create_all(&d3_level_1.0, true).unwrap(); + + assert!(path_to.exists()); + assert!(d_level_1.0.exists()); + assert!(d_level_2.0.exists()); + assert!(d_level_3.0.exists()); + assert!(d_level_4.0.exists()); + assert!(d_level_5.0.exists()); + + assert!(d2_level_1.0.exists()); + assert!(d2_level_2.0.exists()); + assert!(d2_level_3.0.exists()); + assert!(d2_level_4.0.exists()); + assert!(d2_level_5.0.exists()); + + assert!(d3_level_1.0.exists()); + + assert!(!d_level_1.1.exists()); + assert!(!d_level_2.1.exists()); + assert!(!d_level_3.1.exists()); + assert!(!d_level_4.1.exists()); + assert!(!d_level_5.1.exists()); + + assert!(!d2_level_1.1.exists()); + assert!(!d2_level_2.1.exists()); + assert!(!d2_level_3.1.exists()); + assert!(!d2_level_4.1.exists()); + assert!(!d2_level_5.1.exists()); + + assert!(!d3_level_1.1.exists()); + + fs_extra::file::write_all(&file1.0, "content1").unwrap(); + fs_extra::file::write_all(&file2.0, "content2").unwrap(); + fs_extra::file::write_all(&file3.0, "content3").unwrap(); + fs_extra::file::write_all(&file4.0, "content4").unwrap(); + fs_extra::file::write_all(&file5.0, "content5").unwrap(); + + fs_extra::file::write_all(&file21.0, "2content1").unwrap(); + fs_extra::file::write_all(&file22.0, "2content2").unwrap(); + fs_extra::file::write_all(&file23.0, "2content3").unwrap(); + fs_extra::file::write_all(&file24.0, "2content4").unwrap(); + fs_extra::file::write_all(&file25.0, "2content5").unwrap(); + + fs_extra::file::write_all(&file31.0, "3content1").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + + assert!(file21.0.exists()); + assert!(file22.0.exists()); + assert!(file23.0.exists()); + assert!(file24.0.exists()); + assert!(file25.0.exists()); + + assert!(file31.0.exists()); + + assert!(!file1.1.exists()); + assert!(!file2.1.exists()); + assert!(!file3.1.exists()); + assert!(!file4.1.exists()); + assert!(!file5.1.exists()); + + assert!(!file21.1.exists()); + assert!(!file22.1.exists()); + assert!(!file23.1.exists()); + assert!(!file24.1.exists()); + assert!(!file25.1.exists()); + + assert!(!file31.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(d_level_1.0.as_path()); + from_paths.push(d2_level_1.0.as_path()); + from_paths.push(d3_level_1.0.as_path()); + + let mut options = dir::CopyOptions::new(); + options.depth = 4; + let result = copy_items(&from_paths, path_to, &options).unwrap(); + + assert_eq!(77, result); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + + assert!(file21.0.exists()); + assert!(file22.0.exists()); + assert!(file23.0.exists()); + assert!(file24.0.exists()); + assert!(file25.0.exists()); + + assert!(file31.0.exists()); + + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + assert!(file21.1.exists()); + assert!(file22.1.exists()); + assert!(file23.1.exists()); + assert!(file24.1.exists()); + assert!(!file25.1.exists()); + + assert!(file31.1.exists()); + assert!(files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file21.0, &file21.1)); + assert!(files_eq(&file31.0, &file31.1)); +} +#[test] + +fn it_copy_content_only_opton() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_content_only_opton"); + let path_to = test_dir.join("out"); + + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + + let mut options = dir::CopyOptions::new(); + options.content_only = true; + match copy_items(&vec![&file1.0], &file1.1, &options) { + Err(err) => match err.kind { + ErrorKind::Other => { + assert_eq!(1, 1); + } + _ => { + panic!(format!("wrong error {}", err.to_string())); + } + }, + Ok(_) => { + panic!("should be error"); + } + } +} + +#[test] +fn it_copy_progress_work() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_progress_work"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(!dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(!sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content22").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(!file1.1.exists()); + assert!(!file2.1.exists()); + assert!(!file3.1.exists()); + assert!(!file4.1.exists()); + assert!(!file5.1.exists()); + + let options = dir::CopyOptions::new(); + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let func_test = |process_info: TransitProcess| { + tx.send(process_info).unwrap(); + dir::TransitProcessResult::ContinueOrAbort + }; + let result = copy_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + + assert_eq!(41, result); + assert!(compare_dir(&dir1.0, &path_to)); + assert!(compare_dir(&dir2.0, &path_to)); + assert!(files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file2.0, &file2.1)); + }) + .join(); + + loop { + match rx.try_recv() { + Ok(process_info) => { + if process_info.file_name == "file2.txt" { + assert_eq!(9, process_info.file_total_bytes); + assert_eq!(41, process_info.total_bytes); + } else if process_info.file_name == "file1.txt" { + assert_eq!(8, process_info.file_total_bytes); + assert_eq!(41, process_info.total_bytes); + } + } + Err(TryRecvError::Disconnected) => { + break; + } + Err(TryRecvError::Empty) => {} + } + } + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } +} + +#[test] +fn it_copy_with_progress_work_dif_buf_size() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_with_progress_work_dif_buf_size"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(!dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(!sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(!file1.1.exists()); + assert!(!file2.1.exists()); + assert!(!file3.1.exists()); + assert!(!file4.1.exists()); + assert!(!file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + options.buffer_size = 1; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut from_paths = Vec::new(); + from_paths.push(file1.0.as_path().to_str().unwrap().to_string()); + from_paths.push(file2.0.as_path().to_str().unwrap().to_string()); + from_paths.push(dir1.0.as_path().to_str().unwrap().to_string()); + from_paths.push(dir2.0.as_path().to_str().unwrap().to_string()); + + let func_test = |process_info: TransitProcess| { + tx.send(process_info).unwrap(); + dir::TransitProcessResult::ContinueOrAbort + }; + + let result = copy_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + + assert_eq!(40, result); + assert!(compare_dir(&dir1.0, &path_to)); + assert!(compare_dir(&dir2.0, &path_to)); + assert!(files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file2.0, &file2.1)); + + let mut options = dir::CopyOptions::new(); + options.buffer_size = 2; + options.overwrite = true; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let func_test = |process_info: TransitProcess| { + tx.send(process_info).unwrap(); + dir::TransitProcessResult::ContinueOrAbort + }; + let result = + copy_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + + assert_eq!(40, result); + assert!(compare_dir(&dir1.0, &path_to)); + assert!(compare_dir(&dir2.0, &path_to)); + assert!(files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file2.0, &file2.1)); + }) + .join(); + for i in 1..5 { + let process_info: TransitProcess = rx.recv().unwrap(); + assert_eq!(i * 2, process_info.file_bytes_copied); + assert_eq!(i * 2, process_info.copied_bytes); + assert_eq!(8, process_info.file_total_bytes); + assert_eq!(40, process_info.total_bytes); + } + for i in 1..5 { + let process_info: TransitProcess = rx.recv().unwrap(); + assert_eq!(i * 2 + 8, process_info.copied_bytes); + assert_eq!(i * 2, process_info.file_bytes_copied); + assert_eq!(8, process_info.file_total_bytes); + assert_eq!(40, process_info.total_bytes); + } + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + }) + .join(); + + for i in 1..9 { + let process_info: TransitProcess = rx.recv().unwrap(); + assert_eq!(i, process_info.file_bytes_copied); + assert_eq!(i, process_info.copied_bytes); + assert_eq!(8, process_info.file_total_bytes); + assert_eq!(40, process_info.total_bytes); + } + for i in 1..9 { + let process_info: TransitProcess = rx.recv().unwrap(); + assert_eq!(i + 8, process_info.copied_bytes); + assert_eq!(i, process_info.file_bytes_copied); + assert_eq!(8, process_info.file_total_bytes); + assert_eq!(40, process_info.total_bytes); + } + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } +} + +#[test] +fn it_copy_with_progress_source_not_exist() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_with_progress_source_not_exist"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + assert!(!dir1.0.exists()); + assert!(!dir1.1.exists()); + assert!(!dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(!sub.0.exists()); + assert!(!sub.1.exists()); + + assert!(!file1.0.exists()); + assert!(!file1.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + + let func_test = |process_info: TransitProcess| { + println!("{}", process_info.total_bytes); + dir::TransitProcessResult::ContinueOrAbort + }; + + let options = dir::CopyOptions::new(); + match copy_items_with_progress(&from_paths, &path_to, &options, func_test) { + Ok(_) => panic!("Should be a error!"), + Err(err) => match err.kind { + ErrorKind::NotFound => {} + _ => {} + }, + }; +} + +#[test] +fn it_copy_with_progress_exist_overwrite() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_with_progress_exist_overwrite"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + options.overwrite = true; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let func_test = |process_info: TransitProcess| { + tx.send(process_info).unwrap(); + dir::TransitProcessResult::ContinueOrAbort + }; + + let result = copy_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + + assert_eq!(40, result); + assert!(compare_dir(&dir1.0, &path_to)); + assert!(compare_dir(&dir2.0, &path_to)); + assert!(files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file2.0, &file2.1)); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + + match rx.recv() { + Err(_) => panic!("Errors should not be!"), + _ => {} + } +} + +#[test] +fn it_copy_with_progress_exist_not_overwrite() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_with_progress_exist_not_overwrite"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let options = dir::CopyOptions::new(); + let func_test = |process_info: TransitProcess| { + println!("{}", process_info.total_bytes); + dir::TransitProcessResult::ContinueOrAbort + }; + + match copy_items_with_progress(&from_paths, &path_to, &options, func_test) { + Ok(_) => panic!("Should be a error!"), + Err(err) => match err.kind { + ErrorKind::AlreadyExists => {} + _ => panic!(format!("{}", err.to_string())), + }, + }; +} + +#[test] +fn it_copy_with_progress_exist_skip_exist() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_with_progress_exist_skip_exist"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + options.skip_exist = true; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let func_test = |process_info: TransitProcess| { + tx.send(process_info).unwrap(); + dir::TransitProcessResult::ContinueOrAbort + }; + + let result = copy_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + + assert_eq!(16, result); + assert!(!compare_dir(&dir1.0, &path_to)); + assert!(compare_dir(&dir2.0, &path_to)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file2.0, &file2.1)); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + + match rx.recv() { + Err(_) => panic!("Errors should not be!"), + _ => {} + } +} + +#[test] +fn it_copy_with_progress_exist_overwrite_and_skip_exist() { + let test_dir = + Path::new(TEST_FOLDER).join("it_copy_with_progress_exist_overwrite_and_skip_exist"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + options.overwrite = true; + options.skip_exist = true; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let func_test = |process_info: TransitProcess| { + tx.send(process_info).unwrap(); + dir::TransitProcessResult::ContinueOrAbort + }; + + let result = copy_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + + assert_eq!(40, result); + assert!(compare_dir(&dir1.0, &path_to)); + assert!(compare_dir(&dir2.0, &path_to)); + assert!(files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file2.0, &file2.1)); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + + match rx.recv() { + Err(_) => panic!("Errors should not be!"), + _ => {} + } +} + +#[test] +fn it_copy_with_progress_using_first_levels() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_with_progress_using_first_levels"); + let path_to = test_dir.join("out"); + let d_level_1 = (test_dir.join("d_level_1"), path_to.join("d_level_1")); + let d_level_2 = (d_level_1.0.join("d_level_2"), d_level_1.1.join("d_level_2")); + let d_level_3 = (d_level_2.0.join("d_level_3"), d_level_2.1.join("d_level_3")); + let d_level_4 = (d_level_3.0.join("d_level_4"), d_level_3.1.join("d_level_4")); + let d_level_5 = (d_level_4.0.join("d_level_5"), d_level_4.1.join("d_level_5")); + + let d2_level_1 = (test_dir.join("d2_level_1"), path_to.join("d2_level_1")); + let d2_level_2 = ( + d_level_1.0.join("d2_level_2"), + d_level_1.1.join("d2_level_2"), + ); + let d2_level_3 = ( + d_level_2.0.join("d2_level_3"), + d_level_2.1.join("d2_level_3"), + ); + let d2_level_4 = ( + d_level_3.0.join("d2_level_4"), + d_level_3.1.join("d2_level_4"), + ); + let d2_level_5 = ( + d_level_4.0.join("d2_level_5"), + d_level_4.1.join("d2_level_5"), + ); + + let d3_level_1 = (test_dir.join("d3_level_1"), path_to.join("d3_level_1")); + + let file1 = (d_level_1.0.join("file1.txt"), d_level_1.1.join("file1.txt")); + let file2 = (d_level_2.0.join("file2.txt"), d_level_2.1.join("file2.txt")); + let file3 = (d_level_3.0.join("file3.txt"), d_level_3.1.join("file3.txt")); + let file4 = (d_level_4.0.join("file4.txt"), d_level_4.1.join("file4.txt")); + let file5 = (d_level_5.0.join("file5.txt"), d_level_5.1.join("file5.txt")); + + let file21 = ( + d2_level_1.0.join("file21.txt"), + d2_level_1.1.join("file21.txt"), + ); + let file22 = ( + d2_level_2.0.join("file22.txt"), + d2_level_2.1.join("file22.txt"), + ); + let file23 = ( + d2_level_3.0.join("file23.txt"), + d2_level_3.1.join("file23.txt"), + ); + let file24 = ( + d2_level_4.0.join("file24.txt"), + d2_level_4.1.join("file24.txt"), + ); + let file25 = ( + d2_level_5.0.join("file25.txt"), + d2_level_5.1.join("file25.txt"), + ); + + let file31 = ( + d3_level_1.0.join("file31.txt"), + d3_level_1.1.join("file31.txt"), + ); + + dir::create_all(&d_level_1.0, true).unwrap(); + dir::create_all(&d_level_2.0, true).unwrap(); + dir::create_all(&d_level_3.0, true).unwrap(); + dir::create_all(&d_level_4.0, true).unwrap(); + dir::create_all(&d_level_5.0, true).unwrap(); + dir::create_all(&path_to, true).unwrap(); + + dir::create_all(&d2_level_1.0, true).unwrap(); + dir::create_all(&d2_level_2.0, true).unwrap(); + dir::create_all(&d2_level_3.0, true).unwrap(); + dir::create_all(&d2_level_4.0, true).unwrap(); + dir::create_all(&d2_level_5.0, true).unwrap(); + + dir::create_all(&d3_level_1.0, true).unwrap(); + + assert!(path_to.exists()); + assert!(d_level_1.0.exists()); + assert!(d_level_2.0.exists()); + assert!(d_level_3.0.exists()); + assert!(d_level_4.0.exists()); + assert!(d_level_5.0.exists()); + + assert!(d2_level_1.0.exists()); + assert!(d2_level_2.0.exists()); + assert!(d2_level_3.0.exists()); + assert!(d2_level_4.0.exists()); + assert!(d2_level_5.0.exists()); + + assert!(d3_level_1.0.exists()); + + assert!(!d_level_1.1.exists()); + assert!(!d_level_2.1.exists()); + assert!(!d_level_3.1.exists()); + assert!(!d_level_4.1.exists()); + assert!(!d_level_5.1.exists()); + + assert!(!d2_level_1.1.exists()); + assert!(!d2_level_2.1.exists()); + assert!(!d2_level_3.1.exists()); + assert!(!d2_level_4.1.exists()); + assert!(!d2_level_5.1.exists()); + + assert!(!d3_level_1.1.exists()); + + fs_extra::file::write_all(&file1.0, "content1").unwrap(); + fs_extra::file::write_all(&file2.0, "content2").unwrap(); + fs_extra::file::write_all(&file3.0, "content3").unwrap(); + fs_extra::file::write_all(&file4.0, "content4").unwrap(); + fs_extra::file::write_all(&file5.0, "content5").unwrap(); + + fs_extra::file::write_all(&file21.0, "2content1").unwrap(); + fs_extra::file::write_all(&file22.0, "2content2").unwrap(); + fs_extra::file::write_all(&file23.0, "2content3").unwrap(); + fs_extra::file::write_all(&file24.0, "2content4").unwrap(); + fs_extra::file::write_all(&file25.0, "2content5").unwrap(); + + fs_extra::file::write_all(&file31.0, "3content1").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + + assert!(file21.0.exists()); + assert!(file22.0.exists()); + assert!(file23.0.exists()); + assert!(file24.0.exists()); + assert!(file25.0.exists()); + + assert!(file31.0.exists()); + + assert!(!file1.1.exists()); + assert!(!file2.1.exists()); + assert!(!file3.1.exists()); + assert!(!file4.1.exists()); + assert!(!file5.1.exists()); + + assert!(!file21.1.exists()); + assert!(!file22.1.exists()); + assert!(!file23.1.exists()); + assert!(!file24.1.exists()); + assert!(!file25.1.exists()); + + assert!(!file31.1.exists()); + + let mut options = dir::CopyOptions::new(); + options.depth = 1; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut from_paths = Vec::new(); + from_paths.push(d_level_1.0.as_path()); + from_paths.push(d2_level_1.0.as_path()); + from_paths.push(d3_level_1.0.as_path()); + + let func_test = |process_info: TransitProcess| { + tx.send(process_info).unwrap(); + dir::TransitProcessResult::ContinueOrAbort + }; + + let result = copy_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + + assert_eq!(26, result); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + + assert!(file21.0.exists()); + assert!(file22.0.exists()); + assert!(file23.0.exists()); + assert!(file24.0.exists()); + assert!(file25.0.exists()); + + assert!(file31.0.exists()); + + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(!file3.1.exists()); + assert!(!file4.1.exists()); + assert!(!file5.1.exists()); + + assert!(file21.1.exists()); + assert!(!file22.1.exists()); + assert!(!file23.1.exists()); + assert!(!file24.1.exists()); + assert!(!file25.1.exists()); + + assert!(file31.1.exists()); + assert!(files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file21.0, &file21.1)); + assert!(files_eq(&file31.0, &file31.1)); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + + match rx.recv() { + Err(_) => panic!("Errors should not be!"), + _ => {} + } +} + +#[test] +fn it_copy_with_progress_using_four_levels() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_with_progress_using_four_levels"); + let path_to = test_dir.join("out"); + let d_level_1 = (test_dir.join("d_level_1"), path_to.join("d_level_1")); + let d_level_2 = (d_level_1.0.join("d_level_2"), d_level_1.1.join("d_level_2")); + let d_level_3 = (d_level_2.0.join("d_level_3"), d_level_2.1.join("d_level_3")); + let d_level_4 = (d_level_3.0.join("d_level_4"), d_level_3.1.join("d_level_4")); + let d_level_5 = (d_level_4.0.join("d_level_5"), d_level_4.1.join("d_level_5")); + + let d2_level_1 = (test_dir.join("d2_level_1"), path_to.join("d2_level_1")); + let d2_level_2 = ( + d_level_1.0.join("d2_level_2"), + d_level_1.1.join("d2_level_2"), + ); + let d2_level_3 = ( + d_level_2.0.join("d2_level_3"), + d_level_2.1.join("d2_level_3"), + ); + let d2_level_4 = ( + d_level_3.0.join("d2_level_4"), + d_level_3.1.join("d2_level_4"), + ); + let d2_level_5 = ( + d_level_4.0.join("d2_level_5"), + d_level_4.1.join("d2_level_5"), + ); + + let d3_level_1 = (test_dir.join("d3_level_1"), path_to.join("d3_level_1")); + + let file1 = (d_level_1.0.join("file1.txt"), d_level_1.1.join("file1.txt")); + let file2 = (d_level_2.0.join("file2.txt"), d_level_2.1.join("file2.txt")); + let file3 = (d_level_3.0.join("file3.txt"), d_level_3.1.join("file3.txt")); + let file4 = (d_level_4.0.join("file4.txt"), d_level_4.1.join("file4.txt")); + let file5 = (d_level_5.0.join("file5.txt"), d_level_5.1.join("file5.txt")); + + let file21 = ( + d2_level_1.0.join("file21.txt"), + d2_level_1.1.join("file21.txt"), + ); + let file22 = ( + d2_level_2.0.join("file22.txt"), + d2_level_2.1.join("file22.txt"), + ); + let file23 = ( + d2_level_3.0.join("file23.txt"), + d2_level_3.1.join("file23.txt"), + ); + let file24 = ( + d2_level_4.0.join("file24.txt"), + d2_level_4.1.join("file24.txt"), + ); + let file25 = ( + d2_level_5.0.join("file25.txt"), + d2_level_5.1.join("file25.txt"), + ); + + let file31 = ( + d3_level_1.0.join("file31.txt"), + d3_level_1.1.join("file31.txt"), + ); + + dir::create_all(&d_level_1.0, true).unwrap(); + dir::create_all(&d_level_2.0, true).unwrap(); + dir::create_all(&d_level_3.0, true).unwrap(); + dir::create_all(&d_level_4.0, true).unwrap(); + dir::create_all(&d_level_5.0, true).unwrap(); + dir::create_all(&path_to, true).unwrap(); + + dir::create_all(&d2_level_1.0, true).unwrap(); + dir::create_all(&d2_level_2.0, true).unwrap(); + dir::create_all(&d2_level_3.0, true).unwrap(); + dir::create_all(&d2_level_4.0, true).unwrap(); + dir::create_all(&d2_level_5.0, true).unwrap(); + + dir::create_all(&d3_level_1.0, true).unwrap(); + + assert!(path_to.exists()); + assert!(d_level_1.0.exists()); + assert!(d_level_2.0.exists()); + assert!(d_level_3.0.exists()); + assert!(d_level_4.0.exists()); + assert!(d_level_5.0.exists()); + + assert!(d2_level_1.0.exists()); + assert!(d2_level_2.0.exists()); + assert!(d2_level_3.0.exists()); + assert!(d2_level_4.0.exists()); + assert!(d2_level_5.0.exists()); + + assert!(d3_level_1.0.exists()); + + assert!(!d_level_1.1.exists()); + assert!(!d_level_2.1.exists()); + assert!(!d_level_3.1.exists()); + assert!(!d_level_4.1.exists()); + assert!(!d_level_5.1.exists()); + + assert!(!d2_level_1.1.exists()); + assert!(!d2_level_2.1.exists()); + assert!(!d2_level_3.1.exists()); + assert!(!d2_level_4.1.exists()); + assert!(!d2_level_5.1.exists()); + + assert!(!d3_level_1.1.exists()); + + fs_extra::file::write_all(&file1.0, "content1").unwrap(); + fs_extra::file::write_all(&file2.0, "content2").unwrap(); + fs_extra::file::write_all(&file3.0, "content3").unwrap(); + fs_extra::file::write_all(&file4.0, "content4").unwrap(); + fs_extra::file::write_all(&file5.0, "content5").unwrap(); + + fs_extra::file::write_all(&file21.0, "2content1").unwrap(); + fs_extra::file::write_all(&file22.0, "2content2").unwrap(); + fs_extra::file::write_all(&file23.0, "2content3").unwrap(); + fs_extra::file::write_all(&file24.0, "2content4").unwrap(); + fs_extra::file::write_all(&file25.0, "2content5").unwrap(); + + fs_extra::file::write_all(&file31.0, "3content1").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + + assert!(file21.0.exists()); + assert!(file22.0.exists()); + assert!(file23.0.exists()); + assert!(file24.0.exists()); + assert!(file25.0.exists()); + + assert!(file31.0.exists()); + + assert!(!file1.1.exists()); + assert!(!file2.1.exists()); + assert!(!file3.1.exists()); + assert!(!file4.1.exists()); + assert!(!file5.1.exists()); + + assert!(!file21.1.exists()); + assert!(!file22.1.exists()); + assert!(!file23.1.exists()); + assert!(!file24.1.exists()); + assert!(!file25.1.exists()); + + assert!(!file31.1.exists()); + + let mut options = dir::CopyOptions::new(); + options.depth = 4; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut from_paths = Vec::new(); + from_paths.push(d_level_1.0.as_path()); + from_paths.push(d2_level_1.0.as_path()); + from_paths.push(d3_level_1.0.as_path()); + + let func_test = |process_info: TransitProcess| { + tx.send(process_info).unwrap(); + dir::TransitProcessResult::ContinueOrAbort + }; + + let result = copy_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + + assert_eq!(77, result); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + + assert!(file21.0.exists()); + assert!(file22.0.exists()); + assert!(file23.0.exists()); + assert!(file24.0.exists()); + assert!(file25.0.exists()); + + assert!(file31.0.exists()); + + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + assert!(file21.1.exists()); + assert!(file22.1.exists()); + assert!(file23.1.exists()); + assert!(file24.1.exists()); + assert!(!file25.1.exists()); + + assert!(file31.1.exists()); + assert!(files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file21.0, &file21.1)); + assert!(files_eq(&file31.0, &file31.1)); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + + match rx.recv() { + Err(_) => panic!("Errors should not be!"), + _ => {} + } +} + +#[test] +fn it_copy_with_progress_content_only_opton() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_with_progress_content_only_opton"); + let path_to = test_dir.join("out"); + + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + + let mut options = dir::CopyOptions::new(); + options.content_only = true; + let func_test = |process_info: TransitProcess| { + println!("{}", process_info.total_bytes); + dir::TransitProcessResult::ContinueOrAbort + }; + match copy_items_with_progress(&vec![&file1.0], &file1.1, &options, func_test) { + Ok(_) => panic!("Should be a error!"), + Err(err) => match err.kind { + ErrorKind::Other => {} + _ => panic!(format!("wrong error {}", err.to_string())), + }, + }; +} + +#[test] +fn it_move_work() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_work"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(!dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(!sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(!file1.1.exists()); + assert!(!file2.1.exists()); + assert!(!file3.1.exists()); + assert!(!file4.1.exists()); + assert!(!file5.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let options = dir::CopyOptions::new(); + let result = move_items(&from_paths, &path_to, &options).unwrap(); + + assert_eq!(40, result); + assert!(!file1.0.exists()); + assert!(!file2.0.exists()); + assert!(!file3.0.exists()); + assert!(!file4.0.exists()); + assert!(!file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); +} + +#[test] +fn it_move_source_not_exist() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_source_not_exist"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + assert!(!dir1.0.exists()); + assert!(!dir1.1.exists()); + assert!(!dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(!sub.0.exists()); + assert!(!sub.1.exists()); + + assert!(!file1.0.exists()); + assert!(!file1.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + + let options = dir::CopyOptions::new(); + match move_items(&from_paths, &path_to, &options) { + Ok(_) => panic!("Should be a error!"), + Err(err) => match err.kind { + ErrorKind::NotFound => {} + _ => {} + }, + }; +} + +#[test] +fn it_move_exist_overwrite() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_exist_overwrite"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let mut options = dir::CopyOptions::new(); + options.overwrite = true; + let result = move_items(&from_paths, &path_to, &options).unwrap(); + + assert_eq!(40, result); + assert!(!file1.0.exists()); + assert!(!file2.0.exists()); + assert!(!file3.0.exists()); + assert!(!file4.0.exists()); + assert!(!file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); +} + +#[test] +fn it_move_exist_not_overwrite() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_exist_not_overwrite"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let options = dir::CopyOptions::new(); + match move_items(&from_paths, &path_to, &options) { + Ok(_) => panic!("Should be a error!"), + Err(err) => match err.kind { + ErrorKind::AlreadyExists => {} + _ => panic!(format!("{}", err.to_string())), + }, + }; +} + +#[test] +fn it_move_exist_skip() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_exist_skip"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let mut options = dir::CopyOptions::new(); + options.skip_exist = true; + let result = move_items(&from_paths, &path_to, &options).unwrap(); + + assert_eq!(16, result); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(!file2.0.exists()); + assert!(!files_eq(&file3.0, &file3.1)); + assert!(!files_eq(&file4.0, &file4.1)); + assert!(!file5.0.exists()); +} + +#[test] +fn it_move_exist_overwrite_and_skip_exist() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_exist_overwrite_and_skip_exist"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let mut options = dir::CopyOptions::new(); + options.overwrite = true; + options.skip_exist = true; + let result = move_items(&from_paths, &path_to, &options).unwrap(); + + assert_eq!(40, result); + assert!(!file1.0.exists()); + assert!(!file2.0.exists()); + assert!(!file3.0.exists()); + assert!(!file4.0.exists()); + assert!(!file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); +} +#[test] +fn it_move_content_only_option() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_content_only_option"); + let path_to = test_dir.join("out"); + + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + + let mut options = dir::CopyOptions::new(); + options.content_only = true; + match move_items(&vec![&file1.0], &file1.1, &options) { + Err(err) => match err.kind { + ErrorKind::Other => { + assert_eq!(1, 1); + } + _ => { + panic!(format!("wrong error {}", err.to_string())); + } + }, + Ok(_) => { + panic!("should be error"); + } + } +} + +#[test] +fn it_move_progress_work() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_progress_work"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(!dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(!sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content22").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(!file1.1.exists()); + assert!(!file2.1.exists()); + assert!(!file3.1.exists()); + assert!(!file4.1.exists()); + assert!(!file5.1.exists()); + + let options = dir::CopyOptions::new(); + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let func_test = |process_info: TransitProcess| { + tx.send(process_info).unwrap(); + dir::TransitProcessResult::ContinueOrAbort + }; + let result = move_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + + assert_eq!(41, result); + assert!(!file1.0.exists()); + assert!(!file2.0.exists()); + assert!(!file3.0.exists()); + assert!(!file4.0.exists()); + assert!(!file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + }) + .join(); + + loop { + match rx.try_recv() { + Ok(process_info) => { + if process_info.file_name == "file2.txt" { + assert_eq!(9, process_info.file_total_bytes); + assert_eq!(41, process_info.total_bytes); + } else if process_info.file_name == "file1.txt" { + assert_eq!(8, process_info.file_total_bytes); + assert_eq!(41, process_info.total_bytes); + } + } + Err(TryRecvError::Disconnected) => { + break; + } + Err(TryRecvError::Empty) => {} + } + } + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } +} + +#[test] +fn it_move_with_progress_source_not_exist() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_with_progress_source_not_exist"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + assert!(!dir1.0.exists()); + assert!(!dir1.1.exists()); + assert!(!dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(!sub.0.exists()); + assert!(!sub.1.exists()); + + assert!(!file1.0.exists()); + assert!(!file1.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + + let func_test = |process_info: TransitProcess| { + println!("{}", process_info.total_bytes); + dir::TransitProcessResult::ContinueOrAbort + }; + let options = dir::CopyOptions::new(); + match move_items_with_progress(&from_paths, &path_to, &options, func_test) { + Ok(_) => panic!("Should be a error!"), + Err(err) => match err.kind { + ErrorKind::NotFound => {} + _ => {} + }, + }; +} + +#[test] +fn it_move_with_progress_exist_overwrite() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_with_progress_exist_overwrite"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + options.overwrite = true; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let func_test = |process_info: TransitProcess| { + tx.send(process_info).unwrap(); + dir::TransitProcessResult::ContinueOrAbort + }; + let result = move_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + + assert_eq!(40, result); + assert!(!file1.0.exists()); + assert!(!file2.0.exists()); + assert!(!file3.0.exists()); + assert!(!file4.0.exists()); + assert!(!file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + + match rx.recv() { + Err(_) => panic!("Errors should not be!"), + _ => {} + } +} + +#[test] +fn it_move_with_progress_exist_not_overwrite() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_with_progress_exist_not_overwrite"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let options = dir::CopyOptions::new(); + let func_test = |process_info: TransitProcess| { + println!("{}", process_info.total_bytes); + dir::TransitProcessResult::ContinueOrAbort + }; + match move_items_with_progress(&from_paths, &path_to, &options, func_test) { + Ok(_) => panic!("Should be a error!"), + Err(err) => match err.kind { + ErrorKind::AlreadyExists => {} + _ => panic!(format!("{}", err.to_string())), + }, + }; +} + +#[test] +fn it_move_with_progress_exist_skip_exist() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_with_progress_exist_skip_exist"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + dir::create_all(&dir2.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + file::write_all(&file5.1, "old content5").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + options.skip_exist = true; + options.overwrite = false; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let func_test = |process_info: TransitProcess| { + tx.send(process_info).unwrap(); + dir::TransitProcessResult::ContinueOrAbort + }; + let result = move_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + + assert_eq!(8, result); + assert!(file1.0.exists()); + assert!(!file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + assert!(!files_eq(&file1.0, &file1.1)); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + + match rx.recv() { + Err(_) => panic!("Errors should not be!"), + _ => {} + } +} + +#[test] +fn it_move_with_progress_exist_overwrite_and_skip_exist() { + let test_dir = + Path::new(TEST_FOLDER).join("it_move_with_progress_exist_overwrite_and_skip_exist"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + match dir::create_all(&path_to, true) { + Ok(_) => {} + Err(_) => {} + }; + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(!dir2.1.exists()); + assert!(sub.0.exists()); + assert!(sub.1.exists()); + + file::write_all(&file1.0, "content1").unwrap(); + file::write_all(&file2.0, "content2").unwrap(); + file::write_all(&file3.0, "content3").unwrap(); + file::write_all(&file4.0, "content4").unwrap(); + file::write_all(&file5.0, "content5").unwrap(); + + file::write_all(&file1.1, "old content1").unwrap(); + file::write_all(&file3.1, "old content3").unwrap(); + file::write_all(&file4.1, "old content4").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(!file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(!file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + options.overwrite = true; + options.skip_exist = true; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let func_test = |process_info: TransitProcess| { + tx.send(process_info).unwrap(); + dir::TransitProcessResult::ContinueOrAbort + }; + let result = move_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + + assert_eq!(40, result); + assert!(!file1.0.exists()); + assert!(!file2.0.exists()); + assert!(!file3.0.exists()); + assert!(!file4.0.exists()); + assert!(!file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + + match rx.recv() { + Err(_) => panic!("Errors should not be!"), + _ => {} + } +} + +#[test] +fn it_move_with_progress_content_only_option() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_with_progress_content_only_option"); + let path_to = test_dir.join("out"); + + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + + let mut options = dir::CopyOptions::new(); + options.content_only = true; + let func_test = |process_info: TransitProcess| { + println!("{}", process_info.total_bytes); + dir::TransitProcessResult::ContinueOrAbort + }; + match move_items_with_progress(&vec![&file1.0], &file1.1, &options, func_test) { + Ok(_) => panic!("Should be a error!"), + Err(err) => match err.kind { + ErrorKind::Other => {} + _ => panic!(format!("wrong error {}", err.to_string())), + }, + }; +} + +#[test] +fn it_remove_work() { + let test_dir = Path::new(TEST_FOLDER).join("it_remove_work"); + let dir1 = test_dir.join("dir1"); + let dir2 = test_dir.join("dir2"); + let sub = dir1.join("sub"); + let file1 = test_dir.join("file1.txt"); + let file2 = test_dir.join("file2.txt"); + let file3 = dir1.join("file3.txt"); + let file4 = sub.join("file4.txt"); + let file5 = dir2.join("file5.txt"); + + dir::create_all(&dir1, true).unwrap(); + dir::create_all(&dir2, true).unwrap(); + dir::create_all(&sub, true).unwrap(); + + assert!(dir1.exists()); + assert!(dir2.exists()); + assert!(sub.exists()); + + file::write_all(&file1, "content1").unwrap(); + file::write_all(&file2, "content2").unwrap(); + file::write_all(&file3, "content3").unwrap(); + file::write_all(&file4, "content4").unwrap(); + file::write_all(&file5, "content5").unwrap(); + + assert!(file1.exists()); + assert!(file2.exists()); + assert!(file3.exists()); + assert!(file4.exists()); + assert!(file5.exists()); + + let mut from_paths = Vec::new(); + from_paths.push(dir1.as_path()); + from_paths.push(dir2.as_path()); + from_paths.push(file1.as_path()); + from_paths.push(file2.as_path()); + + remove_items(&from_paths).unwrap(); + assert!(!file1.exists()); + assert!(!file2.exists()); + assert!(!file3.exists()); + assert!(!file4.exists()); + assert!(!file5.exists()); +} + +#[test] +fn it_copy_with_progress_exist_user_decide_overwrite() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_with_progress_exist_user_decide_overwrite"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir1.1, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&dir2.1, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(&dir1.0.exists()); + assert!(&dir1.1.exists()); + assert!(&dir2.0.exists()); + assert!(&dir2.1.exists()); + assert!(&sub.0.exists()); + assert!(&sub.1.exists()); + + fs_extra::file::write_all(&file1.0, "content1").unwrap(); + fs_extra::file::write_all(&file2.0, "content2").unwrap(); + fs_extra::file::write_all(&file3.0, "content3").unwrap(); + fs_extra::file::write_all(&file4.0, "content4").unwrap(); + fs_extra::file::write_all(&file5.0, "content5").unwrap(); + + fs_extra::file::write_all(&file1.1, "old content11").unwrap(); + fs_extra::file::write_all(&file2.1, "old content12").unwrap(); + fs_extra::file::write_all(&file3.1, "old content13").unwrap(); + fs_extra::file::write_all(&file4.1, "old content14").unwrap(); + fs_extra::file::write_all(&file5.1, "old content15").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + assert!(!compare_dir(&dir1.0, &dir1.1)); + assert!(!compare_dir(&dir2.0, &dir2.1)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(!files_eq(&file2.0, &file2.1)); + options.buffer_size = 1; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut count_exist_files = 0; + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let result: u64; + { + let func_test = |process_info: TransitProcess| { + let result: dir::TransitProcessResult; + match process_info.state { + dir::TransitState::Exists => { + count_exist_files += 1; + result = dir::TransitProcessResult::Overwrite; + tx.send(process_info).unwrap(); + } + _ => result = dir::TransitProcessResult::Abort, + }; + result + }; + + result = copy_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + } + assert_eq!(5, count_exist_files); + + assert_eq!(40, result); + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(dir2.1.exists()); + assert!(compare_dir(&dir1.0, &path_to)); + assert!(compare_dir(&dir2.0, &path_to)); + assert!(files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file2.0, &file2.1)); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + rx.try_recv().unwrap(); +} + +#[test] +fn it_copy_with_progress_exist_user_decide_overwrite_all() { + let test_dir = + Path::new(TEST_FOLDER).join("it_copy_with_progress_exist_user_decide_overwrite_all"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir1.1, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&dir2.1, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(&dir1.0.exists()); + assert!(&dir1.1.exists()); + assert!(&dir2.0.exists()); + assert!(&dir2.1.exists()); + assert!(&sub.0.exists()); + assert!(&sub.1.exists()); + + fs_extra::file::write_all(&file1.0, "content1").unwrap(); + fs_extra::file::write_all(&file2.0, "content2").unwrap(); + fs_extra::file::write_all(&file3.0, "content3").unwrap(); + fs_extra::file::write_all(&file4.0, "content4").unwrap(); + fs_extra::file::write_all(&file5.0, "content5").unwrap(); + + fs_extra::file::write_all(&file1.1, "old content11").unwrap(); + fs_extra::file::write_all(&file2.1, "old content12").unwrap(); + fs_extra::file::write_all(&file3.1, "old content13").unwrap(); + fs_extra::file::write_all(&file4.1, "old content14").unwrap(); + fs_extra::file::write_all(&file5.1, "old content15").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + assert!(!compare_dir(&dir1.0, &dir1.1)); + assert!(!compare_dir(&dir2.0, &dir2.1)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(!files_eq(&file2.0, &file2.1)); + options.buffer_size = 1; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut count_exist_files = 0; + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let result: u64; + { + let func_test = |process_info: TransitProcess| { + let result: dir::TransitProcessResult; + match process_info.state { + dir::TransitState::Exists => { + count_exist_files += 1; + result = dir::TransitProcessResult::OverwriteAll; + tx.send(process_info).unwrap(); + } + _ => result = dir::TransitProcessResult::Abort, + }; + result + }; + + result = copy_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + } + assert_eq!(1, count_exist_files); + + assert_eq!(40, result); + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(dir2.1.exists()); + assert!(compare_dir(&dir1.0, &path_to)); + assert!(compare_dir(&dir2.0, &path_to)); + assert!(files_eq(&file1.0, &file1.1)); + assert!(files_eq(&file2.0, &file2.1)); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + rx.try_recv().unwrap(); +} + +#[test] +fn it_copy_with_progress_exist_user_decide_skip() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_with_progress_exist_user_decide_skip"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir1.1, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&dir2.1, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(&dir1.0.exists()); + assert!(&dir1.1.exists()); + assert!(&dir2.0.exists()); + assert!(&dir2.1.exists()); + assert!(&sub.0.exists()); + assert!(&sub.1.exists()); + + fs_extra::file::write_all(&file1.0, "content1").unwrap(); + fs_extra::file::write_all(&file2.0, "content2").unwrap(); + fs_extra::file::write_all(&file3.0, "content3").unwrap(); + fs_extra::file::write_all(&file4.0, "content4").unwrap(); + fs_extra::file::write_all(&file5.0, "content5").unwrap(); + + fs_extra::file::write_all(&file1.1, "old content11").unwrap(); + fs_extra::file::write_all(&file2.1, "old content12").unwrap(); + fs_extra::file::write_all(&file3.1, "old content13").unwrap(); + fs_extra::file::write_all(&file4.1, "old content14").unwrap(); + fs_extra::file::write_all(&file5.1, "old content15").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + assert!(!compare_dir(&dir1.0, &dir1.1)); + assert!(!compare_dir(&dir2.0, &dir2.1)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(!files_eq(&file2.0, &file2.1)); + options.buffer_size = 1; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut count_exist_files = 0; + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let result: u64; + { + let func_test = |process_info: TransitProcess| { + let result: dir::TransitProcessResult; + match process_info.state { + dir::TransitState::Exists => { + count_exist_files += 1; + result = dir::TransitProcessResult::Skip; + tx.send(process_info).unwrap(); + } + _ => result = dir::TransitProcessResult::Abort, + }; + result + }; + + result = copy_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + } + assert_eq!(5, count_exist_files); + + assert_eq!(0, result); + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(dir2.1.exists()); + assert!(!compare_dir(&dir1.0, &path_to)); + assert!(!compare_dir(&dir2.0, &path_to)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(!files_eq(&file2.0, &file2.1)); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + rx.try_recv().unwrap(); +} + +#[test] +fn it_copy_with_progress_exist_user_decide_skip_all() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_with_progress_exist_user_decide_skip_all"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir1.1, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&dir2.1, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(&dir1.0.exists()); + assert!(&dir1.1.exists()); + assert!(&dir2.0.exists()); + assert!(&dir2.1.exists()); + assert!(&sub.0.exists()); + assert!(&sub.1.exists()); + + fs_extra::file::write_all(&file1.0, "content1").unwrap(); + fs_extra::file::write_all(&file2.0, "content2").unwrap(); + fs_extra::file::write_all(&file3.0, "content3").unwrap(); + fs_extra::file::write_all(&file4.0, "content4").unwrap(); + fs_extra::file::write_all(&file5.0, "content5").unwrap(); + + fs_extra::file::write_all(&file1.1, "old content11").unwrap(); + fs_extra::file::write_all(&file2.1, "old content12").unwrap(); + fs_extra::file::write_all(&file3.1, "old content13").unwrap(); + fs_extra::file::write_all(&file4.1, "old content14").unwrap(); + fs_extra::file::write_all(&file5.1, "old content15").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + assert!(!compare_dir(&dir1.0, &dir1.1)); + assert!(!compare_dir(&dir2.0, &dir2.1)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(!files_eq(&file2.0, &file2.1)); + options.buffer_size = 1; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut count_exist_files = 0; + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let result: u64; + { + let func_test = |process_info: TransitProcess| { + let result: dir::TransitProcessResult; + match process_info.state { + dir::TransitState::Exists => { + count_exist_files += 1; + result = dir::TransitProcessResult::SkipAll; + tx.send(process_info).unwrap(); + } + _ => result = dir::TransitProcessResult::Abort, + }; + result + }; + + result = copy_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + } + assert_eq!(1, count_exist_files); + + assert_eq!(0, result); + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(dir2.1.exists()); + assert!(!compare_dir(&dir1.0, &path_to)); + assert!(!compare_dir(&dir2.0, &path_to)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(!files_eq(&file2.0, &file2.1)); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + rx.try_recv().unwrap(); +} + +#[test] +fn it_copy_with_progress_exist_user_decide_retry() { + let test_dir = Path::new(TEST_FOLDER).join("it_copy_with_progress_exist_user_decide_retry"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir1.1, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&dir2.1, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(&dir1.0.exists()); + assert!(&dir1.1.exists()); + assert!(&dir2.0.exists()); + assert!(&dir2.1.exists()); + assert!(&sub.0.exists()); + assert!(&sub.1.exists()); + + fs_extra::file::write_all(&file1.0, "content1").unwrap(); + fs_extra::file::write_all(&file2.0, "content2").unwrap(); + fs_extra::file::write_all(&file3.0, "content3").unwrap(); + fs_extra::file::write_all(&file4.0, "content4").unwrap(); + fs_extra::file::write_all(&file5.0, "content5").unwrap(); + + fs_extra::file::write_all(&file1.1, "old content11").unwrap(); + fs_extra::file::write_all(&file2.1, "old content12").unwrap(); + fs_extra::file::write_all(&file3.1, "old content13").unwrap(); + fs_extra::file::write_all(&file4.1, "old content14").unwrap(); + fs_extra::file::write_all(&file5.1, "old content15").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + assert!(!compare_dir(&dir1.0, &dir1.1)); + assert!(!compare_dir(&dir2.0, &dir2.1)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(!files_eq(&file2.0, &file2.1)); + options.buffer_size = 1; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut count_exist_files = 0; + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let result: u64; + { + let func_test = |process_info: TransitProcess| { + let result: dir::TransitProcessResult; + match process_info.state { + dir::TransitState::Exists => { + if count_exist_files == 3 || count_exist_files > 6 { + result = dir::TransitProcessResult::Skip; + } else { + result = dir::TransitProcessResult::Retry; + } + + count_exist_files += 1; + tx.send(process_info).unwrap(); + } + _ => result = dir::TransitProcessResult::Abort, + }; + result + }; + + result = copy_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + } + assert_eq!(11, count_exist_files); + + assert_eq!(0, result); + assert!(dir1.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.0.exists()); + assert!(dir2.1.exists()); + assert!(!compare_dir(&dir1.0, &path_to)); + assert!(!compare_dir(&dir2.0, &path_to)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(!files_eq(&file2.0, &file2.1)); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + rx.try_recv().unwrap(); +} + +#[test] +fn it_move_with_progress_exist_user_decide_overwrite() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_with_progress_exist_user_decide_overwrite"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir1.1, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&dir2.1, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(&dir1.0.exists()); + assert!(&dir1.1.exists()); + assert!(&dir2.0.exists()); + assert!(&dir2.1.exists()); + assert!(&sub.0.exists()); + assert!(&sub.1.exists()); + + fs_extra::file::write_all(&file1.0, "content1").unwrap(); + fs_extra::file::write_all(&file2.0, "content2").unwrap(); + fs_extra::file::write_all(&file3.0, "content3").unwrap(); + fs_extra::file::write_all(&file4.0, "content4").unwrap(); + fs_extra::file::write_all(&file5.0, "content5").unwrap(); + + fs_extra::file::write_all(&file1.1, "old content11").unwrap(); + fs_extra::file::write_all(&file2.1, "old content12").unwrap(); + fs_extra::file::write_all(&file3.1, "old content13").unwrap(); + fs_extra::file::write_all(&file4.1, "old content14").unwrap(); + fs_extra::file::write_all(&file5.1, "old content15").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + assert!(!compare_dir(&dir1.0, &dir1.1)); + assert!(!compare_dir(&dir2.0, &dir2.1)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(!files_eq(&file2.0, &file2.1)); + options.buffer_size = 1; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut count_exist_files = 0; + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let result: u64; + { + let func_test = |process_info: TransitProcess| { + let result: dir::TransitProcessResult; + match process_info.state { + dir::TransitState::Exists => { + count_exist_files += 1; + result = dir::TransitProcessResult::Overwrite; + tx.send(process_info).unwrap(); + } + _ => result = dir::TransitProcessResult::Abort, + }; + result + }; + + result = move_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + } + assert_eq!(5, count_exist_files); + + assert_eq!(40, result); + assert!(!dir1.0.exists()); + assert!(!dir2.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.1.exists()); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + rx.try_recv().unwrap(); +} + +#[test] +fn it_move_with_progress_exist_user_decide_overwrite_all() { + let test_dir = + Path::new(TEST_FOLDER).join("it_move_with_progress_exist_user_decide_overwrite_all"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir1.1, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&dir2.1, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(&dir1.0.exists()); + assert!(&dir1.1.exists()); + assert!(&dir2.0.exists()); + assert!(&dir2.1.exists()); + assert!(&sub.0.exists()); + assert!(&sub.1.exists()); + + fs_extra::file::write_all(&file1.0, "content1").unwrap(); + fs_extra::file::write_all(&file2.0, "content2").unwrap(); + fs_extra::file::write_all(&file3.0, "content3").unwrap(); + fs_extra::file::write_all(&file4.0, "content4").unwrap(); + fs_extra::file::write_all(&file5.0, "content5").unwrap(); + + fs_extra::file::write_all(&file1.1, "old content11").unwrap(); + fs_extra::file::write_all(&file2.1, "old content12").unwrap(); + fs_extra::file::write_all(&file3.1, "old content13").unwrap(); + fs_extra::file::write_all(&file4.1, "old content14").unwrap(); + fs_extra::file::write_all(&file5.1, "old content15").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + assert!(!compare_dir(&dir1.0, &dir1.1)); + assert!(!compare_dir(&dir2.0, &dir2.1)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(!files_eq(&file2.0, &file2.1)); + options.buffer_size = 1; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut count_exist_files = 0; + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let result: u64; + { + let func_test = |process_info: TransitProcess| { + let result: dir::TransitProcessResult; + match process_info.state { + dir::TransitState::Exists => { + count_exist_files += 1; + result = dir::TransitProcessResult::OverwriteAll; + tx.send(process_info).unwrap(); + } + _ => result = dir::TransitProcessResult::Abort, + }; + result + }; + + result = move_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + } + assert_eq!(1, count_exist_files); + + assert_eq!(40, result); + assert!(!dir1.0.exists()); + assert!(!dir2.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.1.exists()); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + rx.try_recv().unwrap(); +} + +#[test] +fn it_move_with_progress_exist_user_decide_skip() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_with_progress_exist_user_decide_skip"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir1.1, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&dir2.1, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(&dir1.0.exists()); + assert!(&dir1.1.exists()); + assert!(&dir2.0.exists()); + assert!(&dir2.1.exists()); + assert!(&sub.0.exists()); + assert!(&sub.1.exists()); + + fs_extra::file::write_all(&file1.0, "content1").unwrap(); + fs_extra::file::write_all(&file2.0, "content2").unwrap(); + fs_extra::file::write_all(&file3.0, "content3").unwrap(); + fs_extra::file::write_all(&file4.0, "content4").unwrap(); + fs_extra::file::write_all(&file5.0, "content5").unwrap(); + + fs_extra::file::write_all(&file1.1, "old content11").unwrap(); + fs_extra::file::write_all(&file2.1, "old content12").unwrap(); + fs_extra::file::write_all(&file3.1, "old content13").unwrap(); + fs_extra::file::write_all(&file4.1, "old content14").unwrap(); + fs_extra::file::write_all(&file5.1, "old content15").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + assert!(!compare_dir(&dir1.0, &dir1.1)); + assert!(!compare_dir(&dir2.0, &dir2.1)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(!files_eq(&file2.0, &file2.1)); + options.buffer_size = 1; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut count_exist_files = 0; + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let result: u64; + { + let func_test = |process_info: TransitProcess| { + let result: dir::TransitProcessResult; + match process_info.state { + dir::TransitState::Exists => { + count_exist_files += 1; + result = dir::TransitProcessResult::Skip; + tx.send(process_info).unwrap(); + } + _ => result = dir::TransitProcessResult::Abort, + }; + result + }; + + result = move_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + } + assert_eq!(5, count_exist_files); + + assert_eq!(0, result); + assert!(dir1.0.exists()); + assert!(dir2.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.1.exists()); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + rx.try_recv().unwrap(); +} + +#[test] +fn it_move_with_progress_exist_user_decide_skip_all() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_with_progress_exist_user_decide_skip_all"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir1.1, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&dir2.1, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(&dir1.0.exists()); + assert!(&dir1.1.exists()); + assert!(&dir2.0.exists()); + assert!(&dir2.1.exists()); + assert!(&sub.0.exists()); + assert!(&sub.1.exists()); + + fs_extra::file::write_all(&file1.0, "content1").unwrap(); + fs_extra::file::write_all(&file2.0, "content2").unwrap(); + fs_extra::file::write_all(&file3.0, "content3").unwrap(); + fs_extra::file::write_all(&file4.0, "content4").unwrap(); + fs_extra::file::write_all(&file5.0, "content5").unwrap(); + + fs_extra::file::write_all(&file1.1, "old content11").unwrap(); + fs_extra::file::write_all(&file2.1, "old content12").unwrap(); + fs_extra::file::write_all(&file3.1, "old content13").unwrap(); + fs_extra::file::write_all(&file4.1, "old content14").unwrap(); + fs_extra::file::write_all(&file5.1, "old content15").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + assert!(!compare_dir(&dir1.0, &dir1.1)); + assert!(!compare_dir(&dir2.0, &dir2.1)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(!files_eq(&file2.0, &file2.1)); + options.buffer_size = 1; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut count_exist_files = 0; + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let result: u64; + { + let func_test = |process_info: TransitProcess| { + let result: dir::TransitProcessResult; + match process_info.state { + dir::TransitState::Exists => { + count_exist_files += 1; + result = dir::TransitProcessResult::SkipAll; + tx.send(process_info).unwrap(); + } + _ => result = dir::TransitProcessResult::Abort, + }; + result + }; + + result = move_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + } + assert_eq!(1, count_exist_files); + + assert_eq!(0, result); + assert!(dir1.0.exists()); + assert!(dir2.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.1.exists()); + assert!(file1.0.exists()); + assert!(file2.0.exists()); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + rx.try_recv().unwrap(); +} + +#[test] +fn it_move_with_progress_exist_user_decide_retry() { + let test_dir = Path::new(TEST_FOLDER).join("it_move_with_progress_exist_user_decide_retry"); + let path_to = test_dir.join("out"); + let dir1 = (test_dir.join("dir1"), path_to.join("dir1")); + let dir2 = (test_dir.join("dir2"), path_to.join("dir2")); + let sub = (dir1.0.join("sub"), dir1.1.join("sub")); + let file1 = (test_dir.join("file1.txt"), path_to.join("file1.txt")); + let file2 = (test_dir.join("file2.txt"), path_to.join("file2.txt")); + let file3 = (dir1.0.join("file3.txt"), dir1.1.join("file3.txt")); + let file4 = (sub.0.join("file4.txt"), sub.1.join("file4.txt")); + let file5 = (dir2.0.join("file5.txt"), dir2.1.join("file5.txt")); + + dir::create_all(&dir1.0, true).unwrap(); + dir::create_all(&dir1.1, true).unwrap(); + dir::create_all(&dir2.0, true).unwrap(); + dir::create_all(&dir2.1, true).unwrap(); + dir::create_all(&sub.0, true).unwrap(); + dir::create_all(&sub.1, true).unwrap(); + + assert!(&dir1.0.exists()); + assert!(&dir1.1.exists()); + assert!(&dir2.0.exists()); + assert!(&dir2.1.exists()); + assert!(&sub.0.exists()); + assert!(&sub.1.exists()); + + fs_extra::file::write_all(&file1.0, "content1").unwrap(); + fs_extra::file::write_all(&file2.0, "content2").unwrap(); + fs_extra::file::write_all(&file3.0, "content3").unwrap(); + fs_extra::file::write_all(&file4.0, "content4").unwrap(); + fs_extra::file::write_all(&file5.0, "content5").unwrap(); + + fs_extra::file::write_all(&file1.1, "old content11").unwrap(); + fs_extra::file::write_all(&file2.1, "old content12").unwrap(); + fs_extra::file::write_all(&file3.1, "old content13").unwrap(); + fs_extra::file::write_all(&file4.1, "old content14").unwrap(); + fs_extra::file::write_all(&file5.1, "old content15").unwrap(); + + assert!(file1.0.exists()); + assert!(file2.0.exists()); + assert!(file3.0.exists()); + assert!(file4.0.exists()); + assert!(file5.0.exists()); + assert!(file1.1.exists()); + assert!(file2.1.exists()); + assert!(file3.1.exists()); + assert!(file4.1.exists()); + assert!(file5.1.exists()); + + let mut options = dir::CopyOptions::new(); + assert!(!compare_dir(&dir1.0, &dir1.1)); + assert!(!compare_dir(&dir2.0, &dir2.1)); + assert!(!files_eq(&file1.0, &file1.1)); + assert!(!files_eq(&file2.0, &file2.1)); + options.buffer_size = 1; + let (tx, rx) = mpsc::channel(); + let result = thread::spawn(move || { + let mut count_exist_files = 0; + let mut from_paths = Vec::new(); + from_paths.push(dir1.0.as_path()); + from_paths.push(dir2.0.as_path()); + from_paths.push(file1.0.as_path()); + from_paths.push(file2.0.as_path()); + + let result: u64; + { + let func_test = |process_info: TransitProcess| { + let result: dir::TransitProcessResult; + match process_info.state { + dir::TransitState::Exists => { + if count_exist_files == 3 || count_exist_files > 6 { + result = dir::TransitProcessResult::Skip; + } else { + result = dir::TransitProcessResult::Retry; + } + + count_exist_files += 1; + tx.send(process_info).unwrap(); + } + _ => result = dir::TransitProcessResult::Abort, + }; + result + }; + + result = move_items_with_progress(&from_paths, &path_to, &options, func_test).unwrap(); + } + assert_eq!(11, count_exist_files); + + assert_eq!(0, result); + assert!(dir1.0.exists()); + assert!(dir2.0.exists()); + assert!(dir1.1.exists()); + assert!(dir2.1.exists()); + }) + .join(); + + match result { + Ok(_) => {} + Err(err) => panic!(err), + } + rx.try_recv().unwrap(); +} -- cgit v1.2.3