# Timeout should not cause inputs to be written as crashers.
! exists testdata/fuzz
+env GOCACHE=$WORK/tmp
+
# When we use fuzztime with an "x" suffix, it runs a specific number of times.
-# This fuzz function creates a file with a unique name ($pid.$count) on each run.
-# We count the files to find the number of runs.
+# This fuzz function creates a file with a unique name ($pid.$count) on each
+# run. We count the files to find the number of runs.
mkdir count
-env GOCACHE=$WORK/tmp
-go test -fuzz=FuzzCount -fuzztime=1000x -fuzzminimizetime=1x
-go run check_file_count.go 1000
+go test -fuzz=FuzzTestCount -fuzztime=1000x -fuzzminimizetime=1x
+go run check_file_count.go count 1000
+
+# When we use fuzzminimizetime with an "x" suffix, it runs a specific number of
+# times while minimizing. This fuzz function creates a file with a unique name
+# ($pid.$count) on each run once the first crash has been found. That means that
+# there should be one file for each execution of the fuzz function during
+# minimization, so we count these to determine how many times minimization was
+# run.
+mkdir minimizecount
+! go test -fuzz=FuzzMinimizeCount -fuzzminimizetime=3x -parallel=1
+go run check_file_count.go minimizecount 3
-- go.mod --
module fuzz
"testing"
)
-func FuzzCount(f *testing.F) {
+func FuzzTestCount(f *testing.F) {
pid := os.Getpid()
n := 0
f.Fuzz(func(t *testing.T, _ []byte) {
n++
})
}
+-- fuzz_minimize_count_test.go --
+package fuzz
+
+import (
+ "bytes"
+ "fmt"
+ "os"
+ "testing"
+)
+
+func FuzzMinimizeCount(f *testing.F) {
+ pid := os.Getpid()
+ n := 0
+ seed := bytes.Repeat([]byte("a"), 357)
+ f.Add(seed)
+ crashFound := false
+ f.Fuzz(func(t *testing.T, b []byte) {
+ if crashFound {
+ name := fmt.Sprintf("minimizecount/%v.%d", pid, n)
+ if err := os.WriteFile(name, nil, 0666); err != nil {
+ t.Fatal(err)
+ }
+ n++
+ }
+ if !bytes.Equal(b, seed) { // this should happen right away
+ crashFound = true
+ t.Error("minimize this!")
+ }
+ })
+}
-- check_file_count.go --
// +build ignore
)
func main() {
- dir, err := os.ReadDir("count")
+ dir, err := os.ReadDir(os.Args[1])
if err != nil {
fmt.Fprintln(os.Stderr, err)
os.Exit(1)
}
got := len(dir)
- want, _ := strconv.Atoi(os.Args[1])
+ want, _ := strconv.Atoi(os.Args[2])
if got != want {
fmt.Fprintf(os.Stderr, "got %d files; want %d\n", got, want)
os.Exit(1)