Fuzzing: Initial commit
Signed-off-by: AdamKorcz <adam@adalogics.com>
This commit is contained in:
parent
0246b7d42a
commit
c4d512399c
|
@ -0,0 +1,21 @@
|
|||
FROM golang:1.16-buster as builder
|
||||
|
||||
RUN apt-get update && apt-get install -y clang git
|
||||
RUN git clone --branch fuzz1 --depth 1 https://github.com/AdamKorcz/helm-controller /helm-controller
|
||||
COPY fuzz.go /helm-controller/controllers/
|
||||
RUN cd /helm-controller/controllers \
|
||||
&& go get github.com/AdaLogics/go-fuzz-headers
|
||||
|
||||
RUN cd / \
|
||||
&& go get -u github.com/mdempsky/go114-fuzz-build
|
||||
|
||||
RUN mkdir /fuzzers
|
||||
RUN cd /helm-controller/controllers \
|
||||
&& go114-fuzz-build -o FuzzHelmreleaseComposeValues.a -func FuzzHelmreleaseComposeValues . \
|
||||
&& clang -o /fuzzers/FuzzHelmreleaseComposeValues FuzzHelmreleaseComposeValues.a -fsanitize=fuzzer
|
||||
RUN cd /helm-controller/controllers \
|
||||
&& go114-fuzz-build -o FuzzHelmreleasereconcile.a -func FuzzHelmreleasereconcile . \
|
||||
&& clang -o /fuzzers/FuzzHelmreleasereconcile FuzzHelmreleasereconcile.a -fsanitize=fuzzer
|
||||
|
||||
# Uncomment here to run the fuzzer
|
||||
#RUN /fuzzers/FuzzHelmreleaseComposeValues
|
|
@ -0,0 +1,147 @@
|
|||
//go:build gofuzz
|
||||
// +build gofuzz
|
||||
|
||||
/*
|
||||
Copyright 2020 The Flux authors
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
*/
|
||||
package controllers
|
||||
|
||||
import (
|
||||
"context"
|
||||
v2 "github.com/fluxcd/helm-controller/api/v2beta1"
|
||||
"github.com/go-logr/logr"
|
||||
corev1 "k8s.io/api/core/v1"
|
||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||
"k8s.io/apimachinery/pkg/runtime"
|
||||
"sigs.k8s.io/controller-runtime/pkg/client/fake"
|
||||
"sigs.k8s.io/controller-runtime/pkg/log"
|
||||
"sync"
|
||||
|
||||
fuzz "github.com/AdaLogics/go-fuzz-headers"
|
||||
)
|
||||
|
||||
var (
|
||||
initter sync.Once
|
||||
scheme *runtime.Scheme
|
||||
)
|
||||
|
||||
// An init function that is invoked by way of sync.Do
|
||||
func initFunc() {
|
||||
scheme = runtime.NewScheme()
|
||||
err := corev1.AddToScheme(scheme)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
err = v2.AddToScheme(scheme)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
}
|
||||
|
||||
// FuzzHelmreleaseComposeValues implements a fuzzer
|
||||
// that targets HelmReleaseReconciler.composeValues()
|
||||
func FuzzHelmreleaseComposeValues(data []byte) int {
|
||||
initter.Do(initFunc)
|
||||
|
||||
f := fuzz.NewConsumer(data)
|
||||
|
||||
hr := v2.HelmRelease{}
|
||||
err := f.GenerateStruct(&hr)
|
||||
if err != nil {
|
||||
return 0
|
||||
}
|
||||
|
||||
r, err := createReconciler(f)
|
||||
if err != nil {
|
||||
return 0
|
||||
}
|
||||
|
||||
_, _ = r.composeValues(logr.NewContext(context.TODO(), log.NullLogger{}), hr)
|
||||
return 1
|
||||
}
|
||||
|
||||
// FuzzHelmreleasereconcile implements a fuzzer
|
||||
// that targets HelmReleaseReconciler.reconcile()
|
||||
func FuzzHelmreleasereconcile(data []byte) int {
|
||||
initter.Do(initFunc)
|
||||
|
||||
f := fuzz.NewConsumer(data)
|
||||
|
||||
hr := v2.HelmRelease{}
|
||||
err := f.GenerateStruct(&hr)
|
||||
if err != nil {
|
||||
return 0
|
||||
}
|
||||
|
||||
r, err := createReconciler(f)
|
||||
if err != nil {
|
||||
return 0
|
||||
}
|
||||
|
||||
_, _, _ = r.reconcile(logr.NewContext(context.TODO(), log.NullLogger{}), hr)
|
||||
return 1
|
||||
}
|
||||
|
||||
// Allows the fuzzer to create a reconciler
|
||||
func createReconciler(f *fuzz.ConsumeFuzzer) (*HelmReleaseReconciler, error) {
|
||||
// Get the type of object:
|
||||
var resources []runtime.Object
|
||||
r := &HelmReleaseReconciler{}
|
||||
getSecret, err := f.GetBool()
|
||||
if err != nil {
|
||||
return r, err
|
||||
}
|
||||
name, err := f.GetString()
|
||||
if err != nil {
|
||||
return r, err
|
||||
}
|
||||
if getSecret {
|
||||
inputMap := make(map[string][]byte)
|
||||
err = f.FuzzMap(&inputMap)
|
||||
if err != nil {
|
||||
return r, err
|
||||
}
|
||||
resources = []runtime.Object{
|
||||
valuesSecret(name, inputMap),
|
||||
}
|
||||
} else {
|
||||
inputMap := make(map[string]string)
|
||||
err = f.FuzzMap(&inputMap)
|
||||
if err != nil {
|
||||
return r, err
|
||||
}
|
||||
resources = []runtime.Object{
|
||||
valuesConfigMap(name, inputMap),
|
||||
}
|
||||
}
|
||||
c := fake.NewFakeClientWithScheme(scheme, resources...)
|
||||
r.Client = c
|
||||
return r, nil
|
||||
}
|
||||
|
||||
// Taken from
|
||||
// https://github.com/fluxcd/helm-controller/blob/main/controllers/helmrelease_controller_test.go#L282
|
||||
func valuesSecret(name string, data map[string][]byte) *corev1.Secret {
|
||||
return &corev1.Secret{
|
||||
ObjectMeta: metav1.ObjectMeta{Name: name},
|
||||
Data: data,
|
||||
}
|
||||
}
|
||||
|
||||
// Taken from
|
||||
// https://github.com/fluxcd/helm-controller/blob/main/controllers/helmrelease_controller_test.go#L289
|
||||
func valuesConfigMap(name string, data map[string]string) *corev1.ConfigMap {
|
||||
return &corev1.ConfigMap{
|
||||
ObjectMeta: metav1.ObjectMeta{Name: name},
|
||||
Data: data,
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue