use file_utils_operations_lib::with_custom_delims::WithCustomDelims; use std::process::Command; use file_utils_operations_lib::utils::test_utils::{ cmp_vector, convert_string_to_list, get_custom_delims, }; static PATH: &str = "./tests_files/DDHC.txt"; static PATH_DELIMS: &str = "./tests_files/DDHC_custom_delims.txt"; #[cfg(test)] mod tests_withcustomdelim_tail { use super::*; #[test] fn tail_n_10_valid_remove_empty_string_false() { let len: usize = 10; let output = if cfg!(target_os = "windows") { Command::new("cmd") .args(["/C", "Not available on windows"]) .output() .expect("failed to execute process") } else { Command::new("sh") .arg("-c") .arg((("tail ".to_string() + PATH).to_string() + " -n ") + &len.to_string()) .output() .expect("failed to execute process") }; let tail_ref_str: String = match String::from_utf8(output.stdout) { Ok(string) => string, Err(_e) => panic!("Error convertion"), }; let tail_ref: Vec = convert_string_to_list(tail_ref_str); let delims: Vec = get_custom_delims(); let check_tail: Vec = WithCustomDelims::tail( PATH_DELIMS.to_string(), len, delims, false, Vec::new(), Vec::new(), false, 1024, ); cmp_vector(tail_ref, check_tail); } #[test] fn tail_n_1_valid_remove_empty_string_false() { let len: usize = 1; let output = if cfg!(target_os = "windows") { Command::new("cmd") .args(["/C", "Not available on windows"]) .output() .expect("failed to execute process") } else { Command::new("sh") .arg("-c") .arg((("tail ".to_string() + PATH).to_string() + " -n ") + &len.to_string()) .output() .expect("failed to execute process") }; let tail_ref_str: String = match String::from_utf8(output.stdout) { Ok(string) => string, Err(_e) => panic!("Error convertion"), }; let tail_ref: Vec = convert_string_to_list(tail_ref_str); let delims: Vec = get_custom_delims(); let check_tail: Vec = WithCustomDelims::tail( PATH_DELIMS.to_string(), len, delims, false, Vec::new(), Vec::new(), false, 1024, ); cmp_vector(tail_ref, check_tail); } #[test] fn tail_n_0_valid_remove_empty_string_false() { let len: usize = 0; let output = if cfg!(target_os = "windows") { Command::new("cmd") .args(["/C", "Not available on windows"]) .output() .expect("failed to execute process") } else { Command::new("sh") .arg("-c") .arg((("tail ".to_string() + PATH).to_string() + " -n ") + &len.to_string()) .output() .expect("failed to execute process") }; let tail_ref_str: String = match String::from_utf8(output.stdout) { Ok(string) => string, Err(_e) => panic!("Error convertion"), }; let tail_ref: Vec = convert_string_to_list(tail_ref_str); let delims: Vec = get_custom_delims(); let check_tail: Vec = WithCustomDelims::tail( PATH_DELIMS.to_string(), len, delims, false, Vec::new(), Vec::new(), false, 1024, ); cmp_vector(tail_ref, check_tail); } #[test] fn tail_n_10_valid_remove_empty_string_true() { let len: usize = 10; let output = if cfg!(target_os = "windows") { Command::new("cmd") .args(["/C", "Not available on windows"]) .output() .expect("failed to execute process") } else { Command::new("sh") .arg("-c") .arg("sed '/^$/d' ".to_string() + PATH + " | tail -n " + &len.to_string()) .output() .expect("failed to execute process") }; let tail_ref_str: String = match String::from_utf8(output.stdout) { Ok(string) => string, Err(_e) => panic!("Error convertion"), }; let tail_ref: Vec = convert_string_to_list(tail_ref_str); let delims: Vec = get_custom_delims(); let check_tail: Vec = WithCustomDelims::tail( PATH_DELIMS.to_string(), len, delims, true, Vec::new(), Vec::new(), false, 1024, ); cmp_vector(tail_ref, check_tail); } #[test] fn tail_n_1_valid_remove_empty_string_true() { let len: usize = 1; let output = if cfg!(target_os = "windows") { Command::new("cmd") .args(["/C", "Not available on windows"]) .output() .expect("failed to execute process") } else { Command::new("sh") .arg("-c") .arg("sed '/^$/d' ".to_string() + PATH + " | tail -n " + &len.to_string()) .output() .expect("failed to execute process") }; let tail_ref_str: String = match String::from_utf8(output.stdout) { Ok(string) => string, Err(_e) => panic!("Error convertion"), }; let tail_ref: Vec = convert_string_to_list(tail_ref_str); let delims: Vec = get_custom_delims(); let check_tail: Vec = WithCustomDelims::tail( PATH_DELIMS.to_string(), len, delims, true, Vec::new(), Vec::new(), false, 1024, ); cmp_vector(tail_ref, check_tail); } #[test] fn tail_n_0_valid_remove_empty_string_true() { let len: usize = 0; let output = if cfg!(target_os = "windows") { Command::new("cmd") .args(["/C", "Not available on windows"]) .output() .expect("failed to execute process") } else { Command::new("sh") .arg("-c") .arg("sed '/^$/d' ".to_string() + PATH + " | tail -n " + &len.to_string()) .output() .expect("failed to execute process") }; let tail_ref_str: String = match String::from_utf8(output.stdout) { Ok(string) => string, Err(_e) => panic!("Error convertion"), }; let tail_ref: Vec = convert_string_to_list(tail_ref_str); let delims: Vec = get_custom_delims(); let check_tail: Vec = WithCustomDelims::tail( PATH_DELIMS.to_string(), len, delims, true, Vec::new(), Vec::new(), false, 1024, ); cmp_vector(tail_ref, check_tail); } ///// #[test] fn tail_n_10_valid_remove_empty_string_false_little_buffer() { let len: usize = 10; let output = if cfg!(target_os = "windows") { Command::new("cmd") .args(["/C", "Not available on windows"]) .output() .expect("failed to execute process") } else { Command::new("sh") .arg("-c") .arg((("tail ".to_string() + PATH).to_string() + " -n ") + &len.to_string()) .output() .expect("failed to execute process") }; let tail_ref_str: String = match String::from_utf8(output.stdout) { Ok(string) => string, Err(_e) => panic!("Error convertion"), }; let tail_ref: Vec = convert_string_to_list(tail_ref_str); let delims: Vec = get_custom_delims(); let check_tail: Vec = WithCustomDelims::tail( PATH_DELIMS.to_string(), len, delims, false, Vec::new(), Vec::new(), false, 4, ); cmp_vector(tail_ref, check_tail); } #[test] fn tail_n_1_valid_remove_empty_string_false_little_buffer() { let len: usize = 1; let output = if cfg!(target_os = "windows") { Command::new("cmd") .args(["/C", "Not available on windows"]) .output() .expect("failed to execute process") } else { Command::new("sh") .arg("-c") .arg((("tail ".to_string() + PATH).to_string() + " -n ") + &len.to_string()) .output() .expect("failed to execute process") }; let tail_ref_str: String = match String::from_utf8(output.stdout) { Ok(string) => string, Err(_e) => panic!("Error convertion"), }; let tail_ref: Vec = convert_string_to_list(tail_ref_str); let delims: Vec = get_custom_delims(); let check_tail: Vec = WithCustomDelims::tail( PATH_DELIMS.to_string(), len, delims, false, Vec::new(), Vec::new(), false, 4, ); cmp_vector(tail_ref, check_tail); } #[test] fn tail_n_0_valid_remove_empty_string_false_little_buffer() { let len: usize = 0; let output = if cfg!(target_os = "windows") { Command::new("cmd") .args(["/C", "Not available on windows"]) .output() .expect("failed to execute process") } else { Command::new("sh") .arg("-c") .arg((("tail ".to_string() + PATH).to_string() + " -n ") + &len.to_string()) .output() .expect("failed to execute process") }; let tail_ref_str: String = match String::from_utf8(output.stdout) { Ok(string) => string, Err(_e) => panic!("Error convertion"), }; let tail_ref: Vec = convert_string_to_list(tail_ref_str); let delims: Vec = get_custom_delims(); let check_tail: Vec = WithCustomDelims::tail( PATH_DELIMS.to_string(), len, delims, false, Vec::new(), Vec::new(), false, 4, ); cmp_vector(tail_ref, check_tail); } #[test] fn tail_n_10_valid_remove_empty_string_true_little_buffer() { let len: usize = 10; let output = if cfg!(target_os = "windows") { Command::new("cmd") .args(["/C", "Not available on windows"]) .output() .expect("failed to execute process") } else { Command::new("sh") .arg("-c") .arg("sed '/^$/d' ".to_string() + PATH + " | tail -n " + &len.to_string()) .output() .expect("failed to execute process") }; let tail_ref_str: String = match String::from_utf8(output.stdout) { Ok(string) => string, Err(_e) => panic!("Error convertion"), }; let tail_ref: Vec = convert_string_to_list(tail_ref_str); let delims: Vec = get_custom_delims(); let check_tail: Vec = WithCustomDelims::tail( PATH_DELIMS.to_string(), len, delims, true, Vec::new(), Vec::new(), false, 4, ); cmp_vector(tail_ref, check_tail); } #[test] fn tail_n_1_valid_remove_empty_string_true_little_buffer() { let len: usize = 1; let output = if cfg!(target_os = "windows") { Command::new("cmd") .args(["/C", "Not available on windows"]) .output() .expect("failed to execute process") } else { Command::new("sh") .arg("-c") .arg("sed '/^$/d' ".to_string() + PATH + " | tail -n " + &len.to_string()) .output() .expect("failed to execute process") }; let tail_ref_str: String = match String::from_utf8(output.stdout) { Ok(string) => string, Err(_e) => panic!("Error convertion"), }; let tail_ref: Vec = convert_string_to_list(tail_ref_str); let delims: Vec = get_custom_delims(); let check_tail: Vec = WithCustomDelims::tail( PATH_DELIMS.to_string(), len, delims, true, Vec::new(), Vec::new(), false, 4, ); cmp_vector(tail_ref, check_tail); } #[test] fn tail_n_0_valid_remove_empty_string_true_little_buffer() { let len: usize = 0; let output = if cfg!(target_os = "windows") { Command::new("cmd") .args(["/C", "Not available on windows"]) .output() .expect("failed to execute process") } else { Command::new("sh") .arg("-c") .arg("sed '/^$/d' ".to_string() + PATH + " | tail -n " + &len.to_string()) .output() .expect("failed to execute process") }; let tail_ref_str: String = match String::from_utf8(output.stdout) { Ok(string) => string, Err(_e) => panic!("Error convertion"), }; let tail_ref: Vec = convert_string_to_list(tail_ref_str); let delims: Vec = get_custom_delims(); let check_tail: Vec = WithCustomDelims::tail( PATH_DELIMS.to_string(), len, delims, true, Vec::new(), Vec::new(), false, 4, ); cmp_vector(tail_ref, check_tail); } }