From 3044e55c1a7748b89973911841db82fbfa3a9429 Mon Sep 17 00:00:00 2001 From: Berk Dehrioglu Date: Tue, 7 Nov 2023 18:21:19 +0300 Subject: [PATCH] fix finalizer removal ordering --- controllers/awsmachinetemplate_controller.go | 55 ++++++++++---------- 1 file changed, 28 insertions(+), 27 deletions(-) diff --git a/controllers/awsmachinetemplate_controller.go b/controllers/awsmachinetemplate_controller.go index 6101c012..2ca72a35 100644 --- a/controllers/awsmachinetemplate_controller.go +++ b/controllers/awsmachinetemplate_controller.go @@ -160,6 +160,34 @@ func (r *AWSMachineTemplateReconciler) reconcileDelete(ctx context.Context, iamS } } } + + cm := &corev1.ConfigMap{} + err = r.Get( + ctx, + types.NamespacedName{ + Namespace: namespace, + Name: fmt.Sprintf("%s-%s", clusterName, "cluster-values"), + }, + cm) + if err != nil { + logger.Error(err, "Failed to get the cluster-values configmap for cluster") + return ctrl.Result{}, errors.WithStack(err) + } + + if controllerutil.ContainsFinalizer(cm, key.FinalizerName(iam.ControlPlaneRole)) { + patchHelper, err := patch.NewHelper(cm, r.Client) + if err != nil { + return ctrl.Result{}, errors.WithStack(err) + } + controllerutil.RemoveFinalizer(cm, key.FinalizerName(iam.ControlPlaneRole)) + err = patchHelper.Patch(ctx, cm) + if err != nil { + logger.Error(err, "failed to remove finalizer from configmap") + return ctrl.Result{}, errors.WithStack(err) + } + logger.Info("successfully removed finalizer from configmap", "finalizer_name", iam.ControlPlaneRole) + } + // remove finalizer from AWSCluster { awsCluster, err := key.GetAWSClusterByName(ctx, r.Client, clusterName, awsMachineTemplate.GetNamespace()) @@ -198,33 +226,6 @@ func (r *AWSMachineTemplateReconciler) reconcileDelete(ctx context.Context, iamS logger.Info("successfully removed finalizer from AWSMachineTemplate", "finalizer_name", iam.ControlPlaneRole) } - cm := &corev1.ConfigMap{} - err = r.Get( - ctx, - types.NamespacedName{ - Namespace: namespace, - Name: fmt.Sprintf("%s-%s", clusterName, "cluster-values"), - }, - cm) - if err != nil { - logger.Error(err, "Failed to get the cluster-values configmap for cluster") - return ctrl.Result{}, errors.WithStack(err) - } - - if controllerutil.ContainsFinalizer(cm, key.FinalizerName(iam.ControlPlaneRole)) { - patchHelper, err := patch.NewHelper(cm, r.Client) - if err != nil { - return ctrl.Result{}, errors.WithStack(err) - } - controllerutil.RemoveFinalizer(cm, key.FinalizerName(iam.ControlPlaneRole)) - err = patchHelper.Patch(ctx, cm) - if err != nil { - logger.Error(err, "failed to remove finalizer from configmap") - return ctrl.Result{}, errors.WithStack(err) - } - logger.Info("successfully removed finalizer from configmap", "finalizer_name", iam.ControlPlaneRole) - } - return ctrl.Result{}, nil }