2025-05-06 12:29:48 +00:00
|
|
|
randfill
|
2024-01-16 14:00:59 +01:00
|
|
|
======
|
|
|
|
|
2025-05-06 12:29:48 +00:00
|
|
|
randfill is a library for populating go objects with random values.
|
2024-01-16 14:00:59 +01:00
|
|
|
|
2025-05-06 12:29:48 +00:00
|
|
|
This is a fork of github.com/google/gofuzz, which was archived.
|
|
|
|
|
|
|
|
NOTE: This repo is supported only for use within Kubernetes. It is not our
|
|
|
|
intention to support general use. That said, if it works for you, that's
|
|
|
|
great! If you have a problem, please feel free to file an issue, but be aware
|
|
|
|
that it may not be a priority for us to fix it unless it is affecting
|
|
|
|
Kubernetes. PRs are welcome, within reason.
|
|
|
|
|
|
|
|
[](https://godoc.org/sigs.k8s.io/randfill)
|
2024-01-16 14:00:59 +01:00
|
|
|
|
|
|
|
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?
|
|
|
|
|
2025-05-06 12:29:48 +00:00
|
|
|
Import with ```import "sigs.k8s.io/randfill"```
|
2024-01-16 14:00:59 +01:00
|
|
|
|
|
|
|
You can use it on single variables:
|
|
|
|
```go
|
2025-05-06 12:29:48 +00:00
|
|
|
f := randfill.New()
|
2024-01-16 14:00:59 +01:00
|
|
|
var myInt int
|
2025-05-06 12:29:48 +00:00
|
|
|
f.Fill(&myInt) // myInt gets a random value.
|
2024-01-16 14:00:59 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
You can use it on maps:
|
|
|
|
```go
|
2025-05-06 12:29:48 +00:00
|
|
|
f := randfill.New().NilChance(0).NumElements(1, 1)
|
2024-01-16 14:00:59 +01:00
|
|
|
var myMap map[ComplexKeyType]string
|
2025-05-06 12:29:48 +00:00
|
|
|
f.Fill(&myMap) // myMap will have exactly one element.
|
2024-01-16 14:00:59 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
Customize the chance of getting a nil pointer:
|
|
|
|
```go
|
2025-05-06 12:29:48 +00:00
|
|
|
f := randfill.New().NilChance(.5)
|
2024-01-16 14:00:59 +01:00
|
|
|
var fancyStruct struct {
|
|
|
|
A, B, C, D *string
|
|
|
|
}
|
2025-05-06 12:29:48 +00:00
|
|
|
f.Fill(&fancyStruct) // About half the pointers should be set.
|
2024-01-16 14:00:59 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
You can even customize the randomization completely if needed:
|
|
|
|
```go
|
|
|
|
type MyEnum string
|
|
|
|
const (
|
|
|
|
A MyEnum = "A"
|
|
|
|
B MyEnum = "B"
|
|
|
|
)
|
|
|
|
type MyInfo struct {
|
|
|
|
Type MyEnum
|
|
|
|
AInfo *string
|
|
|
|
BInfo *string
|
|
|
|
}
|
|
|
|
|
2025-05-06 12:29:48 +00:00
|
|
|
f := randfill.New().NilChance(0).Funcs(
|
|
|
|
func(e *MyInfo, c randfill.Continue) {
|
2024-01-16 14:00:59 +01:00
|
|
|
switch c.Intn(2) {
|
|
|
|
case 0:
|
|
|
|
e.Type = A
|
2025-05-06 12:29:48 +00:00
|
|
|
c.Fill(&e.AInfo)
|
2024-01-16 14:00:59 +01:00
|
|
|
case 1:
|
|
|
|
e.Type = B
|
2025-05-06 12:29:48 +00:00
|
|
|
c.Fill(&e.BInfo)
|
2024-01-16 14:00:59 +01:00
|
|
|
}
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
var myObject MyInfo
|
2025-05-06 12:29:48 +00:00
|
|
|
f.Fill(&myObject) // Type will correspond to whether A or B info is set.
|
2024-01-16 14:00:59 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
See more examples in ```example_test.go```.
|
|
|
|
|
2025-05-06 12:29:48 +00:00
|
|
|
## dvyukov/go-fuzz integration
|
|
|
|
|
2024-01-16 14:00:59 +01:00
|
|
|
You can use this library for easier [go-fuzz](https://github.com/dvyukov/go-fuzz)ing.
|
|
|
|
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:
|
|
|
|
```go
|
|
|
|
// +build gofuzz
|
|
|
|
package mypackage
|
|
|
|
|
2025-05-06 12:29:48 +00:00
|
|
|
import "sigs.k8s.io/randfill"
|
2024-01-16 14:00:59 +01:00
|
|
|
|
|
|
|
func Fuzz(data []byte) int {
|
|
|
|
var i int
|
2025-05-06 12:29:48 +00:00
|
|
|
randfill.NewFromGoFuzz(data).Fill(&i)
|
2024-01-16 14:00:59 +01:00
|
|
|
MyFunc(i)
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Happy testing!
|