diff --git a/fuzz/Cargo.toml b/fuzz/Cargo.toml index 2f94e945..dc113f96 100644 --- a/fuzz/Cargo.toml +++ b/fuzz/Cargo.toml @@ -11,6 +11,7 @@ cargo-fuzz = true [dependencies] libfuzzer-sys = "0.4" arbitrary = { version = "1.3.0", features = ["derive"] } +replace_with = "0.1.7" [dependencies.zip] path = ".." diff --git a/fuzz/fuzz_targets/fuzz_write.rs b/fuzz/fuzz_targets/fuzz_write.rs index 3f03edb5..046eb81c 100644 --- a/fuzz/fuzz_targets/fuzz_write.rs +++ b/fuzz/fuzz_targets/fuzz_write.rs @@ -2,7 +2,7 @@ use arbitrary::Arbitrary; use libfuzzer_sys::fuzz_target; -use std::cell::RefCell; +use replace_with::replace_with_or_abort; use std::io::{Cursor, Read, Seek, Write}; use std::path::PathBuf; @@ -37,7 +37,7 @@ pub struct FuzzTestCase { } fn do_operation( - writer: &mut RefCell>, + writer: &mut zip::ZipWriter, operation: &FileOperation, abort: bool, flush_on_finish_file: bool, @@ -45,9 +45,7 @@ fn do_operation( where T: Read + Write + Seek, { - writer - .borrow_mut() - .set_flush_on_finish_file(flush_on_finish_file); + writer.set_flush_on_finish_file(flush_on_finish_file); let path = &operation.path; match &operation.basic { BasicFileOperation::WriteNormalFile { @@ -60,44 +58,44 @@ where if uncompressed_size >= u32::MAX as usize { options = options.large_file(true); } - writer.borrow_mut().start_file_from_path(path, options)?; + writer.start_file_from_path(path, options)?; for chunk in contents { - writer.borrow_mut().write_all(chunk.as_slice())?; + writer.write_all(chunk.as_slice())?; } } BasicFileOperation::WriteDirectory(options) => { - writer.borrow_mut().add_directory_from_path(path, options.to_owned())?; + writer.add_directory_from_path(path, options.to_owned())?; } BasicFileOperation::WriteSymlinkWithTarget { target, options } => { - writer - .borrow_mut() - .add_symlink_from_path(&path, target, options.to_owned())?; + writer.add_symlink_from_path(&path, target, options.to_owned())?; } BasicFileOperation::ShallowCopy(base) => { do_operation(writer, &base, false, flush_on_finish_file)?; - writer.borrow_mut().shallow_copy_file_from_path(&base.path, &path)?; + writer.shallow_copy_file_from_path(&base.path, &path)?; } BasicFileOperation::DeepCopy(base) => { do_operation(writer, &base, false, flush_on_finish_file)?; - writer.borrow_mut().deep_copy_file_from_path(&base.path, &path)?; + writer.deep_copy_file_from_path(&base.path, &path)?; } } if abort { - writer.borrow_mut().abort_file().unwrap(); + writer.abort_file().unwrap(); } if operation.reopen { - let old_comment = writer.borrow().get_raw_comment().to_owned(); - let new_writer = - zip::ZipWriter::new_append(writer.borrow_mut().finish().unwrap()).unwrap(); - assert_eq!(&old_comment, new_writer.get_raw_comment()); - *writer = new_writer.into(); + let old_comment = writer.get_raw_comment().to_owned(); + replace_with_or_abort(writer, |old_writer: zip::ZipWriter| { + let new_writer = + zip::ZipWriter::new_append(old_writer.finish().unwrap()).unwrap(); + assert_eq!(&old_comment, new_writer.get_raw_comment()); + new_writer + }); } Ok(()) } fuzz_target!(|test_case: FuzzTestCase| { - let mut writer = RefCell::new(zip::ZipWriter::new(Cursor::new(Vec::new()))); - writer.borrow_mut().set_raw_comment(test_case.comment); + let mut writer = zip::ZipWriter::new(Cursor::new(Vec::new())); + writer.set_raw_comment(test_case.comment); for (operation, abort) in test_case.operations { let _ = do_operation( &mut writer, @@ -106,5 +104,5 @@ fuzz_target!(|test_case: FuzzTestCase| { test_case.flush_on_finish_file, ); } - let _ = zip::ZipArchive::new(writer.borrow_mut().finish().unwrap()); + let _ = zip::ZipArchive::new(writer.finish().unwrap()); });