Commit graph

72 commits

Author SHA1 Message Date
Chris Hennick
a2ed77abd3
Bug fixes 2023-05-13 14:29:00 -07:00
Chris Hennick
546693a6c7
Test allowing ZIP64 magic with the sanity checks 2023-05-12 08:36:33 -07:00
Chris Hennick
bf867c5012
Bug fix: skip invalid filenames during write fuzz 2023-05-11 19:25:32 -07:00
Chris Hennick
3af7f187d7
Strengthen fuzz_write: can now close and reopen before copying 2023-05-10 14:54:21 -07:00
Chris Hennick
08ec7ca710
Remove extra data from struct since we're not using it 2023-05-04 16:18:48 -07:00
Chris Hennick
d5e45f3c20
Add abort_file, and call it when validations fail 2023-05-04 10:20:47 -07:00
Chris Hennick
04654fdbe3
Revert large-file test: impractical 2023-05-01 17:06:37 -07:00
Chris Hennick
78139acfae
Prevent WriteLarge from running with no compression 2023-05-01 16:43:38 -07:00
Chris Hennick
1006ddb0e9
Bug fix: need to make a copy 2023-05-01 16:10:59 -07:00
Chris Hennick
29237770c9
Prevent sparse-file chunks from repeating zero times 2023-05-01 16:06:42 -07:00
Chris Hennick
69bb01d535
Allow repetition inside non-default chunks of sparse files 2023-05-01 16:05:27 -07:00
Chris Hennick
c18fae1f77
Use sparse files that are mostly the same byte pattern 2023-05-01 16:01:38 -07:00
Chris Hennick
5220222f84
Bug fix 2023-05-01 15:35:36 -07:00
Chris Hennick
bc14c1ef5e
Set a minimum size for non-repeating chunks 2023-05-01 15:08:20 -07:00
Chris Hennick
09d1ef2e3b
Make large files more compressible 2023-05-01 14:59:04 -07:00
Chris Hennick
a9aaea306e
Make large files more likely 2023-05-01 13:02:52 -07:00
Chris Hennick
6582e13fc4
Make large files more likely 2023-05-01 12:29:25 -07:00
Chris Hennick
a23e3889e2
Strengthen fuzz_write: use longer vectors and multiple writes 2023-05-01 11:56:46 -07:00
Chris Hennick
90b89b5460
WIP: Write fuzzing 2023-04-29 21:19:31 -07:00
Chris Hennick
2f1d73851c
Fix fuzz dependency 2023-04-23 15:03:17 -07:00
Chris Hennick
cde5d5ed11
Implement shallow copy from within the file being written 2023-04-23 14:33:10 -07:00
Nick Babcock
b7966a8538 Add read fuzzing module
As someone who has personal projects that take untrusted zips as input,
it is important to me to be able to fuzz the zip project to simulate
possible inputs and to ensure the projects are not vulnerable.

This commit adds a cargo fuzz module for reading and extracting input.

The `fuzz` directory was scaffolded with a `cargo fuzz init`

I added a CI step to guard against the fuzz module decaying over time.
2022-04-25 20:08:53 -05:00