aboutsummaryrefslogtreecommitdiff
path: root/src/internal/fuzz
diff options
context:
space:
mode:
authorRoland Shoemaker <roland@golang.org>2022-01-30 11:21:28 -0800
committerRoland Shoemaker <roland@golang.org>2022-02-01 16:10:04 +0000
commit93fe469de5388b71af2aa2c959dc485fa3d4bee3 (patch)
tree7a7abb7ad22fadffc59524fa16b8d6b0b59c749b /src/internal/fuzz
parentf1e7dcb49cba50203d656f931c3fb90b29727629 (diff)
downloadgo-93fe469de5388b71af2aa2c959dc485fa3d4bee3.tar.xz
internal/fuzz: properly handle duplicates during cache loading
When loading the corpus, if the cache contained an entry which was a duplicate of an entry added using f.Add, coordinator.addCorpusEntries would return early, ignoring everything after this entry in the cache. Instead, skip duplicates as intended, and continue to load the rest of the cache. Fixes #50913 Change-Id: I3a64b93cbb217c5c364a9f8d0005752e9e9d10ff Reviewed-on: https://go-review.googlesource.com/c/go/+/381960 Trust: Katie Hockman <katie@golang.org> Reviewed-by: Katie Hockman <katie@golang.org> Trust: Roland Shoemaker <roland@golang.org> Run-TryBot: Roland Shoemaker <roland@golang.org> TryBot-Result: Gopher Robot <gobot@golang.org>
Diffstat (limited to 'src/internal/fuzz')
-rw-r--r--src/internal/fuzz/fuzz.go20
1 files changed, 15 insertions, 5 deletions
diff --git a/src/internal/fuzz/fuzz.go b/src/internal/fuzz/fuzz.go
index 73f32dd4c7..f2ff3a1390 100644
--- a/src/internal/fuzz/fuzz.go
+++ b/src/internal/fuzz/fuzz.go
@@ -316,12 +316,12 @@ func CoordinateFuzzing(ctx context.Context, opts CoordinateFuzzingOpts) (err err
} else {
// Update the coordinator's coverage mask and save the value.
inputSize := len(result.entry.Data)
- duplicate, err := c.addCorpusEntries(true, result.entry)
+ entryNew, err := c.addCorpusEntries(true, result.entry)
if err != nil {
stop(err)
break
}
- if duplicate {
+ if !entryNew {
continue
}
c.updateCoverage(keepCoverage)
@@ -419,11 +419,21 @@ type corpus struct {
hashes map[[sha256.Size]byte]bool
}
+// addCorpusEntries adds entries to the corpus, and optional also writes the entries
+// to the cache directory. If an entry is already in the corpus it is skipped. If
+// all of the entries are unique, addCorpusEntries returns true and a nil error,
+// if at least one of the entries was a duplicate, it returns false and a nil error.
func (c *coordinator) addCorpusEntries(addToCache bool, entries ...CorpusEntry) (bool, error) {
+ noDupes := true
for _, e := range entries {
- h := sha256.Sum256(e.Data)
+ data, err := CorpusEntryData(e)
+ if err != nil {
+ return false, err
+ }
+ h := sha256.Sum256(data)
if c.corpus.hashes[h] {
- return true, nil
+ noDupes = false
+ continue
}
if addToCache {
if err := writeToCorpus(&e, c.opts.CacheDir); err != nil {
@@ -437,7 +447,7 @@ func (c *coordinator) addCorpusEntries(addToCache bool, entries ...CorpusEntry)
c.corpus.hashes[h] = true
c.corpus.entries = append(c.corpus.entries, e)
}
- return false, nil
+ return noDupes, nil
}
// CorpusEntry represents an individual input for fuzzing.