From b4b570f81ef7849f871c7c7d07458c3d8562bdd1 Mon Sep 17 00:00:00 2001 From: Joel Speed Date: Mon, 9 Dec 2024 15:50:19 +0000 Subject: [PATCH] Prevent panic when informer receives cache.DeletedFinalStateUnknown --- pkg/provider/azure_local_services.go | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/pkg/provider/azure_local_services.go b/pkg/provider/azure_local_services.go index 0febc94edb..a3cd884bf5 100644 --- a/pkg/provider/azure_local_services.go +++ b/pkg/provider/azure_local_services.go @@ -356,7 +356,23 @@ func (az *Cloud) setUpEndpointSlicesInformer(informerFactory informers.SharedInf } }, DeleteFunc: func(obj interface{}) { - es := obj.(*discovery_v1.EndpointSlice) + var es *discovery_v1.EndpointSlice + switch v := obj.(type) { + case *discovery_v1.EndpointSlice: + es = v + case cache.DeletedFinalStateUnknown: + // We may miss the deletion event if the watch stream is disconnected and the object is deleted. + var ok bool + es, ok = v.Obj.(*discovery_v1.EndpointSlice) + if !ok { + klog.Errorf("Cannot convert to *discovery_v1.EndpointSlice: %T", v.Obj) + return + } + default: + klog.Errorf("Cannot convert to *discovery_v1.EndpointSlice: %T", v) + return + } + az.endpointSlicesCache.Delete(strings.ToLower(fmt.Sprintf("%s/%s", es.Namespace, es.Name))) }, })