Documentation ¶
Overview ¶
Package testing includes utilities for testing controllers.
Copyright 2018 The Knative 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 includes utilities for testing controllers.
Index ¶
- func ConfigMapFromTestFile(t *testing.T, name string, allowed ...string) *corev1.ConfigMap
- func ConfigMapsFromTestFile(t *testing.T, name string, allowed ...string) (*corev1.ConfigMap, *corev1.ConfigMap)
- func Eventf(eventType, reason, messageFmt string, args ...interface{}) string
- func InduceFailure(verb, resource string) clientgotesting.ReactionFunc
- func KeyOrDie(obj interface{}) string
- func PrependGenerateNameReactor(f *clientgotesting.Fake)
- func ValidateCreates(action clientgotesting.Action) (handled bool, ret runtime.Object, err error)
- func ValidateUpdates(action clientgotesting.Action) (handled bool, ret runtime.Object, err error)
- type ActionRecorder
- type ActionRecorderList
- type Actions
- type CreateHookFunc
- type DeleteHookFunc
- type EventList
- type Factory
- type GenerateNameReactor
- type HookResult
- type Hooks
- func (h *Hooks) OnCreate(fake *kubetesting.Fake, resource string, rf CreateHookFunc)
- func (h *Hooks) OnDelete(fake *kubetesting.Fake, resource string, rf DeleteHookFunc)
- func (h *Hooks) OnUpdate(fake *kubetesting.Fake, resource string, rf UpdateHookFunc)
- func (h *Hooks) WaitForHooks(timeout time.Duration) error
- type NullTracker
- type ObjectSorter
- func (o *ObjectSorter) AddObjects(objs ...runtime.Object)
- func (o *ObjectSorter) IndexerForObjectType(obj runtime.Object) cache.Indexer
- func (o *ObjectSorter) ObjectsForScheme(scheme *runtime.Scheme) []runtime.Object
- func (o *ObjectSorter) ObjectsForSchemeFunc(funcs ...func(scheme *runtime.Scheme) error) []runtime.Object
- type TableRow
- type TableTest
- type UpdateHookFunc
Examples ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func ConfigMapFromTestFile ¶
ConfigMapFromTestFile creates a v1.ConfigMap from a YAML file It loads the YAML file from the testdata folder.
func ConfigMapsFromTestFile ¶
func ConfigMapsFromTestFile(t *testing.T, name string, allowed ...string) (*corev1.ConfigMap, *corev1.ConfigMap)
configMapsFromTestFile creates two corev1.ConfigMap resources from the config file read from the testdata directory: 1. The raw configmap read in. 2. A second version of the configmap augmenting `data:` with what's parsed from the value of `_example:`
func InduceFailure ¶
func InduceFailure(verb, resource string) clientgotesting.ReactionFunc
InduceFailure is used in conjunction with TableTest's WithReactors field. Tests that want to induce a failure in a row of a TableTest would add:
WithReactors: []clientgotesting.ReactionFunc{ // Makes calls to create revisions return an error. InduceFailure("create", "revisions"), },
func KeyOrDie ¶
func KeyOrDie(obj interface{}) string
KeyOrDie returns the string key of the Kubernetes object or panics if a key cannot be generated.
func PrependGenerateNameReactor ¶
func PrependGenerateNameReactor(f *clientgotesting.Fake)
PrependGenerateNameReactor will instrument a client-go testing Fake with a reactor that simulates 'generateName' functionality
func ValidateCreates ¶
func ValidateUpdates ¶
Types ¶
type ActionRecorder ¶
type ActionRecorder interface {
Actions() []clientgotesting.Action
}
type ActionRecorderList ¶
type ActionRecorderList []ActionRecorder
func (ActionRecorderList) ActionsByVerb ¶
func (l ActionRecorderList) ActionsByVerb() (Actions, error)
type Actions ¶
type Actions struct { Creates []clientgotesting.CreateAction Updates []clientgotesting.UpdateAction Deletes []clientgotesting.DeleteAction DeleteCollections []clientgotesting.DeleteCollectionAction Patches []clientgotesting.PatchAction }
type CreateHookFunc ¶
type CreateHookFunc func(runtime.Object) HookResult
CreateHookFunc is a function for handling a Create hook. Its runtime.Object parameter will be the Kubernetes resource created. The resource can be cast to its actual type like this:
pod := obj.(*v1.Pod)
A return value of true marks the hook as completed. Returning false allows the hook to run again when the next resource of the requested type is created.
func ExpectNormalEventDelivery ¶
func ExpectNormalEventDelivery(t *testing.T, messageRegexp string) CreateHookFunc
ExpectNormalEventDelivery returns a hook function that can be passed to a Hooks.OnCreate() call to verify that an event of type Normal was created matching the given regular expression. For this expectation to be effective the test must also call Hooks.WaitForHooks().
func ExpectWarningEventDelivery ¶
func ExpectWarningEventDelivery(t *testing.T, messageRegexp string) CreateHookFunc
ExpectWarningEventDelivery returns a hook function that can be passed to a Hooks.OnCreate() call to verify that an event of type Warning was created matching the given regular expression. For this expectation to be effective the test must also call Hooks.WaitForHooks().
type DeleteHookFunc ¶
type DeleteHookFunc func(string) HookResult
DeleteHookFunc is a function for handling a delete hook. Its name parameter will be the name of the resource deleted. The resource itself is not available to the reactor.
type EventList ¶
type EventList struct {
Recorder *record.FakeRecorder
}
EventList exports all events during reconciliation through fake event recorder with event channel with buffer of given size.
type Factory ¶
type Factory func(*testing.T, *TableRow) (controller.Reconciler, ActionRecorderList, EventList)
Factory returns a Reconciler.Interface to perform reconciliation in table test, and ActionRecorderList/EventList to capture k8s actions/events produced during reconciliation.
type GenerateNameReactor ¶
type GenerateNameReactor struct {
// contains filtered or unexported fields
}
GenerateNameReactor will simulate the k8s API server and generate a name for resources who's metadata.generateName property is set. This happens only for CreateAction types
This generator is deterministic (unliked k8s) and uses a global counter to help make test names predictable
func (*GenerateNameReactor) Handles ¶
func (r *GenerateNameReactor) Handles(action clientgotesting.Action) bool
Handles contains all the logic to generate the name and mutates the create action object
This is a hack as 'React' is passed a DeepCopy of the action hence this is the only opportunity to 'mutate' the action in the ReactionChain and have to continue executing additional reactors
We should push changes upstream to client-go to help us with mocking
func (*GenerateNameReactor) React ¶
func (r *GenerateNameReactor) React(action clientgotesting.Action) (handled bool, ret runtime.Object, err error)
React is noop-function
type HookResult ¶
type HookResult bool
HookResult is the return value of hook functions.
const ( // HookComplete indicates the hook function completed, and WaitForHooks should // not wait for it. HookComplete HookResult = true // HookIncomplete indicates the hook function is incomplete, and WaitForHooks // should wait for it to complete. HookIncomplete HookResult = false )
type Hooks ¶
type Hooks struct {
// contains filtered or unexported fields
}
Hooks is a utility struct that simplifies controller testing with fake clients. A Hooks struct allows attaching hook functions to actions (create, update, delete) on a specified resource type within a fake client and ensuring that all hooks complete in a timely manner.
Example ¶
h := NewHooks() f := fake.NewSimpleClientset() h.OnCreate(&f.Fake, "pods", func(obj runtime.Object) HookResult { pod := obj.(*v1.Pod) fmt.Printf("Pod %s has restart policy %v\n", pod.Name, pod.Spec.RestartPolicy) return true }) h.OnUpdate(&f.Fake, "pods", func(obj runtime.Object) HookResult { pod := obj.(*v1.Pod) fmt.Printf("Pod %s restart policy was updated to %v\n", pod.Name, pod.Spec.RestartPolicy) return true }) h.OnDelete(&f.Fake, "pods", func(name string) HookResult { fmt.Printf("Pod %s was deleted\n", name) return true }) pod := &v1.Pod{ ObjectMeta: metav1.ObjectMeta{ Name: "test-pod", }, Spec: v1.PodSpec{ RestartPolicy: v1.RestartPolicyAlways, }, } f.CoreV1().Pods("test").Create(pod) updatedPod := pod.DeepCopy() updatedPod.Spec.RestartPolicy = v1.RestartPolicyNever f.CoreV1().Pods("test").Update(updatedPod) f.CoreV1().Pods("test").Delete(pod.Name, &metav1.DeleteOptions{}) if err := h.WaitForHooks(time.Second); err != nil { log.Fatal(err) }
Output: Pod test-pod has restart policy Always Pod test-pod restart policy was updated to Never Pod test-pod was deleted
func NewHooks ¶
func NewHooks() *Hooks
NewHooks returns a Hooks struct that can be used to attach hooks to one or more fake clients and wait for all hooks to complete. TODO(grantr): Allow validating that a hook never fires
func (*Hooks) OnCreate ¶
func (h *Hooks) OnCreate(fake *kubetesting.Fake, resource string, rf CreateHookFunc)
OnCreate attaches a create hook to the given Fake. The hook function is executed every time a resource of the given type is created.
func (*Hooks) OnDelete ¶
func (h *Hooks) OnDelete(fake *kubetesting.Fake, resource string, rf DeleteHookFunc)
OnDelete attaches a delete hook to the given Fake. The hook function is executed every time a resource of the given type is deleted.
func (*Hooks) OnUpdate ¶
func (h *Hooks) OnUpdate(fake *kubetesting.Fake, resource string, rf UpdateHookFunc)
OnUpdate attaches an update hook to the given Fake. The hook function is executed every time a resource of the given type is updated.
func (*Hooks) WaitForHooks ¶
WaitForHooks waits until all attached hooks have returned true at least once. If the given timeout expires before that happens, an error is returned. The registered actions will no longer be executed after WaitForHooks has returned.
type NullTracker ¶
type NullTracker struct{}
NullTracker implements Tracker.
func (*NullTracker) OnChanged ¶
func (*NullTracker) OnChanged(interface{})
OnChanged implements OnChanged.
func (*NullTracker) Track ¶
func (*NullTracker) Track(corev1.ObjectReference, interface{}) error
Track implements Track.
type ObjectSorter ¶
type ObjectSorter struct {
// contains filtered or unexported fields
}
func NewObjectSorter ¶
func NewObjectSorter(scheme *runtime.Scheme) ObjectSorter
func (*ObjectSorter) AddObjects ¶
func (o *ObjectSorter) AddObjects(objs ...runtime.Object)
func (*ObjectSorter) IndexerForObjectType ¶
func (o *ObjectSorter) IndexerForObjectType(obj runtime.Object) cache.Indexer
func (*ObjectSorter) ObjectsForScheme ¶
func (o *ObjectSorter) ObjectsForScheme(scheme *runtime.Scheme) []runtime.Object
func (*ObjectSorter) ObjectsForSchemeFunc ¶
type TableRow ¶
type TableRow struct { // Name is a descriptive name for this test suitable as a first argument to t.Run() Name string // Objects holds the state of the world at the onset of reconciliation. Objects []runtime.Object // Key is the parameter to reconciliation. // This has the form "namespace/name". Key string // WantErr holds whether we should expect the reconciliation to result in an error. WantErr bool // WantCreates holds the set of Create calls we expect during reconciliation. WantCreates []metav1.Object // WantUpdates holds the set of Update calls we expect during reconciliation. WantUpdates []clientgotesting.UpdateActionImpl // WantStatusUpdates holds the set of Update calls, with `status` subresource set, // that we expect during reconciliation. WantStatusUpdates []clientgotesting.UpdateActionImpl // WantDeletes holds the set of Delete calls we expect during reconciliation. WantDeletes []clientgotesting.DeleteActionImpl // WantDeleteCollections holds the set of DeleteCollection calls we expect during reconciliation. WantDeleteCollections []clientgotesting.DeleteCollectionActionImpl // WantPatches holds the set of Patch calls we expect during reconciliation. WantPatches []clientgotesting.PatchActionImpl // WantEvents holds the set of events we expect during reconciliation. WantEvents []string // WithReactors is a set of functions that are installed as Reactors for the execution // of this row of the table-driven-test. WithReactors []clientgotesting.ReactionFunc // For cluster-scoped resources like ClusterIngress, it does not have to be // in the same namespace with its child resources. SkipNamespaceValidation bool }
TableRow holds a single row of our table test.
type UpdateHookFunc ¶
type UpdateHookFunc func(runtime.Object) HookResult
UpdateHookFunc is a function for handling an update hook. its runtime.Object parameter will be the Kubernetes resource updated. The resource can be cast to its actual type like this:
pod := obj.(*v1.Pod)
A return value of true marks the hook as completed. Returning false allows the hook to run again when the next resource of the requested type is updated.