From 8b7639171b5ae5007c8a7abd1796f02a053313cf Mon Sep 17 00:00:00 2001 From: Daneyon Hansen Date: Wed, 18 Oct 2023 14:41:24 -0700 Subject: [PATCH] Conformance: Adds Test to Exercise Gateway AttachedRoutes Signed-off-by: Daneyon Hansen --- .../tests/gateway-with-attached-routes.go | 48 +++++++++++++++++++ .../tests/gateway-with-attached-routes.yaml | 44 +++++++++++++++++ 2 files changed, 92 insertions(+) diff --git a/conformance/tests/gateway-with-attached-routes.go b/conformance/tests/gateway-with-attached-routes.go index b49fcd2f66..feb8c404e8 100644 --- a/conformance/tests/gateway-with-attached-routes.go +++ b/conformance/tests/gateway-with-attached-routes.go @@ -36,6 +36,7 @@ var GatewayWithAttachedRoutes = suite.ConformanceTest{ Description: "A Gateway in the gateway-conformance-infra namespace should be attached to routes.", Features: []suite.SupportedFeature{ suite.SupportGateway, + suite.SupportHTTPRoute, }, Manifests: []string{"tests/gateway-with-attached-routes.yaml"}, Test: func(t *testing.T, s *suite.ConformanceTestSuite) { @@ -90,6 +91,52 @@ var GatewayWithAttachedRoutes = suite.ConformanceTest{ kubernetes.GatewayStatusMustHaveListeners(t, s.Client, s.TimeoutConfig, gwNN, listeners) }) + + t.Run("Gateway listener should have AttachedRoutes set even when Gateway has unresolved refs", func(t *testing.T) { + gwNN := types.NamespacedName{Name: "unresolved-gateway-with-one-attached-unresolved-route", Namespace: "gateway-conformance-infra"} + listeners := []v1.ListenerStatus{{ + Name: v1.SectionName("tls"), + SupportedKinds: []v1.RouteGroupKind{{ + Group: (*v1.Group)(&v1.GroupVersion.Group), + Kind: v1.Kind("HTTPRoute"), + }}, + Conditions: []metav1.Condition{ + { + Type: string(v1.ListenerConditionAccepted), + Status: metav1.ConditionTrue, + Reason: "", // any reason + }, + { + Type: string(v1.ListenerConditionProgrammed), + Status: metav1.ConditionFalse, + Reason: "", // any reason + }, + { + Type: string(v1.ListenerConditionResolvedRefs), + Status: metav1.ConditionFalse, + Reason: "", // any reason + }, + }, + AttachedRoutes: 1, + }} + + kubernetes.GatewayStatusMustHaveListeners(t, s.Client, s.TimeoutConfig, gwNN, listeners) + + hrouteNN := types.NamespacedName{Name: "http-route-4", Namespace: "gateway-conformance-infra"} + notAccepted := metav1.Condition{ + Type: string(v1.RouteConditionAccepted), + Status: metav1.ConditionTrue, + Reason: "", // any reason + } + unresolved := metav1.Condition{ + Type: string(v1.RouteConditionResolvedRefs), + Status: metav1.ConditionFalse, + Reason: "", // any reason + } + + kubernetes.HTTPRouteMustHaveCondition(t, s.Client, s.TimeoutConfig, hrouteNN, gwNN, notAccepted) + kubernetes.HTTPRouteMustHaveCondition(t, s.Client, s.TimeoutConfig, hrouteNN, gwNN, unresolved) + }) }, } @@ -99,6 +146,7 @@ var GatewayWithAttachedRoutesWithPort8080 = suite.ConformanceTest{ Features: []suite.SupportedFeature{ suite.SupportGateway, suite.SupportGatewayPort8080, + suite.SupportHTTPRoute, }, Manifests: []string{"tests/gateway-with-attached-routes-with-port-8080.yaml"}, Test: func(t *testing.T, s *suite.ConformanceTestSuite) { diff --git a/conformance/tests/gateway-with-attached-routes.yaml b/conformance/tests/gateway-with-attached-routes.yaml index d4f051699b..04f4b9ee43 100644 --- a/conformance/tests/gateway-with-attached-routes.yaml +++ b/conformance/tests/gateway-with-attached-routes.yaml @@ -86,3 +86,47 @@ spec: - backendRefs: - name: infra-backend-v1 port: 8080 +--- +apiVersion: gateway.networking.k8s.io/v1beta1 +kind: Gateway +metadata: + name: unresolved-gateway-with-one-attached-unresolved-route + namespace: gateway-conformance-infra +spec: + gatewayClassName: "{GATEWAY_CLASS_NAME}" + listeners: + - name: tls + port: 443 + protocol: HTTPS + allowedRoutes: + kinds: + - kind: HTTPRoute + namespaces: + from: Selector + selector: + matchLabels: + # This label is added automatically as of K8s 1.22 + # to all namespaces + kubernetes.io/metadata.name: gateway-conformance-infra + tls: + certificateRefs: + - group: "" + kind: Secret + name: does-not-exist + mode: Terminate +--- +apiVersion: gateway.networking.k8s.io/v1beta1 +kind: HTTPRoute +metadata: + name: http-route-4 + namespace: gateway-conformance-infra +spec: + parentRefs: + - kind: Gateway + name: unresolved-gateway-with-one-attached-unresolved-route + namespace: gateway-conformance-infra + sectionName: tls + rules: + - backendRefs: + - name: does-not-exist + port: 8080