Documentation ¶
Overview ¶
Package test contains testing utilities used for constructing fake Contexts which can be used during tests.
It should be used for all unit tests that require a set of fake clientsets etc in order to provide test consistency.
Index ¶
- type Action
- type ActionMatchFn
- type Builder
- func (b *Builder) AllActionsExecuted() error
- func (b *Builder) AllEventsCalled() error
- func (b *Builder) CheckAndFinish(args ...interface{})
- func (b *Builder) Events() []string
- func (b *Builder) FakeCMClient() *cmfake.Clientset
- func (b *Builder) FakeCMInformerFactory() informers.SharedInformerFactory
- func (b *Builder) FakeDiscoveryClient() *discoveryfake.Discovery
- func (b *Builder) FakeGWClient() *gwfake.Clientset
- func (b *Builder) FakeKubeClient() *kubefake.Clientset
- func (b *Builder) FakeKubeInformerFactory() internalinformers.KubeInformerFactory
- func (b *Builder) FakeMetadataClient() *metadatafake.FakeMetadataClient
- func (b *Builder) Init()
- func (b *Builder) InitWithRESTConfig()
- func (b *Builder) Start()
- func (b *Builder) Stop()
- func (b *Builder) Sync()
- type FakeRecorder
- func (f *FakeRecorder) AnnotatedEventf(object runtime.Object, annotations map[string]string, ...)
- func (f *FakeRecorder) Event(object runtime.Object, eventtype, reason, message string)
- func (f *FakeRecorder) Eventf(object runtime.Object, eventtype, reason, messageFmt string, ...)
- func (f *FakeRecorder) PastEventf(object runtime.Object, timestamp metav1.Time, ...)
- type StringGenerator
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Action ¶
type Action interface { Action() coretesting.Action Matches(coretesting.Action) error }
Action implements a getter and a matcher for coretesting.Action type.
func NewAction ¶
func NewAction(a coretesting.Action) Action
NewAction takes coretesting.Action and wraps it with action.
func NewCustomMatch ¶
func NewCustomMatch(a coretesting.Action, matchFn ActionMatchFn) Action
NewCustomMatch takes an Action and a matcher function and returns a wrapper that can be used to compare this Action with another one.
type ActionMatchFn ¶
type ActionMatchFn func(coretesting.Action, coretesting.Action) error
ActionMatchFn is a type of custom matcher for two Actions.
type Builder ¶
type Builder struct { T *testing.T KubeObjects []runtime.Object CertManagerObjects []runtime.Object GWObjects []runtime.Object PartialMetadataObjects []runtime.Object ExpectedActions []Action ExpectedEvents []string StringGenerator StringGenerator // Clock will be the Clock set on the controller context. // If not specified, the RealClock will be used. Clock *fakeclock.FakeClock // CheckFn is a custom check function that will be executed when the // CheckAndFinish method is called on the builder, after all other checks. // It will be passed a reference to the Builder in order to access state, // as well as a list of all the arguments passed to the CheckAndFinish // function (typically the list of return arguments from the function under // test). CheckFn func(*Builder, ...interface{}) *controller.Context // contains filtered or unexported fields }
Builder is a structure used to construct new Contexts for use during tests. Currently, only KubeObjects, CertManagerObjects and GWObjects can be specified. These will be auto loaded into the constructed fake Clientsets. Call ToContext() to construct a new context using the given values.
func (*Builder) AllActionsExecuted ¶
AllActionsExecuted skips the "list" and "watch" action verbs.
func (*Builder) AllEventsCalled ¶
func (*Builder) CheckAndFinish ¶
func (b *Builder) CheckAndFinish(args ...interface{})
CheckAndFinish will run ensure: all reactors are called, all actions are expected, and all events are as expected. It will then call the Builder's CheckFn, if defined.
func (*Builder) FakeCMClient ¶
func (*Builder) FakeCMInformerFactory ¶
func (b *Builder) FakeCMInformerFactory() informers.SharedInformerFactory
func (*Builder) FakeDiscoveryClient ¶
func (b *Builder) FakeDiscoveryClient() *discoveryfake.Discovery
func (*Builder) FakeGWClient ¶
func (*Builder) FakeKubeClient ¶
func (*Builder) FakeKubeInformerFactory ¶
func (b *Builder) FakeKubeInformerFactory() internalinformers.KubeInformerFactory
func (*Builder) FakeMetadataClient ¶
func (b *Builder) FakeMetadataClient() *metadatafake.FakeMetadataClient
func (*Builder) Init ¶
func (b *Builder) Init()
Init will construct a new context for this builder and set default values for any unset fields.
func (*Builder) InitWithRESTConfig ¶
func (b *Builder) InitWithRESTConfig()
InitWithRESTConfig() will call builder.Init(), then assign an initialised RESTConfig with a `cert-manager/unit-test` User Agent.
func (*Builder) Stop ¶
func (b *Builder) Stop()
Stop will signal the informers to stop watching changes This method is *not* safe to be called concurrently
func (*Builder) Sync ¶
func (b *Builder) Sync()
Sync is a function used by tests to wait for all informers to be synced. This function is called initially by the Start method, to wait for the caches to be populated. It is also called directly by tests to wait for any updates made by the fake clients to be reflected in the informer caches. Sync calls the WaitForCacheSync method on all informers to make sure they have populated their caches. The WaitForCacheSync method is only useful at startup. In order to wait for updates made by the fake clients to be reflected in the informer caches, we need to sleep for the informerResyncPeriod.
type FakeRecorder ¶
type FakeRecorder struct {
Events []string
}
FakeRecorder is used as a fake during tests. It is thread safe. It is usable when created manually and not by NewFakeRecorder, however all events may be thrown away in this case.
func (*FakeRecorder) AnnotatedEventf ¶
func (*FakeRecorder) Event ¶
func (f *FakeRecorder) Event(object runtime.Object, eventtype, reason, message string)
func (*FakeRecorder) Eventf ¶
func (f *FakeRecorder) Eventf(object runtime.Object, eventtype, reason, messageFmt string, args ...interface{})