mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-24 20:24:09 +00:00
Merge pull request #100940 from markusthoemmes/fake-client-interface
Implement a FakeClient interface
This commit is contained in:
commit
8da9d2ff55
@ -74,7 +74,10 @@ func (c *Clientset) Tracker() testing.ObjectTracker {
|
|||||||
return c.tracker
|
return c.tracker
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ clientset.Interface = &Clientset{}
|
var (
|
||||||
|
_ clientset.Interface = &Clientset{}
|
||||||
|
_ testing.FakeClient = &Clientset{}
|
||||||
|
)
|
||||||
|
|
||||||
// CrV1 retrieves the CrV1Client
|
// CrV1 retrieves the CrV1Client
|
||||||
func (c *Clientset) CrV1() crv1.CrV1Interface {
|
func (c *Clientset) CrV1() crv1.CrV1Interface {
|
||||||
|
@ -76,7 +76,10 @@ func (c *Clientset) Tracker() testing.ObjectTracker {
|
|||||||
return c.tracker
|
return c.tracker
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ clientset.Interface = &Clientset{}
|
var (
|
||||||
|
_ clientset.Interface = &Clientset{}
|
||||||
|
_ testing.FakeClient = &Clientset{}
|
||||||
|
)
|
||||||
|
|
||||||
// ApiextensionsV1beta1 retrieves the ApiextensionsV1beta1Client
|
// ApiextensionsV1beta1 retrieves the ApiextensionsV1beta1Client
|
||||||
func (c *Clientset) ApiextensionsV1beta1() apiextensionsv1beta1.ApiextensionsV1beta1Interface {
|
func (c *Clientset) ApiextensionsV1beta1() apiextensionsv1beta1.ApiextensionsV1beta1Interface {
|
||||||
|
@ -115,12 +115,15 @@ type dynamicResourceClient struct {
|
|||||||
listKind string
|
listKind string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
_ dynamic.Interface = &FakeDynamicClient{}
|
||||||
|
_ testing.FakeClient = &FakeDynamicClient{}
|
||||||
|
)
|
||||||
|
|
||||||
func (c *FakeDynamicClient) Tracker() testing.ObjectTracker {
|
func (c *FakeDynamicClient) Tracker() testing.ObjectTracker {
|
||||||
return c.tracker
|
return c.tracker
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ dynamic.Interface = &FakeDynamicClient{}
|
|
||||||
|
|
||||||
func (c *FakeDynamicClient) Resource(resource schema.GroupVersionResource) dynamic.NamespaceableResourceInterface {
|
func (c *FakeDynamicClient) Resource(resource schema.GroupVersionResource) dynamic.NamespaceableResourceInterface {
|
||||||
return &dynamicResourceClient{client: c, resource: resource, listKind: c.gvrToListKind[resource]}
|
return &dynamicResourceClient{client: c, resource: resource, listKind: c.gvrToListKind[resource]}
|
||||||
}
|
}
|
||||||
|
@ -158,7 +158,10 @@ func (c *Clientset) Tracker() testing.ObjectTracker {
|
|||||||
return c.tracker
|
return c.tracker
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ clientset.Interface = &Clientset{}
|
var (
|
||||||
|
_ clientset.Interface = &Clientset{}
|
||||||
|
_ testing.FakeClient = &Clientset{}
|
||||||
|
)
|
||||||
|
|
||||||
// AdmissionregistrationV1 retrieves the AdmissionregistrationV1Client
|
// AdmissionregistrationV1 retrieves the AdmissionregistrationV1Client
|
||||||
func (c *Clientset) AdmissionregistrationV1() admissionregistrationv1.AdmissionregistrationV1Interface {
|
func (c *Clientset) AdmissionregistrationV1() admissionregistrationv1.AdmissionregistrationV1Interface {
|
||||||
|
66
staging/src/k8s.io/client-go/testing/interface.go
Normal file
66
staging/src/k8s.io/client-go/testing/interface.go
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2021 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 testing
|
||||||
|
|
||||||
|
import (
|
||||||
|
"k8s.io/apimachinery/pkg/runtime"
|
||||||
|
"k8s.io/apimachinery/pkg/watch"
|
||||||
|
restclient "k8s.io/client-go/rest"
|
||||||
|
)
|
||||||
|
|
||||||
|
type FakeClient interface {
|
||||||
|
// Tracker gives access to the ObjectTracker internal to the fake client.
|
||||||
|
Tracker() ObjectTracker
|
||||||
|
|
||||||
|
// AddReactor appends a reactor to the end of the chain.
|
||||||
|
AddReactor(verb, resource string, reaction ReactionFunc)
|
||||||
|
|
||||||
|
// PrependReactor adds a reactor to the beginning of the chain.
|
||||||
|
PrependReactor(verb, resource string, reaction ReactionFunc)
|
||||||
|
|
||||||
|
// AddWatchReactor appends a reactor to the end of the chain.
|
||||||
|
AddWatchReactor(resource string, reaction WatchReactionFunc)
|
||||||
|
|
||||||
|
// PrependWatchReactor adds a reactor to the beginning of the chain.
|
||||||
|
PrependWatchReactor(resource string, reaction WatchReactionFunc)
|
||||||
|
|
||||||
|
// AddProxyReactor appends a reactor to the end of the chain.
|
||||||
|
AddProxyReactor(resource string, reaction ProxyReactionFunc)
|
||||||
|
|
||||||
|
// PrependProxyReactor adds a reactor to the beginning of the chain.
|
||||||
|
PrependProxyReactor(resource string, reaction ProxyReactionFunc)
|
||||||
|
|
||||||
|
// Invokes records the provided Action and then invokes the ReactionFunc that
|
||||||
|
// handles the action if one exists. defaultReturnObj is expected to be of the
|
||||||
|
// same type a normal call would return.
|
||||||
|
Invokes(action Action, defaultReturnObj runtime.Object) (runtime.Object, error)
|
||||||
|
|
||||||
|
// InvokesWatch records the provided Action and then invokes the ReactionFunc
|
||||||
|
// that handles the action if one exists.
|
||||||
|
InvokesWatch(action Action) (watch.Interface, error)
|
||||||
|
|
||||||
|
// InvokesProxy records the provided Action and then invokes the ReactionFunc
|
||||||
|
// that handles the action if one exists.
|
||||||
|
InvokesProxy(action Action) restclient.ResponseWrapper
|
||||||
|
|
||||||
|
// ClearActions clears the history of actions called on the fake client.
|
||||||
|
ClearActions()
|
||||||
|
|
||||||
|
// Actions returns a chronologically ordered slice fake actions called on the
|
||||||
|
// fake client.
|
||||||
|
Actions() []Action
|
||||||
|
}
|
@ -156,7 +156,10 @@ func (c *Clientset) Tracker() testing.ObjectTracker {
|
|||||||
`
|
`
|
||||||
|
|
||||||
var checkImpl = `
|
var checkImpl = `
|
||||||
var _ clientset.Interface = &Clientset{}
|
var (
|
||||||
|
_ clientset.Interface = &Clientset{}
|
||||||
|
_ testing.FakeClient = &Clientset{}
|
||||||
|
)
|
||||||
`
|
`
|
||||||
|
|
||||||
var clientsetInterfaceImplTemplate = `
|
var clientsetInterfaceImplTemplate = `
|
||||||
|
@ -74,7 +74,10 @@ func (c *Clientset) Tracker() testing.ObjectTracker {
|
|||||||
return c.tracker
|
return c.tracker
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ clientset.Interface = &Clientset{}
|
var (
|
||||||
|
_ clientset.Interface = &Clientset{}
|
||||||
|
_ testing.FakeClient = &Clientset{}
|
||||||
|
)
|
||||||
|
|
||||||
// ExampleGroupV1 retrieves the ExampleGroupV1Client
|
// ExampleGroupV1 retrieves the ExampleGroupV1Client
|
||||||
func (c *Clientset) ExampleGroupV1() examplegroupv1.ExampleGroupV1Interface {
|
func (c *Clientset) ExampleGroupV1() examplegroupv1.ExampleGroupV1Interface {
|
||||||
|
@ -74,7 +74,10 @@ func (c *Clientset) Tracker() testing.ObjectTracker {
|
|||||||
return c.tracker
|
return c.tracker
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ clientset.Interface = &Clientset{}
|
var (
|
||||||
|
_ clientset.Interface = &Clientset{}
|
||||||
|
_ testing.FakeClient = &Clientset{}
|
||||||
|
)
|
||||||
|
|
||||||
// ExampleV1 retrieves the ExampleV1Client
|
// ExampleV1 retrieves the ExampleV1Client
|
||||||
func (c *Clientset) ExampleV1() examplev1.ExampleV1Interface {
|
func (c *Clientset) ExampleV1() examplev1.ExampleV1Interface {
|
||||||
|
@ -78,7 +78,10 @@ func (c *Clientset) Tracker() testing.ObjectTracker {
|
|||||||
return c.tracker
|
return c.tracker
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ clientset.Interface = &Clientset{}
|
var (
|
||||||
|
_ clientset.Interface = &Clientset{}
|
||||||
|
_ testing.FakeClient = &Clientset{}
|
||||||
|
)
|
||||||
|
|
||||||
// Example retrieves the ExampleClient
|
// Example retrieves the ExampleClient
|
||||||
func (c *Clientset) Example() exampleinternalversion.ExampleInterface {
|
func (c *Clientset) Example() exampleinternalversion.ExampleInterface {
|
||||||
|
@ -78,7 +78,10 @@ func (c *Clientset) Tracker() testing.ObjectTracker {
|
|||||||
return c.tracker
|
return c.tracker
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ clientset.Interface = &Clientset{}
|
var (
|
||||||
|
_ clientset.Interface = &Clientset{}
|
||||||
|
_ testing.FakeClient = &Clientset{}
|
||||||
|
)
|
||||||
|
|
||||||
// ExampleV1 retrieves the ExampleV1Client
|
// ExampleV1 retrieves the ExampleV1Client
|
||||||
func (c *Clientset) ExampleV1() examplev1.ExampleV1Interface {
|
func (c *Clientset) ExampleV1() examplev1.ExampleV1Interface {
|
||||||
|
@ -76,7 +76,10 @@ func (c *Clientset) Tracker() testing.ObjectTracker {
|
|||||||
return c.tracker
|
return c.tracker
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ clientset.Interface = &Clientset{}
|
var (
|
||||||
|
_ clientset.Interface = &Clientset{}
|
||||||
|
_ testing.FakeClient = &Clientset{}
|
||||||
|
)
|
||||||
|
|
||||||
// ExampleV1 retrieves the ExampleV1Client
|
// ExampleV1 retrieves the ExampleV1Client
|
||||||
func (c *Clientset) ExampleV1() examplev1.ExampleV1Interface {
|
func (c *Clientset) ExampleV1() examplev1.ExampleV1Interface {
|
||||||
|
@ -76,7 +76,10 @@ func (c *Clientset) Tracker() testing.ObjectTracker {
|
|||||||
return c.tracker
|
return c.tracker
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ clientset.Interface = &Clientset{}
|
var (
|
||||||
|
_ clientset.Interface = &Clientset{}
|
||||||
|
_ testing.FakeClient = &Clientset{}
|
||||||
|
)
|
||||||
|
|
||||||
// ApiregistrationV1beta1 retrieves the ApiregistrationV1beta1Client
|
// ApiregistrationV1beta1 retrieves the ApiregistrationV1beta1Client
|
||||||
func (c *Clientset) ApiregistrationV1beta1() apiregistrationv1beta1.ApiregistrationV1beta1Interface {
|
func (c *Clientset) ApiregistrationV1beta1() apiregistrationv1beta1.ApiregistrationV1beta1Interface {
|
||||||
|
@ -76,7 +76,10 @@ func (c *Clientset) Tracker() testing.ObjectTracker {
|
|||||||
return c.tracker
|
return c.tracker
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ clientset.Interface = &Clientset{}
|
var (
|
||||||
|
_ clientset.Interface = &Clientset{}
|
||||||
|
_ testing.FakeClient = &Clientset{}
|
||||||
|
)
|
||||||
|
|
||||||
// MetricsV1alpha1 retrieves the MetricsV1alpha1Client
|
// MetricsV1alpha1 retrieves the MetricsV1alpha1Client
|
||||||
func (c *Clientset) MetricsV1alpha1() metricsv1alpha1.MetricsV1alpha1Interface {
|
func (c *Clientset) MetricsV1alpha1() metricsv1alpha1.MetricsV1alpha1Interface {
|
||||||
|
@ -76,7 +76,10 @@ func (c *Clientset) Tracker() testing.ObjectTracker {
|
|||||||
return c.tracker
|
return c.tracker
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ clientset.Interface = &Clientset{}
|
var (
|
||||||
|
_ clientset.Interface = &Clientset{}
|
||||||
|
_ testing.FakeClient = &Clientset{}
|
||||||
|
)
|
||||||
|
|
||||||
// WardleV1alpha1 retrieves the WardleV1alpha1Client
|
// WardleV1alpha1 retrieves the WardleV1alpha1Client
|
||||||
func (c *Clientset) WardleV1alpha1() wardlev1alpha1.WardleV1alpha1Interface {
|
func (c *Clientset) WardleV1alpha1() wardlev1alpha1.WardleV1alpha1Interface {
|
||||||
|
@ -74,7 +74,10 @@ func (c *Clientset) Tracker() testing.ObjectTracker {
|
|||||||
return c.tracker
|
return c.tracker
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ clientset.Interface = &Clientset{}
|
var (
|
||||||
|
_ clientset.Interface = &Clientset{}
|
||||||
|
_ testing.FakeClient = &Clientset{}
|
||||||
|
)
|
||||||
|
|
||||||
// SamplecontrollerV1alpha1 retrieves the SamplecontrollerV1alpha1Client
|
// SamplecontrollerV1alpha1 retrieves the SamplecontrollerV1alpha1Client
|
||||||
func (c *Clientset) SamplecontrollerV1alpha1() samplecontrollerv1alpha1.SamplecontrollerV1alpha1Interface {
|
func (c *Clientset) SamplecontrollerV1alpha1() samplecontrollerv1alpha1.SamplecontrollerV1alpha1Interface {
|
||||||
|
Loading…
Reference in New Issue
Block a user