From cb97e6101ca33aa4bd8433c2b72e19ba4ebba08b Mon Sep 17 00:00:00 2001 From: OpenShift Cherrypick Robot Date: Thu, 19 Dec 2024 00:20:58 +0100 Subject: [PATCH] Fix configuration metadata inconsistency (#15601) (#1060) * fix configuration reconcile loop * rename var Co-authored-by: Stavros Kontopoulos --- pkg/reconciler/labeler/accessors.go | 9 +++++++-- pkg/reconciler/service/resources/configuration.go | 5 ++++- 2 files changed, 11 insertions(+), 3 deletions(-) diff --git a/pkg/reconciler/labeler/accessors.go b/pkg/reconciler/labeler/accessors.go index bd30b793e87c..36782ca84711 100644 --- a/pkg/reconciler/labeler/accessors.go +++ b/pkg/reconciler/labeler/accessors.go @@ -18,6 +18,7 @@ package labeler import ( "context" + "sort" "strings" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" @@ -128,7 +129,9 @@ func updateRouteAnnotation(acc kmeta.Accessor, routeName string, diffAnn map[str return } valSet.Delete(routeName) - diffAnn[serving.RoutesAnnotationKey] = strings.Join(valSet.UnsortedList(), ",") + routeNames := valSet.UnsortedList() + sort.Strings(routeNames) + diffAnn[serving.RoutesAnnotationKey] = strings.Join(routeNames, ",") case !has && !remove: if len(valSet) == 0 { @@ -136,7 +139,9 @@ func updateRouteAnnotation(acc kmeta.Accessor, routeName string, diffAnn map[str return } valSet.Insert(routeName) - diffAnn[serving.RoutesAnnotationKey] = strings.Join(valSet.UnsortedList(), ",") + routeNames := valSet.UnsortedList() + sort.Strings(routeNames) + diffAnn[serving.RoutesAnnotationKey] = strings.Join(routeNames, ",") } } diff --git a/pkg/reconciler/service/resources/configuration.go b/pkg/reconciler/service/resources/configuration.go index 241ac7f11d54..6cede2877237 100644 --- a/pkg/reconciler/service/resources/configuration.go +++ b/pkg/reconciler/service/resources/configuration.go @@ -17,6 +17,7 @@ limitations under the License. package resources import ( + "sort" "strings" corev1 "k8s.io/api/core/v1" @@ -48,7 +49,9 @@ func MakeConfigurationFromExisting(service *v1.Service, existing *v1.Configurati routeName := names.Route(service) set := labeler.GetListAnnValue(existing.Annotations, serving.RoutesAnnotationKey) set.Insert(routeName) - anns[serving.RoutesAnnotationKey] = strings.Join(set.UnsortedList(), ",") + routeNames := set.UnsortedList() + sort.Strings(routeNames) + anns[serving.RoutesAnnotationKey] = strings.Join(routeNames, ",") return &v1.Configuration{ ObjectMeta: metav1.ObjectMeta{