From eb230e8ae286dc8cff293883207ccd96f34c055b Mon Sep 17 00:00:00 2001 From: Eguzki Astiz Lezaun Date: Fri, 24 Nov 2023 16:49:15 +0100 Subject: [PATCH 1/2] rlp integration tests: wait for route to be accepted --- .../ratelimitpolicy_controller_test.go | 29 +++++++++++++++++++ pkg/reconcilers/targetref_reconciler.go | 6 +++- 2 files changed, 34 insertions(+), 1 deletion(-) diff --git a/controllers/ratelimitpolicy_controller_test.go b/controllers/ratelimitpolicy_controller_test.go index c635bef3b..eb6181dce 100644 --- a/controllers/ratelimitpolicy_controller_test.go +++ b/controllers/ratelimitpolicy_controller_test.go @@ -82,6 +82,7 @@ var _ = Describe("RateLimitPolicy controller", func() { httpRoute := testBuildBasicHttpRoute(routeName, gwName, testNamespace, []string{"*.example.com"}) err := k8sClient.Create(context.Background(), httpRoute) Expect(err).ToNot(HaveOccurred()) + Eventually(testRouteIsAcceptedByGateway(client.ObjectKeyFromObject(httpRoute), gateway), time.Minute, 5*time.Second).Should(BeTrue()) // create ratelimitpolicy rlp := &kuadrantv1beta2.RateLimitPolicy{ @@ -238,6 +239,7 @@ var _ = Describe("RateLimitPolicy controller", func() { } err := k8sClient.Create(context.Background(), httpRoute) Expect(err).ToNot(HaveOccurred()) + Eventually(testRouteIsAcceptedByGateway(client.ObjectKeyFromObject(httpRoute), gateway), time.Minute, 5*time.Second).Should(BeTrue()) // create ratelimitpolicy rlp := &kuadrantv1beta2.RateLimitPolicy{ @@ -421,6 +423,7 @@ var _ = Describe("RateLimitPolicy controller", func() { httpRoute := testBuildBasicHttpRoute(routeName, gwName, testNamespace, []string{"*.example.com"}) err := k8sClient.Create(context.Background(), httpRoute) Expect(err).ToNot(HaveOccurred()) + Eventually(testRouteIsAcceptedByGateway(client.ObjectKeyFromObject(httpRoute), gateway), time.Minute, 5*time.Second).Should(BeTrue()) // create ratelimitpolicy rlp := &kuadrantv1beta2.RateLimitPolicy{ @@ -651,3 +654,29 @@ func testWasmPluginIsAvailable(key client.ObjectKey) func() bool { return true } } + +func testRouteIsAcceptedByGateway(key client.ObjectKey, gateway *gatewayapiv1.Gateway) func() bool { + return func() bool { + route := &gatewayapiv1.HTTPRoute{} + err := k8sClient.Get(context.Background(), key, route) + if err != nil { + return false + } + + routeParentStatus, found := common.Find(route.Status.RouteStatus.Parents, func(p gatewayapiv1.RouteParentStatus) bool { + return *p.ParentRef.Kind == ("Gateway") && + ((p.ParentRef.Namespace == nil && route.GetNamespace() == gateway.Namespace) || string(*p.ParentRef.Namespace) == gateway.Namespace) && + string(p.ParentRef.Name) == gateway.Name + }) + + if !found { + return false + } + + if !meta.IsStatusConditionTrue(routeParentStatus.Conditions, "Accepted") { + return false + } + + return true + } +} diff --git a/pkg/reconcilers/targetref_reconciler.go b/pkg/reconcilers/targetref_reconciler.go index fd605c4ab..01040cb57 100644 --- a/pkg/reconcilers/targetref_reconciler.go +++ b/pkg/reconcilers/targetref_reconciler.go @@ -119,7 +119,11 @@ func (r *TargetRefReconciler) FetchAcceptedGatewayHTTPRoutes(ctx context.Context routes = append(routes, route) continue } - logger.V(1).Info("skipping route, not attached to gateway", "httproute", client.ObjectKeyFromObject(&route)) + + logger.V(1).Info("skipping route, not attached to gateway", + "httproute", client.ObjectKeyFromObject(&route), + "isChildRoute", found, + "isAccepted", routeParentStatus != nil && meta.IsStatusConditionTrue(routeParentStatus.Conditions, "Accepted")) } return From eb0403c18114c811f2459dd33bc7310facd56d96 Mon Sep 17 00:00:00 2001 From: Eguzki Astiz Lezaun Date: Sun, 26 Nov 2023 11:37:02 +0100 Subject: [PATCH 2/2] authpolicy integration tests: wait for route to be accepted --- controllers/authpolicy_controller_test.go | 30 +++-------------- controllers/helper_test.go | 16 ++++++++++ .../ratelimitpolicy_controller_test.go | 32 ++----------------- 3 files changed, 23 insertions(+), 55 deletions(-) diff --git a/controllers/authpolicy_controller_test.go b/controllers/authpolicy_controller_test.go index e25d068ed..dba7cd1fd 100644 --- a/controllers/authpolicy_controller_test.go +++ b/controllers/authpolicy_controller_test.go @@ -26,7 +26,6 @@ import ( authorinoapi "github.com/kuadrant/authorino/api/v1beta2" api "github.com/kuadrant/kuadrant-operator/api/v1beta2" - "github.com/kuadrant/kuadrant-operator/pkg/common" ) const ( @@ -59,12 +58,7 @@ var _ = Describe("AuthPolicy controller", func() { route := testBuildBasicHttpRoute(testHTTPRouteName, testGatewayName, testNamespace, []string{"*.toystore.com"}) err = k8sClient.Create(context.Background(), route) Expect(err).ToNot(HaveOccurred()) - - Eventually(func() bool { - existingRoute := &gatewayapiv1.HTTPRoute{} - err := k8sClient.Get(context.Background(), client.ObjectKeyFromObject(route), existingRoute) - return err == nil && common.IsHTTPRouteAccepted(existingRoute) - }, 15*time.Second, 5*time.Second).Should(BeTrue()) + Eventually(testRouteIsAccepted(client.ObjectKeyFromObject(route)), time.Minute, 5*time.Second).Should(BeTrue()) }) It("Attaches policy to the Gateway", func() { @@ -144,11 +138,7 @@ var _ = Describe("AuthPolicy controller", func() { route := testBuildBasicHttpRoute(routeName, gatewayName, testNamespace, []string{"*.api.example.com"}) err = k8sClient.Create(context.Background(), route) Expect(err).ToNot(HaveOccurred()) - Eventually(func() bool { - existingRoute := &gatewayapiv1.HTTPRoute{} - err := k8sClient.Get(context.Background(), client.ObjectKeyFromObject(route), existingRoute) - return err == nil && common.IsHTTPRouteAccepted(existingRoute) - }, 15*time.Second, 5*time.Second).Should(BeTrue()) + Eventually(testRouteIsAccepted(client.ObjectKeyFromObject(route)), time.Minute, 5*time.Second).Should(BeTrue()) policy := &api.AuthPolicy{ ObjectMeta: metav1.ObjectMeta{ @@ -282,6 +272,7 @@ var _ = Describe("AuthPolicy controller", func() { } err = k8sClient.Create(context.Background(), otherRoute) Expect(err).ToNot(HaveOccurred()) + Eventually(testRouteIsAccepted(client.ObjectKeyFromObject(otherRoute)), time.Minute, 5*time.Second).Should(BeTrue()) // attach policy to the gatewaay gwPolicy := &api.AuthPolicy{ @@ -835,12 +826,7 @@ var _ = Describe("AuthPolicy controller", func() { route := testBuildMultipleRulesHttpRoute(testHTTPRouteName, testGatewayName, testNamespace, []string{"*.toystore.com", "*.admin.toystore.com"}) err = k8sClient.Create(context.Background(), route) Expect(err).ToNot(HaveOccurred()) - - Eventually(func() bool { - existingRoute := &gatewayapiv1.HTTPRoute{} - err := k8sClient.Get(context.Background(), client.ObjectKeyFromObject(route), existingRoute) - return err == nil && common.IsHTTPRouteAccepted(existingRoute) - }, 15*time.Second, 5*time.Second).Should(BeTrue()) + Eventually(testRouteIsAccepted(client.ObjectKeyFromObject(route)), time.Minute, 5*time.Second).Should(BeTrue()) }) It("Attaches simple policy to the HTTPRoute", func() { @@ -1299,14 +1285,6 @@ func testBasicAuthScheme() api.AuthSchemeSpec { } } -func testGatewayIsReady(gateway *gatewayapiv1.Gateway) func() bool { - return func() bool { - existingGateway := &gatewayapiv1.Gateway{} - err := k8sClient.Get(context.Background(), client.ObjectKeyFromObject(gateway), existingGateway) - return err == nil && meta.IsStatusConditionTrue(existingGateway.Status.Conditions, common.GatewayProgrammedConditionType) - } -} - func testPolicyIsReady(policy *api.AuthPolicy) func() bool { return func() bool { existingPolicy := &api.AuthPolicy{} diff --git a/controllers/helper_test.go b/controllers/helper_test.go index 3dcd62805..dd7b8583f 100644 --- a/controllers/helper_test.go +++ b/controllers/helper_test.go @@ -280,3 +280,19 @@ func testBuildMultipleRulesHttpRoute(routeName, gwName, ns string, hostnames []s } return route } + +func testRouteIsAccepted(routeKey client.ObjectKey) func() bool { + return func() bool { + route := &gatewayapiv1.HTTPRoute{} + err := k8sClient.Get(context.Background(), routeKey, route) + return err == nil && common.IsHTTPRouteAccepted(route) + } +} + +func testGatewayIsReady(gateway *gatewayapiv1.Gateway) func() bool { + return func() bool { + existingGateway := &gatewayapiv1.Gateway{} + err := k8sClient.Get(context.Background(), client.ObjectKeyFromObject(gateway), existingGateway) + return err == nil && meta.IsStatusConditionTrue(existingGateway.Status.Conditions, common.GatewayProgrammedConditionType) + } +} diff --git a/controllers/ratelimitpolicy_controller_test.go b/controllers/ratelimitpolicy_controller_test.go index eb6181dce..b59dc0fd3 100644 --- a/controllers/ratelimitpolicy_controller_test.go +++ b/controllers/ratelimitpolicy_controller_test.go @@ -82,7 +82,7 @@ var _ = Describe("RateLimitPolicy controller", func() { httpRoute := testBuildBasicHttpRoute(routeName, gwName, testNamespace, []string{"*.example.com"}) err := k8sClient.Create(context.Background(), httpRoute) Expect(err).ToNot(HaveOccurred()) - Eventually(testRouteIsAcceptedByGateway(client.ObjectKeyFromObject(httpRoute), gateway), time.Minute, 5*time.Second).Should(BeTrue()) + Eventually(testRouteIsAccepted(client.ObjectKeyFromObject(httpRoute)), time.Minute, 5*time.Second).Should(BeTrue()) // create ratelimitpolicy rlp := &kuadrantv1beta2.RateLimitPolicy{ @@ -239,7 +239,7 @@ var _ = Describe("RateLimitPolicy controller", func() { } err := k8sClient.Create(context.Background(), httpRoute) Expect(err).ToNot(HaveOccurred()) - Eventually(testRouteIsAcceptedByGateway(client.ObjectKeyFromObject(httpRoute), gateway), time.Minute, 5*time.Second).Should(BeTrue()) + Eventually(testRouteIsAccepted(client.ObjectKeyFromObject(httpRoute)), time.Minute, 5*time.Second).Should(BeTrue()) // create ratelimitpolicy rlp := &kuadrantv1beta2.RateLimitPolicy{ @@ -423,7 +423,7 @@ var _ = Describe("RateLimitPolicy controller", func() { httpRoute := testBuildBasicHttpRoute(routeName, gwName, testNamespace, []string{"*.example.com"}) err := k8sClient.Create(context.Background(), httpRoute) Expect(err).ToNot(HaveOccurred()) - Eventually(testRouteIsAcceptedByGateway(client.ObjectKeyFromObject(httpRoute), gateway), time.Minute, 5*time.Second).Should(BeTrue()) + Eventually(testRouteIsAccepted(client.ObjectKeyFromObject(httpRoute)), time.Minute, 5*time.Second).Should(BeTrue()) // create ratelimitpolicy rlp := &kuadrantv1beta2.RateLimitPolicy{ @@ -654,29 +654,3 @@ func testWasmPluginIsAvailable(key client.ObjectKey) func() bool { return true } } - -func testRouteIsAcceptedByGateway(key client.ObjectKey, gateway *gatewayapiv1.Gateway) func() bool { - return func() bool { - route := &gatewayapiv1.HTTPRoute{} - err := k8sClient.Get(context.Background(), key, route) - if err != nil { - return false - } - - routeParentStatus, found := common.Find(route.Status.RouteStatus.Parents, func(p gatewayapiv1.RouteParentStatus) bool { - return *p.ParentRef.Kind == ("Gateway") && - ((p.ParentRef.Namespace == nil && route.GetNamespace() == gateway.Namespace) || string(*p.ParentRef.Namespace) == gateway.Namespace) && - string(p.ParentRef.Name) == gateway.Name - }) - - if !found { - return false - } - - if !meta.IsStatusConditionTrue(routeParentStatus.Conditions, "Accepted") { - return false - } - - return true - } -}