mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-11-03 19:58:17 +00:00 
			
		
		
		
	https: //docs.google.com/document/d/1-CKDPRHsG6XfnGs-Bb7ptWgDtTq9-hj8aJQpGz1CSh8/edit Change-Id: If7134a5553b4ecc12b1d58ffc52ebb9f8594778a
		
			
				
	
	
		
			137 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			137 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
/*
 | 
						|
Copyright 2017 The Kubernetes 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 fuzzer
 | 
						|
 | 
						|
import (
 | 
						|
	"fmt"
 | 
						|
	"net/netip"
 | 
						|
 | 
						|
	fuzz "github.com/google/gofuzz"
 | 
						|
	runtimeserializer "k8s.io/apimachinery/pkg/runtime/serializer"
 | 
						|
	"k8s.io/kubernetes/pkg/apis/networking"
 | 
						|
	utilpointer "k8s.io/utils/pointer"
 | 
						|
)
 | 
						|
 | 
						|
// Funcs returns the fuzzer functions for the networking api group.
 | 
						|
var Funcs = func(codecs runtimeserializer.CodecFactory) []interface{} {
 | 
						|
	return []interface{}{
 | 
						|
		func(np *networking.NetworkPolicyPeer, c fuzz.Continue) {
 | 
						|
			c.FuzzNoCustom(np) // fuzz self without calling this function again
 | 
						|
			// TODO: Implement a fuzzer to generate valid keys, values and operators for
 | 
						|
			// selector requirements.
 | 
						|
			if np.IPBlock != nil {
 | 
						|
				np.IPBlock = &networking.IPBlock{
 | 
						|
					CIDR:   "192.168.1.0/24",
 | 
						|
					Except: []string{"192.168.1.1/24", "192.168.1.2/24"},
 | 
						|
				}
 | 
						|
			}
 | 
						|
		},
 | 
						|
		func(np *networking.NetworkPolicy, c fuzz.Continue) {
 | 
						|
			c.FuzzNoCustom(np) // fuzz self without calling this function again
 | 
						|
			// TODO: Implement a fuzzer to generate valid keys, values and operators for
 | 
						|
			// selector requirements.
 | 
						|
			if len(np.Spec.PolicyTypes) == 0 {
 | 
						|
				np.Spec.PolicyTypes = []networking.PolicyType{networking.PolicyTypeIngress}
 | 
						|
			}
 | 
						|
		},
 | 
						|
		func(path *networking.HTTPIngressPath, c fuzz.Continue) {
 | 
						|
			c.FuzzNoCustom(path) // fuzz self without calling this function again
 | 
						|
			pathTypes := []networking.PathType{networking.PathTypeExact, networking.PathTypePrefix, networking.PathTypeImplementationSpecific}
 | 
						|
			path.PathType = &pathTypes[c.Rand.Intn(len(pathTypes))]
 | 
						|
		},
 | 
						|
		func(p *networking.ServiceBackendPort, c fuzz.Continue) {
 | 
						|
			c.FuzzNoCustom(p)
 | 
						|
			// clear one of the fields
 | 
						|
			if c.RandBool() {
 | 
						|
				p.Name = ""
 | 
						|
				if p.Number == 0 {
 | 
						|
					p.Number = 1
 | 
						|
				}
 | 
						|
			} else {
 | 
						|
				p.Number = 0
 | 
						|
				if p.Name == "" {
 | 
						|
					p.Name = "portname"
 | 
						|
				}
 | 
						|
			}
 | 
						|
		},
 | 
						|
		func(p *networking.IngressClass, c fuzz.Continue) {
 | 
						|
			c.FuzzNoCustom(p) // fuzz self without calling this function again
 | 
						|
			// default Parameters to Cluster
 | 
						|
			if p.Spec.Parameters == nil || p.Spec.Parameters.Scope == nil {
 | 
						|
				p.Spec.Parameters = &networking.IngressClassParametersReference{
 | 
						|
					Scope: utilpointer.String(networking.IngressClassParametersReferenceScopeCluster),
 | 
						|
				}
 | 
						|
			}
 | 
						|
		},
 | 
						|
		func(obj *networking.IPAddress, c fuzz.Continue) {
 | 
						|
			c.FuzzNoCustom(obj) // fuzz self without calling this function again
 | 
						|
			// length in bytes of the IP Family: IPv4: 4 bytes IPv6: 16 bytes
 | 
						|
			boolean := []bool{false, true}
 | 
						|
			is6 := boolean[c.Rand.Intn(2)]
 | 
						|
			ip := generateRandomIP(is6, c)
 | 
						|
			obj.Name = ip
 | 
						|
		},
 | 
						|
		func(obj *networking.ServiceCIDR, c fuzz.Continue) {
 | 
						|
			c.FuzzNoCustom(obj) // fuzz self without calling this function again
 | 
						|
			boolean := []bool{false, true}
 | 
						|
 | 
						|
			is6 := boolean[c.Rand.Intn(2)]
 | 
						|
			primary := generateRandomCIDR(is6, c)
 | 
						|
			obj.Spec.CIDRs = []string{primary}
 | 
						|
 | 
						|
			if boolean[c.Rand.Intn(2)] {
 | 
						|
				obj.Spec.CIDRs = append(obj.Spec.CIDRs, generateRandomCIDR(!is6, c))
 | 
						|
			}
 | 
						|
		},
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func generateRandomIP(is6 bool, c fuzz.Continue) string {
 | 
						|
	n := 4
 | 
						|
	if is6 {
 | 
						|
		n = 16
 | 
						|
	}
 | 
						|
	bytes := make([]byte, n)
 | 
						|
	for i := 0; i < n; i++ {
 | 
						|
		bytes[i] = uint8(c.Rand.Intn(255))
 | 
						|
	}
 | 
						|
 | 
						|
	ip, ok := netip.AddrFromSlice(bytes)
 | 
						|
	if ok {
 | 
						|
		return ip.String()
 | 
						|
	}
 | 
						|
	// this should not happen
 | 
						|
	panic(fmt.Sprintf("invalid IP %v", bytes))
 | 
						|
}
 | 
						|
 | 
						|
func generateRandomCIDR(is6 bool, c fuzz.Continue) string {
 | 
						|
	ip, err := netip.ParseAddr(generateRandomIP(is6, c))
 | 
						|
	if err != nil {
 | 
						|
		// generateRandomIP already panics if returns a not valid ip
 | 
						|
		panic(err)
 | 
						|
	}
 | 
						|
 | 
						|
	n := 32
 | 
						|
	if is6 {
 | 
						|
		n = 128
 | 
						|
	}
 | 
						|
 | 
						|
	bits := c.Rand.Intn(n)
 | 
						|
	prefix := netip.PrefixFrom(ip, bits)
 | 
						|
	return prefix.Masked().String()
 | 
						|
}
 |