From b0b0f5bb6fdeae5813e21d903e1f2edda1749fae Mon Sep 17 00:00:00 2001 From: David Grove Date: Thu, 12 Dec 2024 16:51:25 -0500 Subject: [PATCH] Ensure consistent resource status if create errors (#277) --- .../controller/appwrapper/resource_management.go | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/internal/controller/appwrapper/resource_management.go b/internal/controller/appwrapper/resource_management.go index eff0a7f..afa9b95 100644 --- a/internal/controller/appwrapper/resource_management.go +++ b/internal/controller/appwrapper/resource_management.go @@ -317,6 +317,18 @@ func (r *AppWrapperReconciler) createComponent(ctx context.Context, aw *workload } // fall through. This is not actually an error. The object already exists and the correct appwrapper owns it. } else { + // resource not actually created; patch status to reflect that + orig := copyForStatusPatch(aw) + meta.SetStatusCondition(&aw.Status.ComponentStatus[componentIdx].Conditions, metav1.Condition{ + Type: string(workloadv1beta2.ResourcesDeployed), + Status: metav1.ConditionFalse, + Reason: "ComponentCreationErrored", + }) + if patchErr := r.Status().Patch(ctx, aw, client.MergeFrom(orig)); patchErr != nil { + // ugh. Patch failed, so retry the create so we can get to a consistient state + return patchErr, false + } + // return actual error return err, meta.IsNoMatchError(err) || apierrors.IsInvalid(err) // fatal } }