diff --git a/src/main.rs b/src/main.rs index 049d27b..78df6a2 100644 --- a/src/main.rs +++ b/src/main.rs @@ -108,7 +108,13 @@ fn main() -> crate::error::Result<()> { std::fs::create_dir_all(dir).unwrap(); std::fs::File::create(&output_path).unwrap(); - exec_obfus(entry.to_str().unwrap(), &output_path, &args).unwrap(); + match exec_obfus(entry.to_str().unwrap(), &output_path, &args) { + Ok(_) => println!("obfuscation done!"), + Err(e) => { + eprintln!("error while obfuscation: {}", e); + return Err(e); + } + } } } @@ -160,7 +166,6 @@ fn exec_obfus(input_path: &str, output_path: &str, args: &Args) -> crate::error: obfuscator.encrypt_function_name(&args.encrypt_f, &args.encrypt_key)?; } - println!("obfuscation done!"); Ok(()) } false => Err(crate::error::Error::InvalidMagic), @@ -277,4 +282,46 @@ mod tests { ); } } + + #[test] + fn got_overwrite() { + { + let loader = crate::obfus::Obfuscator::open("bin/got", "bin/res_got"); + let mut obfuscator = loader.unwrap(); + obfuscator.got_overwrite("system", "secret").unwrap(); + } + + std::process::Command::new("chmod") + .args(["+x", "bin/res_got"]) + .output() + .expect("failed to execute chmod"); + + let output = std::process::Command::new("./bin/res_got") + .output() + .expect("failed to execute res_got"); + + assert_eq!( + String::from_utf8(output.stdout).unwrap(), + "secret function called\n" + ); + } + + #[test] + fn encrypt_function_name() { + let loader = crate::obfus::Obfuscator::open("bin/test_64bit", "bin/res_encrypt"); + let mut obfuscator = loader.unwrap(); + obfuscator.encrypt_function_name("fac", "foo").unwrap(); + + let output = std::process::Command::new("readelf") + .args(["-s", "bin/test_64bit"]) + .output() + .expect("failed to execute readelf"); + assert!(String::from_utf8(output.stdout).is_ok()); + + let output = std::process::Command::new("readelf") + .args(["-s", "bin/res_encrypt"]) + .output() + .expect("failed to execute readelf"); + assert!(String::from_utf8(output.stdout).is_err()); + } }