From 2fee857cfc9075e1799ec569099d0f58d203045a Mon Sep 17 00:00:00 2001 From: roothunter Date: Sun, 17 Nov 2024 23:41:26 +0100 Subject: [PATCH] Refactoring --- Cargo.lock | 407 ------------------------------------------------ Cargo.toml | 7 +- Makefile | 2 +- tests/engine.rs | 78 +--------- 4 files changed, 6 insertions(+), 488 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 373ce9e..878cf59 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -2,85 +2,6 @@ # It is not intended for manual editing. version = 3 -[[package]] -name = "aho-corasick" -version = "1.1.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8e60d3430d3a69478ad0993f19238d2df97c507009a52b3c10addcd7f6bcb916" -dependencies = [ - "memchr", -] - -[[package]] -name = "android-tzdata" -version = "0.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e999941b234f3131b00bc13c22d06e8c5ff726d1b6318ac7eb276997bbb4fef0" - -[[package]] -name = "android_system_properties" -version = "0.1.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "819e7219dbd41043ac279b19830f2efc897156490d7fd6ea916720117ee66311" -dependencies = [ - "libc", -] - -[[package]] -name = "anstream" -version = "0.6.18" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8acc5369981196006228e28809f761875c0327210a891e941f4c683b3a99529b" -dependencies = [ - "anstyle", - "anstyle-parse", - "anstyle-query", - "anstyle-wincon", - "colorchoice", - "is_terminal_polyfill", - "utf8parse", -] - -[[package]] -name = "anstyle" -version = "1.0.10" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "55cc3b69f167a1ef2e161439aa98aed94e6028e5f9a59be9a6ffb47aef1651f9" - -[[package]] -name = "anstyle-parse" -version = "0.2.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3b2d16507662817a6a20a9ea92df6652ee4f94f914589377d69f3b21bc5798a9" -dependencies = [ - "utf8parse", -] - -[[package]] -name = "anstyle-query" -version = "1.1.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "79947af37f4177cfead1110013d678905c37501914fba0efea834c3fe9a8d60c" -dependencies = [ - "windows-sys", -] - -[[package]] -name = "anstyle-wincon" -version = "3.0.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2109dbce0e72be3ec00bed26e6a7479ca384ad226efdd66db8fa2e3a38c83125" -dependencies = [ - "anstyle", - "windows-sys", -] - -[[package]] -name = "autocfg" -version = "1.4.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ace50bade8e6234aa140d9a2f552bbee1db4d353f69b8217bc503490fc1a9f26" - [[package]] name = "bincode" version = "1.3.3" @@ -90,153 +11,6 @@ dependencies = [ "serde", ] -[[package]] -name = "bumpalo" -version = "3.16.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "79296716171880943b8470b5f8d03aa55eb2e645a4874bdbb28adb49162e012c" - -[[package]] -name = "cc" -version = "1.2.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fd9de9f2205d5ef3fd67e685b0df337994ddd4495e2a28d185500d0e1edfea47" -dependencies = [ - "shlex", -] - -[[package]] -name = "cfg-if" -version = "1.0.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" - -[[package]] -name = "chrono" -version = "0.4.38" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a21f936df1771bf62b77f047b726c4625ff2e8aa607c01ec06e5a05bd8463401" -dependencies = [ - "android-tzdata", - "iana-time-zone", - "js-sys", - "num-traits", - "wasm-bindgen", - "windows-targets", -] - -[[package]] -name = "colorchoice" -version = "1.0.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5b63caa9aa9397e2d9480a9b13673856c78d8ac123288526c37d7839f2a86990" - -[[package]] -name = "core-foundation-sys" -version = "0.8.7" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "773648b94d0e5d620f64f280777445740e61fe701025087ec8b57f45c791888b" - -[[package]] -name = "env_filter" -version = "0.1.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4f2c92ceda6ceec50f43169f9ee8424fe2db276791afde7b2cd8bc084cb376ab" -dependencies = [ - "log", - "regex", -] - -[[package]] -name = "env_logger" -version = "0.11.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e13fa619b91fb2381732789fc5de83b45675e882f66623b7d8cb4f643017018d" -dependencies = [ - "anstream", - "anstyle", - "env_filter", - "humantime", - "log", -] - -[[package]] -name = "humantime" -version = "2.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9a3a5bfb195931eeb336b2a7b4d761daec841b97f947d34394601737a7bba5e4" - -[[package]] -name = "iana-time-zone" -version = "0.1.61" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "235e081f3925a06703c2d0117ea8b91f042756fd6e7a6e5d901e8ca1a996b220" -dependencies = [ - "android_system_properties", - "core-foundation-sys", - "iana-time-zone-haiku", - "js-sys", - "wasm-bindgen", - "windows-core", -] - -[[package]] -name = "iana-time-zone-haiku" -version = "0.1.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f31827a206f56af32e590ba56d5d2d085f558508192593743f16b2306495269f" -dependencies = [ - "cc", -] - -[[package]] -name = "is_terminal_polyfill" -version = "1.70.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7943c866cc5cd64cbc25b2e01621d07fa8eb2a1a23160ee81ce38704e97b8ecf" - -[[package]] -name = "js-sys" -version = "0.3.72" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6a88f1bda2bd75b0452a14784937d796722fdebfe50df998aeb3f0b7603019a9" -dependencies = [ - "wasm-bindgen", -] - -[[package]] -name = "libc" -version = "0.2.164" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "433bfe06b8c75da9b2e3fbea6e5329ff87748f0b144ef75306e674c3f6f7c13f" - -[[package]] -name = "log" -version = "0.4.22" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a7a70ba024b9dc04c27ea2f0c0548feb474ec5c54bba33a7f72f873a39d07b24" - -[[package]] -name = "memchr" -version = "2.7.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "78ca9ab1a0babb1e7d5695e3530886289c18cf2f87ec19a575a0abdce112e3a3" - -[[package]] -name = "num-traits" -version = "0.2.19" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "071dfc062690e90b734c0b2273ce72ad0ffa95f0c74596bc250dcfd960262841" -dependencies = [ - "autocfg", -] - -[[package]] -name = "once_cell" -version = "1.20.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1261fe7e33c73b354eab43b1273a57c8f967d0391e80353e51f764ac02cf6775" - [[package]] name = "proc-macro2" version = "1.0.89" @@ -255,35 +29,6 @@ dependencies = [ "proc-macro2", ] -[[package]] -name = "regex" -version = "1.11.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b544ef1b4eac5dc2db33ea63606ae9ffcfac26c1416a2806ae0bf5f56b201191" -dependencies = [ - "aho-corasick", - "memchr", - "regex-automata", - "regex-syntax", -] - -[[package]] -name = "regex-automata" -version = "0.4.9" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "809e8dc61f6de73b46c85f4c96486310fe304c434cfa43669d7b40f711150908" -dependencies = [ - "aho-corasick", - "memchr", - "regex-syntax", -] - -[[package]] -name = "regex-syntax" -version = "0.8.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2b15c43186be67a4fd63bee50d0303afffcef381492ebe2c5d87f324e1b8815c" - [[package]] name = "rustc-hash" version = "2.0.0" @@ -310,12 +55,6 @@ dependencies = [ "syn", ] -[[package]] -name = "shlex" -version = "1.3.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0fda2ff0d084019ba4d7c6f371c95d8fd75ce3524c3cb8fb653a3023f6323e64" - [[package]] name = "syn" version = "2.0.87" @@ -332,9 +71,6 @@ name = "tc" version = "0.2.0" dependencies = [ "bincode", - "chrono", - "env_logger", - "log", "rustc-hash", "serde", ] @@ -344,146 +80,3 @@ name = "unicode-ident" version = "1.0.13" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e91b56cd4cadaeb79bbf1a5645f6b4f8dc5bde8834ad5894a8db35fda9efa1fe" - -[[package]] -name = "utf8parse" -version = "0.2.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "06abde3611657adf66d383f00b093d7faecc7fa57071cce2578660c9f1010821" - -[[package]] -name = "wasm-bindgen" -version = "0.2.95" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "128d1e363af62632b8eb57219c8fd7877144af57558fb2ef0368d0087bddeb2e" -dependencies = [ - "cfg-if", - "once_cell", - "wasm-bindgen-macro", -] - -[[package]] -name = "wasm-bindgen-backend" -version = "0.2.95" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cb6dd4d3ca0ddffd1dd1c9c04f94b868c37ff5fac97c30b97cff2d74fce3a358" -dependencies = [ - "bumpalo", - "log", - "once_cell", - "proc-macro2", - "quote", - "syn", - "wasm-bindgen-shared", -] - -[[package]] -name = "wasm-bindgen-macro" -version = "0.2.95" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e79384be7f8f5a9dd5d7167216f022090cf1f9ec128e6e6a482a2cb5c5422c56" -dependencies = [ - "quote", - "wasm-bindgen-macro-support", -] - -[[package]] -name = "wasm-bindgen-macro-support" -version = "0.2.95" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "26c6ab57572f7a24a4985830b120de1594465e5d500f24afe89e16b4e833ef68" -dependencies = [ - "proc-macro2", - "quote", - "syn", - "wasm-bindgen-backend", - "wasm-bindgen-shared", -] - -[[package]] -name = "wasm-bindgen-shared" -version = "0.2.95" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "65fc09f10666a9f147042251e0dda9c18f166ff7de300607007e96bdebc1068d" - -[[package]] -name = "windows-core" -version = "0.52.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "33ab640c8d7e35bf8ba19b884ba838ceb4fba93a4e8c65a9059d08afcfc683d9" -dependencies = [ - "windows-targets", -] - -[[package]] -name = "windows-sys" -version = "0.59.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1e38bc4d79ed67fd075bcc251a1c39b32a1776bbe92e5bef1f0bf1f8c531853b" -dependencies = [ - "windows-targets", -] - -[[package]] -name = "windows-targets" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9b724f72796e036ab90c1021d4780d4d3d648aca59e491e6b98e725b84e99973" -dependencies = [ - "windows_aarch64_gnullvm", - "windows_aarch64_msvc", - "windows_i686_gnu", - "windows_i686_gnullvm", - "windows_i686_msvc", - "windows_x86_64_gnu", - "windows_x86_64_gnullvm", - "windows_x86_64_msvc", -] - -[[package]] -name = "windows_aarch64_gnullvm" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "32a4622180e7a0ec044bb555404c800bc9fd9ec262ec147edd5989ccd0c02cd3" - -[[package]] -name = "windows_aarch64_msvc" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "09ec2a7bb152e2252b53fa7803150007879548bc709c039df7627cabbd05d469" - -[[package]] -name = "windows_i686_gnu" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8e9b5ad5ab802e97eb8e295ac6720e509ee4c243f69d781394014ebfe8bbfa0b" - -[[package]] -name = "windows_i686_gnullvm" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0eee52d38c090b3caa76c563b86c3a4bd71ef1a819287c19d586d7334ae8ed66" - -[[package]] -name = "windows_i686_msvc" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "240948bc05c5e7c6dabba28bf89d89ffce3e303022809e73deaefe4f6ec56c66" - -[[package]] -name = "windows_x86_64_gnu" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "147a5c80aabfbf0c7d901cb5895d1de30ef2907eb21fbbab29ca94c5b08b1a78" - -[[package]] -name = "windows_x86_64_gnullvm" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "24d5b23dc417412679681396f2b49f3de8c1473deb516bd34410872eff51ed0d" - -[[package]] -name = "windows_x86_64_msvc" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "589f6da84c646204747d1270a2a5661ea66ed1cced2631d546fdfb155959f9ec" diff --git a/Cargo.toml b/Cargo.toml index 30d5368..1a46681 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -8,9 +8,4 @@ authors = ["Antonio Ricciardi "] [dependencies] serde = { version = "1", features = ["derive"] } bincode = "1.3" -rustc-hash = "2" - -[dev-dependencies] -log = "0.4" -env_logger = "0.11" -chrono = "0.4" \ No newline at end of file +rustc-hash = "2" \ No newline at end of file diff --git a/Makefile b/Makefile index c7f5077..9c1e08b 100644 --- a/Makefile +++ b/Makefile @@ -1,4 +1,4 @@ TIMESTAMP := $(shell date +%Y%m%d_%H%M%S) test: - cargo test -v -- --nocapture --test-threads=1 | tee ./tests/history/test_output_${TIMESTAMP}.log \ No newline at end of file + cargo test --release -v -- --nocapture --test-threads=1 | tee ./tests/history/test_output_${TIMESTAMP}.log \ No newline at end of file diff --git a/tests/engine.rs b/tests/engine.rs index bab114b..8ec0787 100644 --- a/tests/engine.rs +++ b/tests/engine.rs @@ -1,54 +1,8 @@ -use chrono::Local; -use env_logger::Builder; -use log::LevelFilter; -use std::fs::File; -use std::io::Write; - -use std::sync::atomic::{AtomicBool, Ordering}; -use std::sync::Once; - -static IS_LOGGER_INITIALIZED: AtomicBool = AtomicBool::new(false); -static INIT_LOGGER_ONCE: Once = Once::new(); - -fn init_logger() { - INIT_LOGGER_ONCE.call_once(|| { - let timestamp = Local::now().format("%Y_%m_%d"); - let log_path = format!("./tests/logs/test_{}.log", timestamp); - - let target = Box::new(File::create(log_path).expect("Can't create file")); - - let result = Builder::new() - .format(|buf, record| { - writeln!( - buf, - "{}:{} {} [{}] - {}", - record.file().unwrap_or("unknown"), - record.line().unwrap_or(0), - Local::now().format("%Y-%m-%dT%H:%M:%S%.3f"), - record.level(), - record.args() - ) - }) - .target(env_logger::Target::Pipe(target)) - .filter(None, LevelFilter::Info) - .try_init(); - - if result.is_ok() { - println!("Logger init with success"); - } else { - println!("Error to init logger"); - } - }); -} - #[cfg(test)] mod tests { - use super::*; use std::fs::File; use std::io::Read; - use crate::init_logger; - fn are_files_equal(file1: &str, file2: &str) -> std::io::Result { let mut file1 = File::open(file1)?; let mut file2 = File::open(file2)?; @@ -64,14 +18,11 @@ mod tests { fn test_file(original_path: &str, compressed_path: &str, decompressed_path: &str) { println!("#######################################"); - println!("Original path: {}", original_path); - println!("Compressed path: {}", compressed_path); - println!("Decompressed path: {}", decompressed_path); + println!("Original size: {}", std::fs::metadata(original_path).unwrap().len()); let compressed = tc::compress_file(original_path, compressed_path); if compressed.is_ok() { - println!("Original size: {}", std::fs::metadata(original_path).unwrap().len()); println!("Compressed size: {}", std::fs::metadata(compressed_path).unwrap().len()); let decompressed = tc::decompress_file(compressed_path, decompressed_path); @@ -85,23 +36,14 @@ mod tests { } else { assert!(false); } - } - - fn is_init() -> bool { - return IS_LOGGER_INITIALIZED.load(Ordering::SeqCst); - } - fn init() { - if !is_init() { - init_logger(); - IS_LOGGER_INITIALIZED.store(true, Ordering::SeqCst); - } + println!("Original path: {}", original_path); + println!("Compressed path: {}", compressed_path); + println!("Decompressed path: {}", decompressed_path); } #[test] fn test_1() { - init(); - let test_path = "./tests/inputs/input_1.txt"; let compressed_path = "./tests/tmp/compressed_1.tc"; @@ -116,8 +58,6 @@ mod tests { #[test] fn test_2() { - init(); - let original_path = "./tests/inputs/input_1.txt"; let compressed_path = "./tests/tmp/compressed_2.tc"; let decompressed_path = "./tests/tmp/decompressed_2.tc"; @@ -129,8 +69,6 @@ mod tests { #[test] fn test_3() { - init(); - let original_path = "./tests/inputs/input_2.txt"; let compressed_path = "./tests/tmp/compressed_3.tc"; let decompressed_path = "./tests/tmp/decompressed_3.tc"; @@ -142,8 +80,6 @@ mod tests { #[test] fn test_4() { - init(); - let original_path = "./tests/inputs/input_3.txt"; let compressed_path = "./tests/tmp/compressed_4.tc"; let decompressed_path = "./tests/tmp/decompressed_4.tc"; @@ -155,8 +91,6 @@ mod tests { #[test] fn test_5() { - init(); - let original_path = "./tests/inputs/input_4.txt"; let compressed_path = "./tests/tmp/compressed_5.tc"; let decompressed_path = "./tests/tmp/decompressed_5.tc"; @@ -168,8 +102,6 @@ mod tests { #[test] fn test_6() { - init(); - let original_path = "./tests/inputs/input_5.txt"; let compressed_path = "./tests/tmp/compressed_6.tc"; let decompressed_path = "./tests/tmp/decompressed_6.tc"; @@ -181,8 +113,6 @@ mod tests { #[test] fn test_7() { - init(); - let original_path = "./tests/inputs/input_7.txt"; let compressed_path = "./tests/tmp/compressed_7.tc"; let decompressed_path = "./tests/tmp/decompressed_7.tc";