Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type TestFieldManager ¶
type TestFieldManager interface { // APIVersion of the object that we're tracking. APIVersion() string // Reset resets the state of the liveObject by resetting it to an empty object. Reset() // Live returns a copy of the current liveObject. Live() runtime.Object // Apply applies the given object on top of the current liveObj, for the // given manager and force flag. Apply(obj runtime.Object, manager string, force bool) error // Update will updates the managed fields in the liveObj based on the // changes performed by the update. Update(obj runtime.Object, manager string) error // ManagedFields returns the list of existing managed fields for the // liveObj. ManagedFields() []metav1.ManagedFieldsEntry }
TestFieldManager is a FieldManager that can be used in test to simulate the behavior of Server-Side Apply and field tracking. This also has a few methods to get a sense of the state of the object.
This TestFieldManager uses a series of "fake" objects to simulate some behavior which come with the limitation that you can only use one version since there is no version conversion logic.
You can use this rather than NewDefaultTestFieldManager if you want to specify either a sub-resource, or a set of modified Manager to test them specifically.
func NewTestFieldManager ¶
func NewTestFieldManager(typeConverter managedfields.TypeConverter, gvk schema.GroupVersionKind) TestFieldManager
NewTestFieldManager returns a new TestFieldManager built for the given gvk, on the main resource.
func NewTestFieldManagerSubresource ¶
func NewTestFieldManagerSubresource(typeConverter managedfields.TypeConverter, gvk schema.GroupVersionKind, subresource string) TestFieldManager
NewTestFieldManagerSubresource returns a new TestFieldManager built for the given gvk, on the given sub-resource.