From e65552549db322376e6081aa45597f7c8bc6df9a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Elvira=20Garc=C3=ADa?= Date: Wed, 20 Dec 2023 15:41:58 +0100 Subject: [PATCH] Add Neutron's default route annotations MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit When the webhook calls for Neutron defaults, it should also write the route override annotation on Neutron's CR section. Signed-off-by: Elvira GarcĂ­a --- apis/core/v1beta1/openstackcontrolplane_webhook.go | 10 ++++++++++ tests/functional/openstackoperator_controller_test.go | 5 +++++ 2 files changed, 15 insertions(+) diff --git a/apis/core/v1beta1/openstackcontrolplane_webhook.go b/apis/core/v1beta1/openstackcontrolplane_webhook.go index 0c07a6163..7985e6874 100644 --- a/apis/core/v1beta1/openstackcontrolplane_webhook.go +++ b/apis/core/v1beta1/openstackcontrolplane_webhook.go @@ -19,6 +19,7 @@ package v1beta1 import ( "fmt" + "github.com/openstack-k8s-operators/lib-common/modules/common/route" apierrors "k8s.io/apimachinery/pkg/api/errors" "k8s.io/apimachinery/pkg/runtime" "k8s.io/apimachinery/pkg/runtime/schema" @@ -318,6 +319,14 @@ func (r *OpenStackControlPlane) Default() { r.DefaultServices() } +// Helper function to initialize overrideSpec object. Could be moved to lib-common. +func initializeOverrideSpec(override **route.OverrideSpec, anno map[string]string) { + if *override == nil { + *override = &route.OverrideSpec{} + } + (*override).AddAnnotation(anno) +} + // DefaultServices - common function for calling individual services' defaulting functions func (r *OpenStackControlPlane) DefaultServices() { // RabbitMQ @@ -381,6 +390,7 @@ func (r *OpenStackControlPlane) DefaultServices() { // Neutron r.Spec.Neutron.Template.Default() + initializeOverrideSpec(&r.Spec.Neutron.APIOverride.Route, r.Spec.Neutron.Template.GetDefaultRouteAnnotations()) // Nova r.Spec.Nova.Template.Default() diff --git a/tests/functional/openstackoperator_controller_test.go b/tests/functional/openstackoperator_controller_test.go index ad5d78cf8..c9e8ff934 100644 --- a/tests/functional/openstackoperator_controller_test.go +++ b/tests/functional/openstackoperator_controller_test.go @@ -96,6 +96,11 @@ var _ = Describe("OpenStackOperator controller", func() { g.Expect(keystoneAPI).Should(Not(BeNil())) }, timeout, interval).Should(Succeed()) }) + // Default route timeouts are set + It("should have default timeout for the routes set", func() { + OSCtlplane := GetOpenStackControlPlane(names.OpenStackControlplaneName) + Expect(OSCtlplane.Spec.Neutron.APIOverride.Route.Annotations).Should(HaveKeyWithValue("haproxy.router.openshift.io/timeout", "120s")) + }) It("should create selfsigned issuer and public+internal CA and issuer", func() { OSCtlplane := GetOpenStackControlPlane(names.OpenStackControlplaneName)