caching/vendor/github.com/google/gofuzz
knative-automation a31ce17164
upgrade to latest dependencies (#438)
bumping github.com/google/go-cmp ec71d6d...8fa37b4:
  > 8fa37b4 Fix reporter verbosity bug (# 253)
  > dc6435e De-virtualize interfaces for specialized diffing (# 254)
  > e9947a2 Run tests on Go 1.16 (# 252)
  > 3a98a11 cmp/cmpopts: use errors.Is with ≥go1.13 in compareErrors (# 251)
bumping knative.dev/pkg 4048853...6a33a1a:
  > 6a33a1a Upgrade a few assorted dependencies (# 2058)

Signed-off-by: Knative Automation <automation@knative.team>
2021-03-15 11:59:01 -07:00
..
bytesource upgrade to latest dependencies (#438) 2021-03-15 11:59:01 -07:00
.travis.yml upgrade to latest dependencies (#438) 2021-03-15 11:59:01 -07:00
CONTRIBUTING.md upgrade to latest dependencies (#438) 2021-03-15 11:59:01 -07:00
LICENSE Add the initial caching type definitions. (#5) 2018-09-07 09:56:33 -07:00
README.md upgrade to latest dependencies (#438) 2021-03-15 11:59:01 -07:00
doc.go Add the initial caching type definitions. (#5) 2018-09-07 09:56:33 -07:00
fuzz.go upgrade to latest dependencies (#438) 2021-03-15 11:59:01 -07:00
go.mod Migrate caching to go mod (#258) 2020-04-27 14:35:51 -07:00

README.md

gofuzz

gofuzz is a library for populating go objects with random values.

GoDoc Travis

This is useful for testing:

  • Do your project's objects really serialize/unserialize correctly in all cases?
  • Is there an incorrectly formatted object that will cause your project to panic?

Import with import "github.com/google/gofuzz"

You can use it on single variables:

f := fuzz.New()
var myInt int
f.Fuzz(&myInt) // myInt gets a random value.

You can use it on maps:

f := fuzz.New().NilChance(0).NumElements(1, 1)
var myMap map[ComplexKeyType]string
f.Fuzz(&myMap) // myMap will have exactly one element.

Customize the chance of getting a nil pointer:

f := fuzz.New().NilChance(.5)
var fancyStruct struct {
  A, B, C, D *string
}
f.Fuzz(&fancyStruct) // About half the pointers should be set.

You can even customize the randomization completely if needed:

type MyEnum string
const (
        A MyEnum = "A"
        B MyEnum = "B"
)
type MyInfo struct {
        Type MyEnum
        AInfo *string
        BInfo *string
}

f := fuzz.New().NilChance(0).Funcs(
        func(e *MyInfo, c fuzz.Continue) {
                switch c.Intn(2) {
                case 0:
                        e.Type = A
                        c.Fuzz(&e.AInfo)
                case 1:
                        e.Type = B
                        c.Fuzz(&e.BInfo)
                }
        },
)

var myObject MyInfo
f.Fuzz(&myObject) // Type will correspond to whether A or B info is set.

See more examples in example_test.go.

You can use this library for easier go-fuzzing. go-fuzz provides the user a byte-slice, which should be converted to different inputs for the tested function. This library can help convert the byte slice. Consider for example a fuzz test for a the function mypackage.MyFunc that takes an int arguments:

// +build gofuzz
package mypackage

import fuzz "github.com/google/gofuzz"

func Fuzz(data []byte) int {
        var i int
        fuzz.NewFromGoFuzz(data).Fuzz(&i)
        MyFunc(i)
        return 0
}

Happy testing!