From bc82a62663432c9cffc7dedc7717fd87e8a0cf6f Mon Sep 17 00:00:00 2001 From: Rafael Raposo Date: Mon, 30 Sep 2024 21:09:50 +0200 Subject: [PATCH] Avoid premature CRD Deletion Signed-off-by: Rafael Raposo --- flyteadmin/pkg/workflowengine/impl/k8s_executor.go | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/flyteadmin/pkg/workflowengine/impl/k8s_executor.go b/flyteadmin/pkg/workflowengine/impl/k8s_executor.go index d941cc8309..62430a3734 100644 --- a/flyteadmin/pkg/workflowengine/impl/k8s_executor.go +++ b/flyteadmin/pkg/workflowengine/impl/k8s_executor.go @@ -94,6 +94,17 @@ func (e K8sWorkflowExecutor) Abort(ctx context.Context, data interfaces.AbortDat if err != nil { return errors.NewFlyteAdminErrorf(codes.Internal, err.Error()) } + // Check if the execution has been handled by FlytePropeller + crd, err := target.FlyteClient.FlyteworkflowV1alpha1().FlyteWorkflows(data.Namespace).Get(ctx, data.ExecutionID.GetName(), v1.GetOptions{}) + if err != nil { + return errors.NewFlyteAdminErrorf(codes.Internal, err.Error()) + } + + if crd.Generation < 2 { + logger.Infof(ctx, "Execution [%v] hasn't been handled by FlytePropeller", data.ExecutionID) + return nil + } + err = target.FlyteClient.FlyteworkflowV1alpha1().FlyteWorkflows(data.Namespace).Delete(ctx, data.ExecutionID.GetName(), v1.DeleteOptions{ PropagationPolicy: &deletePropagationBackground, })