Documentation ¶
Index ¶
- Constants
- Variables
- func Delete(to Setter, t kmapi.ConditionType)
- func FalseCondition(t kmapi.ConditionType, reason string, severity kmapi.ConditionSeverity, ...) *kmapi.Condition
- func Get(from Getter, t kmapi.ConditionType) *kmapi.Condition
- func GetCondition(conditions []kmapi.Condition, condType string) (int, *kmapi.Condition)
- func GetLastTransitionTime(from Getter, t kmapi.ConditionType) *metav1.Time
- func GetMessage(from Getter, t kmapi.ConditionType) string
- func GetReason(from Getter, t kmapi.ConditionType) string
- func GetSeverity(from Getter, t kmapi.ConditionType) *kmapi.ConditionSeverity
- func Has(from Getter, t kmapi.ConditionType) bool
- func HasCondition(conditions []kmapi.Condition, condType string) bool
- func HaveSameStateOf(expected *kmapi.Condition) types.GomegaMatcher
- func IsConditionFalse(conditions []kmapi.Condition, condType string) bool
- func IsConditionTrue(conditions []kmapi.Condition, condType string) bool
- func IsConditionUnknown(conditions []kmapi.Condition, condType string) bool
- func IsFalse(from Getter, t kmapi.ConditionType) bool
- func IsTrue(from Getter, t kmapi.ConditionType) bool
- func IsUnknown(from Getter, t kmapi.ConditionType) bool
- func MarkFalse(to Setter, t kmapi.ConditionType, reason string, ...)
- func MarkTrue(to Setter, t kmapi.ConditionType)
- func MarkUnknown(to Setter, t kmapi.ConditionType, reason, messageFormat string, ...)
- func MatchCondition(expected kmapi.Condition) types.GomegaMatcher
- func MatchConditions(expected kmapi.Conditions) types.GomegaMatcher
- func NewCondition(reason string, message string, generation int64, conditionStatus ...bool) kmapi.Condition
- func RemoveCondition(conditions []kmapi.Condition, condType string) []kmapi.Condition
- func Set(to Setter, condition *kmapi.Condition)
- func SetAggregate(to Setter, targetCondition kmapi.ConditionType, from []Getter, ...)
- func SetCondition(conditions []kmapi.Condition, newCondition kmapi.Condition) []kmapi.Condition
- func SetMirror(to Setter, targetCondition kmapi.ConditionType, from Getter, ...)
- func SetSummary(to Setter, options ...MergeOption)
- func TrueCondition(t kmapi.ConditionType) *kmapi.Condition
- func UnknownCondition(t kmapi.ConditionType, reason string, messageFormat string, ...) *kmapi.Condition
- type ApplyOption
- type Getter
- type MergeOption
- type MirrorOptions
- type Patch
- type PatchOperation
- type PatchOperationType
- type Setter
- type Status
Constants ¶
const ( ConditionProgressing = "Progressing" ConditionInitialized = "Initialized" ConditionReady = "Ready" ConditionAvailable = "Available" ConditionFailed = "Failed" ConditionRequestApproved = "Approved" ConditionRequestDenied = "Denied" )
List of common condition types
Variables ¶
var Statuses = []Status{InProgressStatus, FailedStatus, CurrentStatus, TerminatingStatus, UnknownStatus}
Functions ¶
func Delete ¶
func Delete(to Setter, t kmapi.ConditionType)
Delete deletes the condition with the given type.
func FalseCondition ¶
func FalseCondition(t kmapi.ConditionType, reason string, severity kmapi.ConditionSeverity, messageFormat string, messageArgs ...interface{}) *kmapi.Condition
FalseCondition returns a condition with Status=False and the given type.
func Get ¶
func Get(from Getter, t kmapi.ConditionType) *kmapi.Condition
Get returns the condition with the given type, if the condition does not exist, it returns nil.
func GetCondition ¶
GetCondition returns a pointer to the desired condition referred by "condType". Otherwise, it returns nil.
func GetLastTransitionTime ¶
func GetLastTransitionTime(from Getter, t kmapi.ConditionType) *metav1.Time
GetLastTransitionTime returns the condition Severity or nil if the condition does not exist (is nil).
func GetMessage ¶
func GetMessage(from Getter, t kmapi.ConditionType) string
GetMessage returns a nil safe string of Message.
func GetReason ¶
func GetReason(from Getter, t kmapi.ConditionType) string
GetReason returns a nil safe string of Reason for the condition with the given type.
func GetSeverity ¶
func GetSeverity(from Getter, t kmapi.ConditionType) *kmapi.ConditionSeverity
GetSeverity returns the condition Severity or nil if the condition does not exist (is nil).
func Has ¶
func Has(from Getter, t kmapi.ConditionType) bool
Has returns true if a condition with the given type exists.
func HasCondition ¶
HasCondition returns "true" if the desired condition provided in "condType" is present in the condition list. Otherwise, it returns "false".
func HaveSameStateOf ¶
func HaveSameStateOf(expected *kmapi.Condition) types.GomegaMatcher
HaveSameStateOf matches a condition to have the same state of another.
func IsConditionFalse ¶
IsConditionFalse returns "true" if the desired condition is in false state. It returns "false" if the desired condition is not in "false" state or is not in the condition list.
func IsConditionTrue ¶
IsConditionTrue returns "true" if the desired condition is in true state. It returns "false" if the desired condition is not in "true" state or is not in the condition list.
func IsConditionUnknown ¶
IsConditionUnknown returns "true" if the desired condition is in unknown state. It returns "false" if the desired condition is not in "unknown" state or is not in the condition list.
func IsFalse ¶
func IsFalse(from Getter, t kmapi.ConditionType) bool
IsFalse is true if the condition with the given type is False, otherwise it returns false if the condition is not False or if the condition does not exist (is nil).
func IsTrue ¶
func IsTrue(from Getter, t kmapi.ConditionType) bool
IsTrue is true if the condition with the given type is True, otherwise it returns false if the condition is not True or if the condition does not exist (is nil).
func IsUnknown ¶
func IsUnknown(from Getter, t kmapi.ConditionType) bool
IsUnknown is true if the condition with the given type is Unknown or if the condition does not exist (is nil).
func MarkFalse ¶
func MarkFalse(to Setter, t kmapi.ConditionType, reason string, severity kmapi.ConditionSeverity, messageFormat string, messageArgs ...interface{})
MarkFalse sets Status=False for the condition with the given type.
func MarkTrue ¶
func MarkTrue(to Setter, t kmapi.ConditionType)
MarkTrue sets Status=True for the condition with the given type.
func MarkUnknown ¶
func MarkUnknown(to Setter, t kmapi.ConditionType, reason, messageFormat string, messageArgs ...interface{})
MarkUnknown sets Status=Unknown for the condition with the given type.
func MatchCondition ¶
func MatchCondition(expected kmapi.Condition) types.GomegaMatcher
MatchCondition returns a custom matcher to check equality of conditionsapi.Condition.
func MatchConditions ¶
func MatchConditions(expected kmapi.Conditions) types.GomegaMatcher
MatchConditions returns a custom matcher to check equality of conditionsapi.Conditions.
func NewCondition ¶
func RemoveCondition ¶
RemoveCondition remove a condition from the condition list referred by "condType" parameter.
func Set ¶
Set sets the given condition.
NOTE: If a condition already exists, the LastTransitionTime is updated only if a change is detected in any of the following fields: Status, Reason, Severity and Message.
func SetAggregate ¶
func SetAggregate(to Setter, targetCondition kmapi.ConditionType, from []Getter, options ...MergeOption)
SetAggregate creates a new condition with the aggregation of all the Ready condition from a list of dependent objects; if the Ready condition does not exist in one of the source object, the object is excluded from the aggregation; if none of the source object have ready condition, no target conditions is generated.
func SetCondition ¶
SetCondition add/update the desired condition to the condition list. It does nothing if the condition is already in its desired state.
func SetMirror ¶
func SetMirror(to Setter, targetCondition kmapi.ConditionType, from Getter, options ...MirrorOptions)
SetMirror creates a new condition by mirroring the Ready condition from a dependent object; if the Ready condition does not exist in the source object, no target conditions is generated.
func SetSummary ¶
func SetSummary(to Setter, options ...MergeOption)
SetSummary sets a Ready condition with the summary of all the conditions existing on an object. If the object does not have other conditions, no summary condition is generated.
func TrueCondition ¶
func TrueCondition(t kmapi.ConditionType) *kmapi.Condition
TrueCondition returns a condition with Status=True and the given type.
func UnknownCondition ¶
func UnknownCondition(t kmapi.ConditionType, reason string, messageFormat string, messageArgs ...interface{}) *kmapi.Condition
UnknownCondition returns a condition with Status=Unknown and the given type.
Types ¶
type ApplyOption ¶
type ApplyOption func(*applyOptions)
ApplyOption defines an option for applying a condition patch.
func WithForceOverwrite ¶
func WithForceOverwrite(v bool) ApplyOption
WithForceOverwrite In case of conflicts for the owned conditions, the patch helper will always use the value provided by the controller.
func WithOwnedConditions ¶
func WithOwnedConditions(t ...kmapi.ConditionType) ApplyOption
WithOwnedConditions allows to define condition types owned by the controller. In case of conflicts for the owned conditions, the patch helper will always use the value provided by the controller.
type Getter ¶
type Getter interface { metav1.Object runtime.Object // GetConditions returns the list of conditions for an object. GetConditions() kmapi.Conditions }
Getter interface defines methods that an object should implement in order to use the conditions package for getting conditions.
type MergeOption ¶
type MergeOption func(*mergeOptions)
MergeOption defines an option for computing a summary of conditions.
func AddSourceRef ¶
func AddSourceRef() MergeOption
AddSourceRef instructs merge to add info about the originating object to the target Reason.
func WithConditions ¶
func WithConditions(t ...kmapi.ConditionType) MergeOption
WithConditions instructs merge about the condition types to consider when doing a merge operation; if this option is not specified, all the conditions (excepts Ready) will be considered. This is required, so we can provide some guarantees about the semantic of the target condition without worrying about side effects if someone or something adds custom conditions to the objects.
NOTE: The order of conditions types defines the priority for determining the Reason and Message for the target condition. IMPORTANT: This options works only while generating the Summary condition.
func WithStepCounter ¶
func WithStepCounter() MergeOption
WithStepCounter instructs merge to add a "x of y completed" string to the message, where x is the number of conditions with Status=true and y is the number of conditions in scope.
func WithStepCounterIf ¶
func WithStepCounterIf(value bool) MergeOption
WithStepCounterIf adds a step counter if the value is true. This can be used e.g. to add a step counter only if the object is not being deleted.
IMPORTANT: This options works only while generating the Summary condition.
func WithStepCounterIfOnly ¶
func WithStepCounterIfOnly(t ...kmapi.ConditionType) MergeOption
WithStepCounterIfOnly ensure a step counter is show only if a subset of condition exists. This applies for example on Machines, where we want to use the step counter notation while provisioning the machine, but then we want to move away from this notation as soon as the machine is provisioned and e.g. a Machine health check condition is generated
IMPORTANT: This options requires WithStepCounter or WithStepCounterIf to be set. IMPORTANT: This options works only while generating the Summary condition.
type MirrorOptions ¶
type MirrorOptions func(*mirrorOptions)
MirrorOptions defines an option for mirroring conditions.
func WithFallbackValue ¶
func WithFallbackValue(fallbackValue bool, reason string, severity kmapi.ConditionSeverity, message string) MirrorOptions
WithFallbackValue specify a fallback value to use in case the mirrored condition does not exist; in case the fallbackValue is false, given values for reason, severity and message will be used.
type Patch ¶
type Patch []PatchOperation
Patch defines a list of operations to change a list of conditions into another.
func NewPatch ¶
NewPatch returns the list of Patch required to align source conditions to after conditions.
type PatchOperation ¶
type PatchOperation struct { Before *kmapi.Condition After *kmapi.Condition Op PatchOperationType }
PatchOperation define an operation that changes a single condition.
type PatchOperationType ¶
type PatchOperationType string
PatchOperationType defines patch operation types.
const ( // AddConditionPatch defines an add condition patch operation. AddConditionPatch PatchOperationType = "Add" // ChangeConditionPatch defines a change condition patch operation. ChangeConditionPatch PatchOperationType = "Change" // RemoveConditionPatch defines a remove condition patch operation. RemoveConditionPatch PatchOperationType = "Remove" )
type Setter ¶
type Setter interface { Getter SetConditions(kmapi.Conditions) }
Setter interface defines methods that an object should implement in order to use the conditions package for setting conditions.
type Status ¶
type Status string
Status defines the set of statuses a resource can have. Based on kstatus: https://github.com/kubernetes-sigs/cli-utils/tree/master/pkg/kstatus +kubebuilder:validation:Enum=InProgress;Failed;Current;Terminating;NotFound;Unknown
func StatusFromStringOrDie ¶
StatusFromStringOrDie turns a string into a Status. Will panic if the provided string is not a valid status.