From d527a51ef7ae0a3870ff9540b61984cd64ade22a Mon Sep 17 00:00:00 2001 From: Andre Fredette Date: Sun, 22 Dec 2024 13:10:24 -0500 Subject: [PATCH] Fix intermittent error when deleting programs Fixes: #353 Signed-off-by: Andre Fredette --- controllers/bpfman-agent/common.go | 23 ++++++++++++++++------- 1 file changed, 16 insertions(+), 7 deletions(-) diff --git a/controllers/bpfman-agent/common.go b/controllers/bpfman-agent/common.go index 21ca76d2c..9c93f7392 100644 --- a/controllers/bpfman-agent/common.go +++ b/controllers/bpfman-agent/common.go @@ -653,21 +653,30 @@ func (r *ReconcilerCommon[T, TL]) handleProgDelete( return internal.Requeue, fmt.Errorf("failed to delete program from bpfman: %v", err) } - if r.removeFinalizer(ctx, bpfProgram.GetClientObject(), rec.getFinalizer()) { - return internal.Updated, nil - } - if isBeingDeleted { // We're deleting these programs because the *Program is being - // deleted, so update the status and the program will be deleted - // when the owner is deleted. + // deleted. + + // So update the status. if r.updateStatus(ctx, rec, &bpfProgram, cond) { return internal.Updated, nil } + + // Then remove the finalizer, and the program will be deleted when + // the owner is deleted. + if r.removeFinalizer(ctx, bpfProgram.GetClientObject(), rec.getFinalizer()) { + return internal.Updated, nil + } } else { // We're deleting these programs because they were not expected due // to changes that caused the containers to not be selected anymore. - // So, explicitly delete them. + + // So, remove the finalizer. + if r.removeFinalizer(ctx, bpfProgram.GetClientObject(), rec.getFinalizer()) { + return internal.Updated, nil + } + + // Then explicitly delete them. opts := client.DeleteOptions{} r.Logger.Info("Calling KubeAPI to delete BpfProgram", "Name", bpfProgram.GetName(), "Owner", bpfProgram.GetName()) if err := r.Delete(ctx, bpfProgram.GetClientObject(), &opts); err != nil {