mirror of
https://github.com/mimblewimble/grin.git
synced 2025-01-21 19:41:08 +03:00
36 lines
858 B
Markdown
36 lines
858 B
Markdown
|
# Fuzz testing
|
||
|
|
||
|
## Installation
|
||
|
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 tx_read
|
||
|
|
||
|
cargo fuzz run block_read
|
||
|
|
||
|
cargo fuzz run compact_block_read
|
||
|
|
||
|
```
|
||
|
Check `fuzz/Cargo.toml` for the full list of targets.
|