Skip to content

Commit

Permalink
Get application in retry blocks (#418)
Browse files Browse the repository at this point in the history
* Get application in retry blocks

Signed-off-by: John Collier <jcollier@redhat.com>

* Fix typo

Signed-off-by: John Collier <jcollier@redhat.com>

* Fix typo

Signed-off-by: John Collier <jcollier@redhat.com>

---------

Signed-off-by: John Collier <jcollier@redhat.com>
  • Loading branch information
johnmcollier authored Nov 21, 2023
1 parent 109a862 commit 8941feb
Showing 1 changed file with 18 additions and 5 deletions.
23 changes: 18 additions & 5 deletions controllers/application_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -119,10 +119,16 @@ func (r *ApplicationReconciler) Reconcile(ctx context.Context, req ctrl.Request)
if finalizeErr := r.Finalize(ctx, &application, ghClient); finalizeErr != nil {
finalizeCounter, err := getCounterAnnotation(finalizeCount, &application)
if err == nil && finalizeCounter < 5 {
// The Finalize function failed, so increment the finalize count and return
setCounterAnnotation(finalizeCount, &application, finalizeCounter+1)
err := retry.RetryOnConflict(retry.DefaultRetry, func() error {
err := r.Update(ctx, &application)
var currentApplication appstudiov1alpha1.Application
err := r.Get(ctx, req.NamespacedName, &currentApplication)
if err != nil {
return err
}
// The Finalize function failed, so increment the finalize count and return
setCounterAnnotation(finalizeCount, &currentApplication, finalizeCounter+1)

err = r.Update(ctx, &currentApplication)
return err
})
if err != nil {
Expand All @@ -141,9 +147,16 @@ func (r *ApplicationReconciler) Reconcile(ctx context.Context, req ctrl.Request)
}

// remove the finalizer from the list and update it.
controllerutil.RemoveFinalizer(&application, appFinalizerName)
err := retry.RetryOnConflict(retry.DefaultRetry, func() error {
err := r.Update(ctx, &application)
var currentApplication appstudiov1alpha1.Application
err := r.Get(ctx, req.NamespacedName, &currentApplication)
if err != nil {
return err
}

controllerutil.RemoveFinalizer(&currentApplication, appFinalizerName)

err = r.Update(ctx, &currentApplication)
return err
})
if err != nil {
Expand Down

0 comments on commit 8941feb

Please sign in to comment.