From 68544d1a12ff6fa59ef80d0b0176efb3951d6026 Mon Sep 17 00:00:00 2001 From: Sangeetha Madamanchi Date: Fri, 2 Feb 2024 11:49:52 -0600 Subject: [PATCH] fix: adapt to the major helm controller upgrade 0.37.2 --- .github/workflows/publish-latest.yaml | 2 +- controllers/application_controller.go | 9 +++++++-- controllers/application_controller_test.go | 8 ++++---- 3 files changed, 12 insertions(+), 7 deletions(-) diff --git a/.github/workflows/publish-latest.yaml b/.github/workflows/publish-latest.yaml index 8555979..61bbe8c 100644 --- a/.github/workflows/publish-latest.yaml +++ b/.github/workflows/publish-latest.yaml @@ -5,7 +5,7 @@ on: branches: [master] types: [completed] env: - VERSION: v0.0.10 + VERSION: v0.0.11 jobs: deploy: runs-on: ubuntu-latest diff --git a/controllers/application_controller.go b/controllers/application_controller.go index 07db964..2e3af42 100644 --- a/controllers/application_controller.go +++ b/controllers/application_controller.go @@ -255,8 +255,13 @@ func (r *ApplicationReconciler) reconcileHelmReleaseStatus(ctx context.Context, } helmReadyStatusNotReconciled := true for _, condition := range hr.GetConditions() { - apimeta.SetStatusCondition(&application.Status.Conditions, condition) - if condition.Type == meta.ReadyCondition && condition.Reason == v2beta2.ReconciliationSucceededReason { + if condition.Reason == meta.ProgressingReason || condition.Status == metav1.ConditionUnknown { + v1.AppInProgressStatus(application) + break + } else { + apimeta.SetStatusCondition(&application.Status.Conditions, condition) + } + if condition.Type == meta.ReadyCondition && condition.Status == metav1.ConditionTrue { apimeta.RemoveStatusCondition(&application.Status.Conditions, v1.PodReady) helmReadyStatusNotReconciled = false } diff --git a/controllers/application_controller_test.go b/controllers/application_controller_test.go index 488f630..bea20ab 100644 --- a/controllers/application_controller_test.go +++ b/controllers/application_controller_test.go @@ -277,15 +277,15 @@ var _ = Describe("Application controller", func() { return k8sClient.Get(ctx, client.ObjectKey{Name: a.Name, Namespace: a.Namespace}, hr) } }(ctx, hr), 5*time.Second, 300*time.Millisecond).Should(BeNil()) - hr.Status.ObservedGeneration = 1 - hr.Generation = hr.Status.ObservedGeneration + hr.Status.LastAttemptedGeneration = 1 + hr.Generation = hr.Status.LastAttemptedGeneration conditions := []metav1.Condition{{ Type: meta.ReadyCondition, Status: metav1.ConditionStatus(v1.ConditionTrue), ObservedGeneration: 1, LastTransitionTime: metav1.NewTime(time.Now()), - Message: "Helm Release Reconciled", - Reason: meta.SucceededReason, + Message: "Helm Release Reconciliation in Progress", + Reason: meta.ProgressingReason, }} hr.SetConditions(conditions) Expect(k8sClient.Status().Update(ctx, hr)).Should(BeNil())