-
Notifications
You must be signed in to change notification settings - Fork 2.2k
/
fakevalidator.go
108 lines (90 loc) · 2.57 KB
/
fakevalidator.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
// Copyright 2019 The Kubernetes Authors.
// SPDX-License-Identifier: Apache-2.0
// Package valtest_test defines a fakeValidator that can be used in tests
package valtest_test
import (
"errors"
"regexp"
"testing"
)
// fakeValidator can be used in tests.
type fakeValidator struct {
happy bool
called bool
t *testing.T
}
// SAD is an error string.
const SAD = "i'm not happy Bob, NOT HAPPY"
// MakeHappyMapValidator makes a fakeValidator that always passes.
func MakeHappyMapValidator(t *testing.T) *fakeValidator {
return &fakeValidator{happy: true, t: t}
}
// MakeSadMapValidator makes a fakeValidator that always fails.
func MakeSadMapValidator(t *testing.T) *fakeValidator {
return &fakeValidator{happy: false, t: t}
}
// MakeFakeValidator makes an empty Fake Validator.
func MakeFakeValidator() *fakeValidator {
return &fakeValidator{}
}
// ErrIfInvalidKey returns nil
func (v *fakeValidator) ErrIfInvalidKey(_ string) error {
return nil
}
// IsEnvVarName returns nil
func (v *fakeValidator) IsEnvVarName(_ string) error {
return nil
}
// MakeAnnotationValidator returns a nil function
func (v *fakeValidator) MakeAnnotationValidator() func(map[string]string) error {
return nil
}
// MakeAnnotationNameValidator returns a nil function
func (v *fakeValidator) MakeAnnotationNameValidator() func([]string) error {
return nil
}
// MakeLabelValidator returns a nil function
func (v *fakeValidator) MakeLabelValidator() func(map[string]string) error {
return nil
}
// MakeLabelNameValidator returns a nil function
func (v *fakeValidator) MakeLabelNameValidator() func([]string) error {
return nil
}
// ValidateNamespace validates namespace by regexp
func (v *fakeValidator) ValidateNamespace(s string) []string {
pattern := regexp.MustCompile(`^[a-zA-Z].*`)
if pattern.MatchString(s) {
return nil
}
return []string{"doesn't match"}
}
// Validator replaces apimachinery validation in tests.
// Can be set to fail or succeed to test error handling.
// Can confirm if run or not run by surrounding code.
func (v *fakeValidator) Validator(_ map[string]string) error {
v.called = true
if v.happy {
return nil
}
return errors.New(SAD)
}
func (v *fakeValidator) ValidatorArray(_ []string) error {
v.called = true
if v.happy {
return nil
}
return errors.New(SAD)
}
// VerifyCall returns true if Validator was used.
func (v *fakeValidator) VerifyCall() {
if !v.called {
v.t.Errorf("should have called Validator")
}
}
// VerifyNoCall returns true if Validator was not used.
func (v *fakeValidator) VerifyNoCall() {
if v.called {
v.t.Errorf("should not have called Validator")
}
}