Skip to content

Commit

Permalink
tests/fuzzers: improve the fuzzers (ethereum#21829)
Browse files Browse the repository at this point in the history
* tests/fuzzers, common/bitutil: make fuzzers use correct returnvalues + remove output

* tests/fuzzers/stacktrie: fix duplicate-key insertion in stacktrie (false positive)

* tests/fuzzers/stacktrie: fix compilation error

* tests/fuzzers: linter nits
  • Loading branch information
holiman authored Nov 13, 2020
1 parent 9ded4e3 commit 0703c91
Show file tree
Hide file tree
Showing 5 changed files with 33 additions and 20 deletions.
6 changes: 3 additions & 3 deletions common/bitutil/compress_fuzz.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ import "bytes"
// invocations.
func Fuzz(data []byte) int {
if len(data) == 0 {
return -1
return 0
}
if data[0]%2 == 0 {
return fuzzEncode(data[1:])
Expand All @@ -39,7 +39,7 @@ func fuzzEncode(data []byte) int {
if !bytes.Equal(data, proc) {
panic("content mismatch")
}
return 0
return 1
}

// fuzzDecode implements a go-fuzz fuzzer method to test the bit decoding and
Expand All @@ -52,5 +52,5 @@ func fuzzDecode(data []byte) int {
if comp := bitsetEncodeBytes(blob); !bytes.Equal(comp, data) {
panic("content mismatch")
}
return 0
return 1
}
2 changes: 1 addition & 1 deletion tests/fuzzers/keystore/keystore-fuzzer.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,5 +33,5 @@ func Fuzz(input []byte) int {
panic(err)
}
os.Remove(a.URL.Path)
return 0
return 1
}
16 changes: 8 additions & 8 deletions tests/fuzzers/rlp/rlp_fuzzer.go
Original file line number Diff line number Diff line change
Expand Up @@ -37,17 +37,17 @@ func decodeEncode(input []byte, val interface{}, i int) {
}

func Fuzz(input []byte) int {
if len(input) == 0 {
return 0
}

var i int
{
if len(input) > 0 {
rlp.Split(input)
}
rlp.Split(input)
}
{
if len(input) > 0 {
if elems, _, err := rlp.SplitList(input); err == nil {
rlp.CountValues(elems)
}
if elems, _, err := rlp.SplitList(input); err == nil {
rlp.CountValues(elems)
}
}

Expand Down Expand Up @@ -123,5 +123,5 @@ func Fuzz(input []byte) int {
var rs types.Receipts
decodeEncode(input, &rs, i)
}
return 0
return 1
}
7 changes: 7 additions & 0 deletions tests/fuzzers/stacktrie/trie_fuzzer.go
Original file line number Diff line number Diff line change
Expand Up @@ -148,6 +148,8 @@ func (f *fuzzer) fuzz() int {
vals kvs
useful bool
maxElements = 10000
// operate on unique keys only
keys = make(map[string]struct{})
)
// Fill the trie with elements
for i := 0; !f.exhausted && i < maxElements; i++ {
Expand All @@ -158,6 +160,11 @@ func (f *fuzzer) fuzz() int {
// thus 'deletion' which is not supported on stacktrie
break
}
if _, present := keys[string(k)]; present {
// This key is a duplicate, ignore it
continue
}
keys[string(k)] = struct{}{}
vals = append(vals, kv{k: k, v: v})
trieA.Update(k, v)
useful = true
Expand Down
22 changes: 14 additions & 8 deletions tests/fuzzers/txfetcher/txfetcher_fuzzer.go
Original file line number Diff line number Diff line change
Expand Up @@ -51,8 +51,9 @@ func init() {
func Fuzz(input []byte) int {
// Don't generate insanely large test cases, not much value in them
if len(input) > 16*1024 {
return -1
return 0
}
verbose := false
r := bytes.NewReader(input)

// Reduce the problem space for certain fuzz runs. Small tx space is better
Expand Down Expand Up @@ -124,7 +125,9 @@ func Fuzz(input []byte) int {
announceIdxs[i] = (int(annBuf[0])*256 + int(annBuf[1])) % len(txs)
announces[i] = txs[announceIdxs[i]].Hash()
}
fmt.Println("Notify", peer, announceIdxs)
if verbose {
fmt.Println("Notify", peer, announceIdxs)
}
if err := f.Notify(peer, announces); err != nil {
panic(err)
}
Expand Down Expand Up @@ -163,8 +166,9 @@ func Fuzz(input []byte) int {
return 0
}
direct := (directFlag % 2) == 0

fmt.Println("Enqueue", peer, deliverIdxs, direct)
if verbose {
fmt.Println("Enqueue", peer, deliverIdxs, direct)
}
if err := f.Enqueue(peer, deliveries, direct); err != nil {
panic(err)
}
Expand All @@ -177,8 +181,9 @@ func Fuzz(input []byte) int {
return 0
}
peer := peers[int(peerIdx)%len(peers)]

fmt.Println("Drop", peer)
if verbose {
fmt.Println("Drop", peer)
}
if err := f.Drop(peer); err != nil {
panic(err)
}
Expand All @@ -191,8 +196,9 @@ func Fuzz(input []byte) int {
return 0
}
tick := time.Duration(tickCnt) * 100 * time.Millisecond

fmt.Println("Sleep", tick)
if verbose {
fmt.Println("Sleep", tick)
}
clock.Run(tick)
}
}
Expand Down

0 comments on commit 0703c91

Please sign in to comment.