sample-controller/vendor/github.com/google/gofuzz
Kubernetes Publisher cfd89cde21 Merge pull request #72947 from apelisse/wip-feature-serverside-apply-merge
Merge feature-serverside-apply back in master

Kubernetes-commit: 2a5a41a08b08075aa2960170c8342d974ccc2cd3
2019-02-05 05:30:45 +00:00
..
.travis.yml Merge pull request #52753 from munnerz/sample-controller 2017-10-26 12:35:59 +00:00
CONTRIBUTING.md Merge pull request #52753 from munnerz/sample-controller 2017-10-26 12:35:59 +00:00
doc.go Merge pull request #52753 from munnerz/sample-controller 2017-10-26 12:35:59 +00:00
fuzz.go Merge pull request #72947 from apelisse/wip-feature-serverside-apply-merge 2019-02-05 05:30:45 +00:00
LICENSE Merge pull request #52753 from munnerz/sample-controller 2017-10-26 12:35:59 +00:00
README.md Merge pull request #52753 from munnerz/sample-controller 2017-10-26 12:35:59 +00:00

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.

Happy testing!