From c04e075d66bbf588b935c4c6e0aac1de135e8ccf Mon Sep 17 00:00:00 2001 From: Reed Schalo Date: Wed, 4 Sep 2024 19:09:40 -0700 Subject: [PATCH] fix: handle webhook inability to connect error v33 (#1633) --- pkg/operator/operator.go | 5 +++++ pkg/webhooks/webhooks.go | 21 +++++++++++++++++++++ 2 files changed, 26 insertions(+) diff --git a/pkg/operator/operator.go b/pkg/operator/operator.go index 45a316bc3e..9ac1d1509e 100644 --- a/pkg/operator/operator.go +++ b/pkg/operator/operator.go @@ -214,6 +214,11 @@ func (o *Operator) Start(ctx context.Context, cp cloudprovider.CloudProvider) { ctx = injection.WithClient(ctx, o.GetClient()) webhooks.Start(ctx, o.GetConfig(), o.webhooks...) }() + wg.Add(1) + go func() { + defer wg.Done() + webhooks.ValidateConversionEnabled(ctx, o.GetClient()) + }() } wg.Wait() } diff --git a/pkg/webhooks/webhooks.go b/pkg/webhooks/webhooks.go index 9c5b571ca1..e5f766a0f4 100644 --- a/pkg/webhooks/webhooks.go +++ b/pkg/webhooks/webhooks.go @@ -21,6 +21,7 @@ import ( "io" "net/http" "strings" + "time" "github.com/samber/lo" "go.uber.org/zap" @@ -39,6 +40,7 @@ import ( "knative.dev/pkg/webhook/resourcesemantics" "knative.dev/pkg/webhook/resourcesemantics/conversion" "knative.dev/pkg/webhook/resourcesemantics/validation" + "sigs.k8s.io/controller-runtime/pkg/client" "sigs.k8s.io/controller-runtime/pkg/healthz" v1 "sigs.k8s.io/karpenter/pkg/apis/v1" @@ -204,3 +206,22 @@ func HealthProbe(ctx context.Context) healthz.Checker { return nil } } + +func ValidateConversionEnabled(ctx context.Context, kubeclient client.Client) { + // allow context to exist longer than cache sync timeout which has a default of 120 seconds + listCtx, cancel := context.WithTimeout(ctx, 130*time.Second) + defer cancel() + var err error + v1np := &v1.NodePoolList{} + for { + err = kubeclient.List(listCtx, v1np, &client.ListOptions{Limit: 1}) + if err == nil { + return + } + select { + case <-listCtx.Done(): + panic("Conversion webhook enabled but unable to complete call: " + err.Error()) + case <-time.After(10 * time.Second): + } + } +}