grin/core/fuzz
hashmap 16487a3eb7
[1.1.0] Bring fuzz test back (#2675)
Corpus generation was updated and simplified, plus small updates
2019-03-15 15:32:14 +01:00
..
fuzz_targets [1.1.0] Bring fuzz test back (#2675) 2019-03-15 15:32:14 +01:00
src [1.1.0] Bring fuzz test back (#2675) 2019-03-15 15:32:14 +01:00
.gitignore Introduce fuzz tests for core (#844) 2018-03-22 16:53:47 +00:00
Cargo.lock [1.1.0] Bring fuzz test back (#2675) 2019-03-15 15:32:14 +01:00
Cargo.toml comment out fuzz tests for now, remove wallet crate reference (#2635) 2019-02-27 11:12:09 +00:00
README.md [1.1.0] Bring fuzz test back (#2675) 2019-03-15 15:32:14 +01:00

Fuzz testing

Installation

You have to use Rust nightly at the moment. Cargo-fuzz (https://github.com/rust-fuzz/cargo-fuzz) has been used. To install it:

cargo install cargo-fuzz

Pattern generation for corpus

This step is optional, libFuzz will generate random patterns to populate corpus (in folder corpus). However we can genearete more meaningful pattern e.g. use serialized form of a real block or transaction. To generate them:

cd fuzz

cargo run --bin  gen-corpus

Run tests

Fuzz test is basically infinite test, run it for some period of time then stop if no failures are found. To run the tests make sure youre in folder core otherwise you may get some misleading errors, then run one of the following tests:

cargo fuzz run transaction_read

cargo fuzz run block_read

cargo fuzz run compact_block_read

Run

cargo fuzz list

or check fuzz/Cargo.toml for the full list of targets.