From ad518329bd6025fb56493ff75b39029263de2d02 Mon Sep 17 00:00:00 2001 From: Arko Dasgupta Date: Wed, 6 Nov 2024 17:42:10 -0800 Subject: [PATCH] fix panic in provider when the direct response body is nil (#4647) body is an optional field, it may be nil Signed-off-by: Arko Dasgupta --- internal/provider/kubernetes/filters.go | 1 + test/e2e/testdata/direct-response.yaml | 20 ++++++++++++++++++++ test/e2e/tests/direct-response.go | 5 +++-- test/e2e/tests/response-override.go | 13 ++++++++++--- 4 files changed, 34 insertions(+), 5 deletions(-) diff --git a/internal/provider/kubernetes/filters.go b/internal/provider/kubernetes/filters.go index b322950cced..cffcf214f6b 100644 --- a/internal/provider/kubernetes/filters.go +++ b/internal/provider/kubernetes/filters.go @@ -66,6 +66,7 @@ func (r *gatewayAPIReconciler) processRouteFilterConfigMapRef( resourceMap *resourceMappings, resourceTree *resource.Resources, ) { if filter.Spec.DirectResponse != nil && + filter.Spec.DirectResponse.Body != nil && filter.Spec.DirectResponse.Body.ValueRef != nil && string(filter.Spec.DirectResponse.Body.ValueRef.Kind) == resource.KindConfigMap { configMap := new(corev1.ConfigMap) diff --git a/test/e2e/testdata/direct-response.yaml b/test/e2e/testdata/direct-response.yaml index a1d2d81e8bb..da869f8729a 100644 --- a/test/e2e/testdata/direct-response.yaml +++ b/test/e2e/testdata/direct-response.yaml @@ -27,6 +27,17 @@ spec: group: gateway.envoyproxy.io kind: HTTPRouteFilter name: direct-response-value-ref + - matches: + - path: + type: PathPrefix + value: /401 + filters: + - type: ExtensionRef + extensionRef: + group: gateway.envoyproxy.io + kind: HTTPRouteFilter + name: direct-response-status + --- apiVersion: v1 kind: ConfigMap @@ -62,3 +73,12 @@ spec: group: "" kind: ConfigMap name: value-ref-response +--- +apiVersion: gateway.envoyproxy.io/v1alpha1 +kind: HTTPRouteFilter +metadata: + name: direct-response-status + namespace: gateway-conformance-infra +spec: + directResponse: + statusCode: 401 diff --git a/test/e2e/tests/direct-response.go b/test/e2e/tests/direct-response.go index 12c667fdd30..cc839f39313 100644 --- a/test/e2e/tests/direct-response.go +++ b/test/e2e/tests/direct-response.go @@ -31,8 +31,9 @@ var DirectResponseTest = suite.ConformanceTest{ gwAddr := kubernetes.GatewayAndHTTPRoutesMustBeAccepted(t, suite.Client, suite.TimeoutConfig, suite.ControllerName, kubernetes.NewGatewayRef(gwNN), routeNN) kubernetes.HTTPRouteMustHaveResolvedRefsConditionsTrue(t, suite.Client, suite.TimeoutConfig, routeNN, gwNN) - verifyCustomResponse(t, suite.TimeoutConfig, gwAddr, "/inline", "text/plain", "Oops! Your request is not found.") - verifyCustomResponse(t, suite.TimeoutConfig, gwAddr, "/value-ref", "application/json", `{"error": "Internal Server Error"}`) + verifyCustomResponse(t, suite.TimeoutConfig, gwAddr, "/inline", "text/plain", "Oops! Your request is not found.", 200) + verifyCustomResponse(t, suite.TimeoutConfig, gwAddr, "/value-ref", "application/json", `{"error": "Internal Server Error"}`, 200) + verifyCustomResponse(t, suite.TimeoutConfig, gwAddr, "/401", "", ``, 401) }) }, } diff --git a/test/e2e/tests/response-override.go b/test/e2e/tests/response-override.go index c7c12bd2c10..3f7a553fee6 100644 --- a/test/e2e/tests/response-override.go +++ b/test/e2e/tests/response-override.go @@ -49,13 +49,15 @@ var ResponseOverrideTest = suite.ConformanceTest{ Name: gwapiv1.ObjectName(gwNN.Name), } BackendTrafficPolicyMustBeAccepted(t, suite.Client, types.NamespacedName{Name: "response-override", Namespace: ns}, suite.ControllerName, ancestorRef) - verifyCustomResponse(t, suite.TimeoutConfig, gwAddr, "/status/404", "text/plain", "Oops! Your request is not found.") - verifyCustomResponse(t, suite.TimeoutConfig, gwAddr, "/status/500", "application/json", `{"error": "Internal Server Error"}`) + verifyCustomResponse(t, suite.TimeoutConfig, gwAddr, "/status/404", "text/plain", "Oops! Your request is not found.", 404) + verifyCustomResponse(t, suite.TimeoutConfig, gwAddr, "/status/500", "application/json", `{"error": "Internal Server Error"}`, 500) }) }, } -func verifyCustomResponse(t *testing.T, timeoutConfig config.TimeoutConfig, gwAddr, path, expectedContentType, expectedBody string) { +func verifyCustomResponse(t *testing.T, timeoutConfig config.TimeoutConfig, gwAddr, + path, expectedContentType, expectedBody string, expectedStatusCode int, +) { reqURL := url.URL{ Scheme: "http", Host: httputils.CalculateHost(t, gwAddr, "http"), @@ -88,6 +90,11 @@ func verifyCustomResponse(t *testing.T, timeoutConfig config.TimeoutConfig, gwAd return false } + if expectedStatusCode != rsp.StatusCode { + tlog.Logf(t, "expected status code to be %d but got %d", expectedStatusCode, rsp.StatusCode) + return false + } + return true })