forked from giantswarm/azure-admission-controller
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdefault_k8sclient.go
122 lines (106 loc) · 3.01 KB
/
default_k8sclient.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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
package unittest
import (
corev1alpha1 "github.com/giantswarm/apiextensions/v3/pkg/apis/core/v1alpha1"
providerv1alpha1 "github.com/giantswarm/apiextensions/v3/pkg/apis/provider/v1alpha1"
releasev1alpha1 "github.com/giantswarm/apiextensions/v3/pkg/apis/release/v1alpha1"
securityv1alpha1 "github.com/giantswarm/apiextensions/v3/pkg/apis/security/v1alpha1"
"github.com/giantswarm/apiextensions/v3/pkg/clientset/versioned"
fakeg8s "github.com/giantswarm/apiextensions/v3/pkg/clientset/versioned/fake"
"github.com/giantswarm/k8sclient/v5/pkg/k8sclient"
"github.com/giantswarm/k8sclient/v5/pkg/k8scrdclient"
apiextensionsclient "k8s.io/apiextensions-apiserver/pkg/client/clientset/clientset"
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/client-go/dynamic"
"k8s.io/client-go/kubernetes"
fakek8s "k8s.io/client-go/kubernetes/fake"
"k8s.io/client-go/rest"
capz "sigs.k8s.io/cluster-api-provider-azure/api/v1alpha3"
capzexp "sigs.k8s.io/cluster-api-provider-azure/exp/api/v1alpha3"
capi "sigs.k8s.io/cluster-api/api/v1alpha3"
capiexp "sigs.k8s.io/cluster-api/exp/api/v1alpha3"
"sigs.k8s.io/controller-runtime/pkg/client"
"sigs.k8s.io/controller-runtime/pkg/client/fake" //nolint:staticcheck
)
type fakeK8sClient struct {
ctrlClient client.Client
k8sClient *fakek8s.Clientset
g8sclient *fakeg8s.Clientset
}
func FakeK8sClient() k8sclient.Interface {
var err error
var k8sClient k8sclient.Interface
{
scheme := runtime.NewScheme()
err = corev1alpha1.AddToScheme(scheme)
if err != nil {
panic(err)
}
err = capiexp.AddToScheme(scheme)
if err != nil {
panic(err)
}
err = capzexp.AddToScheme(scheme)
if err != nil {
panic(err)
}
err = capi.AddToScheme(scheme)
if err != nil {
panic(err)
}
err = capz.AddToScheme(scheme)
if err != nil {
panic(err)
}
err = providerv1alpha1.AddToScheme(scheme)
if err != nil {
panic(err)
}
err = releasev1alpha1.AddToScheme(scheme)
if err != nil {
panic(err)
}
err = securityv1alpha1.AddToScheme(scheme)
if err != nil {
panic(err)
}
_ = fakek8s.AddToScheme(scheme)
k8sclient := fakek8s.NewSimpleClientset()
g8sclient := fakeg8s.NewSimpleClientset()
k8sClient = &fakeK8sClient{
ctrlClient: fake.NewFakeClientWithScheme(scheme),
k8sClient: k8sclient,
g8sclient: g8sclient,
}
}
return k8sClient
}
func (f *fakeK8sClient) CRDClient() k8scrdclient.Interface {
return nil
}
func (f *fakeK8sClient) CtrlCache() client.Reader {
return f.ctrlClient
}
func (f *fakeK8sClient) CtrlClient() client.Client {
return f.ctrlClient
}
func (f *fakeK8sClient) DynClient() dynamic.Interface {
return nil
}
func (f *fakeK8sClient) ExtClient() apiextensionsclient.Interface {
return nil
}
func (f *fakeK8sClient) G8sClient() versioned.Interface {
return f.g8sclient
}
func (f *fakeK8sClient) K8sClient() kubernetes.Interface {
return f.k8sClient
}
func (f *fakeK8sClient) RESTClient() rest.Interface {
return nil
}
func (f *fakeK8sClient) RESTConfig() *rest.Config {
return nil
}
func (f *fakeK8sClient) Scheme() *runtime.Scheme {
return nil
}