From fa833dfaa3b2e0bb2d53d2dd30b3b4d50680bc1f Mon Sep 17 00:00:00 2001 From: zirain Date: Wed, 3 Jul 2024 09:57:36 +0800 Subject: [PATCH 1/4] e2e: fix accesslog test Signed-off-by: zirain --- test/config/gatewayclass.yaml | 2 + test/e2e/tests/accesslog.go | 131 ++++------------------------------ test/e2e/tests/utils.go | 96 +++++++++++++++++++++++++ 3 files changed, 112 insertions(+), 117 deletions(-) diff --git a/test/config/gatewayclass.yaml b/test/config/gatewayclass.yaml index 01fcfc2c371..8fc6806b0a5 100644 --- a/test/config/gatewayclass.yaml +++ b/test/config/gatewayclass.yaml @@ -46,6 +46,8 @@ spec: type: Text text: | [%START_TIME%] %METADATA(ROUTE:envoy-gateway:resources)% "%REQ(:METHOD)% %REQ(X-ENVOY-ORIGINAL-PATH?:PATH)% %PROTOCOL%" %RESPONSE_CODE% %RESPONSE_FLAGS% %BYTES_RECEIVED% %BYTES_SENT% %DURATION% "%REQ(X-FORWARDED-FOR)%" "%REQ(USER-AGENT)%" "%REQ(X-REQUEST-ID)%" "%REQ(:AUTHORITY)%" "%UPSTREAM_HOST%" + matches: + - "'x-envoy-logged' in request.headers" sinks: - type: File file: diff --git a/test/e2e/tests/accesslog.go b/test/e2e/tests/accesslog.go index d7d79f089c0..fea8c3bb2a0 100644 --- a/test/e2e/tests/accesslog.go +++ b/test/e2e/tests/accesslog.go @@ -10,19 +10,11 @@ package tests import ( "context" - "encoding/json" - "fmt" - "io" - "net/http" - "net/url" - "strings" "testing" "time" - corev1 "k8s.io/api/core/v1" "k8s.io/apimachinery/pkg/types" "k8s.io/apimachinery/pkg/util/wait" - "sigs.k8s.io/controller-runtime/pkg/client" httputils "sigs.k8s.io/gateway-api/conformance/utils/http" "sigs.k8s.io/gateway-api/conformance/utils/kubernetes" "sigs.k8s.io/gateway-api/conformance/utils/suite" @@ -46,6 +38,9 @@ var FileAccessLogTest = suite.ConformanceTest{ expectedResponse := httputils.ExpectedResponse{ Request: httputils.Request{ Path: "/file", + Headers: map[string]string{ + "x-envoy-logged": "1", + }, }, Response: httputils.Response{ StatusCode: 200, @@ -64,9 +59,7 @@ var FileAccessLogTest = suite.ConformanceTest{ if err := wait.PollUntilContextTimeout(context.TODO(), time.Second, time.Minute, true, func(ctx context.Context) (bool, error) { // query log count from loki - count, err := QueryLogCountFromLoki(t, suite.Client, types.NamespacedName{ - Namespace: "envoy-gateway-system", - }, labels, "test-annotation-value") + count, err := QueryLogCountFromLoki(t, suite.Client, labels, "test-annotation-value") if err != nil { t.Logf("failed to get log count from loki: %v", err) return false, nil @@ -83,9 +76,7 @@ var FileAccessLogTest = suite.ConformanceTest{ if err := wait.PollUntilContextTimeout(context.TODO(), time.Second, time.Minute, true, func(ctx context.Context) (bool, error) { // query log count from loki - preCount, err := QueryLogCountFromLoki(t, suite.Client, types.NamespacedName{ - Namespace: "envoy-gateway-system", - }, labels, "test-annotation-value") + preCount, err := QueryLogCountFromLoki(t, suite.Client, labels, "test-annotation-value") if err != nil { t.Logf("failed to get log count from loki: %v", err) return false, nil @@ -96,9 +87,7 @@ var FileAccessLogTest = suite.ConformanceTest{ // it will take some time for fluent-bit to collect the log and send to loki // let's wait for a while if err := wait.PollUntilContextTimeout(ctx, 500*time.Millisecond, 15*time.Second, true, func(_ context.Context) (bool, error) { - count, err := QueryLogCountFromLoki(t, suite.Client, types.NamespacedName{ - Namespace: "envoy-gateway-system", - }, labels, "test-annotation-value") + count, err := QueryLogCountFromLoki(t, suite.Client, labels, "test-annotation-value") if err != nil { t.Logf("failed to get log count from loki: %v", err) return false, nil @@ -137,6 +126,9 @@ var OpenTelemetryTest = suite.ConformanceTest{ expectedResponse := httputils.ExpectedResponse{ Request: httputils.Request{ Path: "/otel", + Headers: map[string]string{ + "x-envoy-logged": "1", + }, }, Response: httputils.Response{ StatusCode: 200, @@ -153,9 +145,7 @@ var OpenTelemetryTest = suite.ConformanceTest{ if err := wait.PollUntilContextTimeout(context.TODO(), time.Second, time.Minute, true, func(ctx context.Context) (bool, error) { // query log count from loki - preCount, err := QueryLogCountFromLoki(t, suite.Client, types.NamespacedName{ - Namespace: "envoy-gateway-system", - }, labels, "") + preCount, err := QueryLogCountFromLoki(t, suite.Client, labels, "") if err != nil { t.Logf("failed to get log count from loki: %v", err) return false, nil @@ -164,9 +154,7 @@ var OpenTelemetryTest = suite.ConformanceTest{ httputils.MakeRequestAndExpectEventuallyConsistentResponse(t, suite.RoundTripper, suite.TimeoutConfig, gwAddr, expectedResponse) if err := wait.PollUntilContextTimeout(ctx, 500*time.Millisecond, 10*time.Second, true, func(_ context.Context) (bool, error) { - count, err := QueryLogCountFromLoki(t, suite.Client, types.NamespacedName{ - Namespace: "envoy-gateway-system", - }, labels, "") + count, err := QueryLogCountFromLoki(t, suite.Client, labels, "") if err != nil { t.Logf("failed to get log count from loki: %v", err) return false, nil @@ -205,6 +193,9 @@ var ALSTest = suite.ConformanceTest{ expectedResponse := httputils.ExpectedResponse{ Request: httputils.Request{ Path: "/als", + Headers: map[string]string{ + "x-envoy-logged": "1", + }, }, Response: httputils.Response{ StatusCode: 200, @@ -224,97 +215,3 @@ var ALSTest = suite.ConformanceTest{ }) }, } - -func ALSLogCount(t *testing.T, suite *suite.ConformanceTestSuite) int { - metricPath, err := RetrieveURL(suite.Client, types.NamespacedName{ - Namespace: "monitoring", - Name: "envoy-als", - }, 19001, "/metrics") - if err != nil { - t.Fatalf("failed to get metric url: %v", err) - } - - countMetric, err := RetrieveMetric(metricPath, "log_count", time.Second) - if err != nil { - t.Fatalf("failed to get metric: %v", err) - } - - total := 0 - for _, m := range countMetric.Metric { - if m.Counter != nil && m.Counter.Value != nil { - total += int(*m.Counter.Value) - } - } - - return total -} - -// QueryLogCountFromLoki queries log count from loki -// TODO: move to utils package if needed -func QueryLogCountFromLoki(t *testing.T, c client.Client, nn types.NamespacedName, keyValues map[string]string, match string) (int, error) { - svc := corev1.Service{} - if err := c.Get(context.Background(), types.NamespacedName{ - Namespace: "monitoring", - Name: "loki", - }, &svc); err != nil { - return -1, err - } - lokiHost := "" - for _, ing := range svc.Status.LoadBalancer.Ingress { - if ing.IP != "" { - lokiHost = ing.IP - break - } - } - - qParams := make([]string, 0, len(keyValues)) - for k, v := range keyValues { - qParams = append(qParams, fmt.Sprintf("%s=\"%s\"", k, v)) - } - - q := "{" + strings.Join(qParams, ",") + "}" - if match != "" { - q = q + "|~\"" + match + "\"" - } - params := url.Values{} - params.Add("query", q) - params.Add("start", fmt.Sprintf("%d", time.Now().Add(-10*time.Minute).Unix())) // query logs from last 10 minutes - lokiQueryURL := fmt.Sprintf("http://%s:3100/loki/api/v1/query_range?%s", lokiHost, params.Encode()) - res, err := http.DefaultClient.Get(lokiQueryURL) - if err != nil { - return -1, err - } - t.Logf("get response from loki, query=%s, status=%s", q, res.Status) - - b, err := io.ReadAll(res.Body) - if err != nil { - return -1, err - } - - lokiResponse := &LokiQueryResponse{} - if err := json.Unmarshal(b, lokiResponse); err != nil { - return -1, err - } - - if len(lokiResponse.Data.Result) == 0 { - return 0, nil - } - - total := 0 - for _, res := range lokiResponse.Data.Result { - total += len(res.Values) - } - t.Logf("get response from loki, query=%s, total=%d", q, total) - return total, nil -} - -type LokiQueryResponse struct { - Status string `json:"status"` - Data struct { - ResultType string `json:"resultType"` - Result []struct { - Metric interface{} - Values []interface{} `json:"values"` - } - } -} diff --git a/test/e2e/tests/utils.go b/test/e2e/tests/utils.go index 5dfc9af494e..b29d2b48d0d 100644 --- a/test/e2e/tests/utils.go +++ b/test/e2e/tests/utils.go @@ -7,10 +7,12 @@ package tests import ( "context" + "encoding/json" "errors" "fmt" "io" "net/http" + "net/url" "strings" "testing" "time" @@ -30,6 +32,7 @@ import ( "sigs.k8s.io/controller-runtime/pkg/client" gwapiv1a2 "sigs.k8s.io/gateway-api/apis/v1alpha2" "sigs.k8s.io/gateway-api/conformance/utils/config" + "sigs.k8s.io/gateway-api/conformance/utils/suite" "sigs.k8s.io/gateway-api/conformance/utils/tlog" egv1a1 "github.com/envoyproxy/gateway/api/v1alpha1" @@ -365,3 +368,96 @@ func WaitForLoadBalancerAddress(t *testing.T, client client.Client, timeout time require.NoErrorf(t, waitErr, "error waiting for Service to have at least one load balancer IP address in status") return ipAddr, nil } + +func ALSLogCount(t *testing.T, suite *suite.ConformanceTestSuite) int { + metricPath, err := RetrieveURL(suite.Client, types.NamespacedName{ + Namespace: "monitoring", + Name: "envoy-als", + }, 19001, "/metrics") + if err != nil { + t.Fatalf("failed to get metric url: %v", err) + } + + countMetric, err := RetrieveMetric(metricPath, "log_count", time.Second) + if err != nil { + t.Fatalf("failed to get metric: %v", err) + } + + total := 0 + for _, m := range countMetric.Metric { + if m.Counter != nil && m.Counter.Value != nil { + total += int(*m.Counter.Value) + } + } + + return total +} + +// QueryLogCountFromLoki queries log count from loki +func QueryLogCountFromLoki(t *testing.T, c client.Client, keyValues map[string]string, match string) (int, error) { + svc := corev1.Service{} + if err := c.Get(context.Background(), types.NamespacedName{ + Namespace: "monitoring", + Name: "loki", + }, &svc); err != nil { + return -1, err + } + lokiHost := "" + for _, ing := range svc.Status.LoadBalancer.Ingress { + if ing.IP != "" { + lokiHost = ing.IP + break + } + } + + qParams := make([]string, 0, len(keyValues)) + for k, v := range keyValues { + qParams = append(qParams, fmt.Sprintf("%s=\"%s\"", k, v)) + } + + q := "{" + strings.Join(qParams, ",") + "}" + if match != "" { + q = q + "|~\"" + match + "\"" + } + params := url.Values{} + params.Add("query", q) + params.Add("start", fmt.Sprintf("%d", time.Now().Add(-10*time.Minute).Unix())) // query logs from last 10 minutes + lokiQueryURL := fmt.Sprintf("http://%s:3100/loki/api/v1/query_range?%s", lokiHost, params.Encode()) + res, err := http.DefaultClient.Get(lokiQueryURL) + if err != nil { + return -1, err + } + t.Logf("get response from loki, query=%s, status=%s", q, res.Status) + + b, err := io.ReadAll(res.Body) + if err != nil { + return -1, err + } + + lokiResponse := &LokiQueryResponse{} + if err := json.Unmarshal(b, lokiResponse); err != nil { + return -1, err + } + + if len(lokiResponse.Data.Result) == 0 { + return 0, nil + } + + total := 0 + for _, res := range lokiResponse.Data.Result { + total += len(res.Values) + } + t.Logf("get response from loki, query=%s, total=%d", q, total) + return total, nil +} + +type LokiQueryResponse struct { + Status string `json:"status"` + Data struct { + ResultType string `json:"resultType"` + Result []struct { + Metric interface{} + Values []interface{} `json:"values"` + } + } +} From e3530e04758cbb091cb7dc2b165ffabc97e4d2bd Mon Sep 17 00:00:00 2001 From: zirain Date: Wed, 3 Jul 2024 11:02:31 +0800 Subject: [PATCH 2/4] refactor test Signed-off-by: zirain --- test/e2e/tests/accesslog.go | 130 ++++++++++++------------------------ 1 file changed, 43 insertions(+), 87 deletions(-) diff --git a/test/e2e/tests/accesslog.go b/test/e2e/tests/accesslog.go index fea8c3bb2a0..24b390d3ae9 100644 --- a/test/e2e/tests/accesslog.go +++ b/test/e2e/tests/accesslog.go @@ -29,7 +29,7 @@ var FileAccessLogTest = suite.ConformanceTest{ Description: "Make sure file access log is working", Manifests: []string{"testdata/accesslog-file.yaml"}, Test: func(t *testing.T, suite *suite.ConformanceTestSuite) { - t.Run("Stdout", func(t *testing.T) { + t.Run("Positive", func(t *testing.T) { ns := "gateway-conformance-infra" routeNN := types.NamespacedName{Name: "accesslog-file", Namespace: ns} gwNN := types.NamespacedName{Name: "same-namespace", Namespace: ns} @@ -55,59 +55,8 @@ var FileAccessLogTest = suite.ConformanceTest{ "k8s_namespace_name": "envoy-gateway-system", "k8s_container_name": "envoy", } - // let's wait for the log to be sent to stdout - if err := wait.PollUntilContextTimeout(context.TODO(), time.Second, time.Minute, true, - func(ctx context.Context) (bool, error) { - // query log count from loki - count, err := QueryLogCountFromLoki(t, suite.Client, labels, "test-annotation-value") - if err != nil { - t.Logf("failed to get log count from loki: %v", err) - return false, nil - } - - if count > 0 { - return true, nil - } - return false, nil - }); err != nil { - t.Errorf("failed to wait log flush to loki: %v", err) - } - - if err := wait.PollUntilContextTimeout(context.TODO(), time.Second, time.Minute, true, - func(ctx context.Context) (bool, error) { - // query log count from loki - preCount, err := QueryLogCountFromLoki(t, suite.Client, labels, "test-annotation-value") - if err != nil { - t.Logf("failed to get log count from loki: %v", err) - return false, nil - } - - httputils.MakeRequestAndExpectEventuallyConsistentResponse(t, suite.RoundTripper, suite.TimeoutConfig, gwAddr, expectedResponse) - - // it will take some time for fluent-bit to collect the log and send to loki - // let's wait for a while - if err := wait.PollUntilContextTimeout(ctx, 500*time.Millisecond, 15*time.Second, true, func(_ context.Context) (bool, error) { - count, err := QueryLogCountFromLoki(t, suite.Client, labels, "test-annotation-value") - if err != nil { - t.Logf("failed to get log count from loki: %v", err) - return false, nil - } - - delta := count - preCount - if delta == 1 { - return true, nil - } - - t.Logf("preCount=%d, count=%d", preCount, count) - return false, nil - }); err != nil { - return false, nil - } - return true, nil - }); err != nil { - t.Errorf("failed to get log count from loki: %v", err) - } + runLogTest(t, suite, gwAddr, expectedResponse, labels, 1) }) }, } @@ -117,7 +66,7 @@ var OpenTelemetryTest = suite.ConformanceTest{ Description: "Make sure OpenTelemetry access log is working", Manifests: []string{"testdata/accesslog-otel.yaml"}, Test: func(t *testing.T, suite *suite.ConformanceTestSuite) { - t.Run("OTel", func(t *testing.T) { + t.Run("Positive", func(t *testing.T) { ns := "gateway-conformance-infra" routeNN := types.NamespacedName{Name: "accesslog-otel", Namespace: ns} gwNN := types.NamespacedName{Name: "same-namespace", Namespace: ns} @@ -142,39 +91,7 @@ var OpenTelemetryTest = suite.ConformanceTest{ "k8s_namespace_name": "envoy-gateway-system", "exporter": "OTLP", } - if err := wait.PollUntilContextTimeout(context.TODO(), time.Second, time.Minute, true, - func(ctx context.Context) (bool, error) { - // query log count from loki - preCount, err := QueryLogCountFromLoki(t, suite.Client, labels, "") - if err != nil { - t.Logf("failed to get log count from loki: %v", err) - return false, nil - } - - httputils.MakeRequestAndExpectEventuallyConsistentResponse(t, suite.RoundTripper, suite.TimeoutConfig, gwAddr, expectedResponse) - - if err := wait.PollUntilContextTimeout(ctx, 500*time.Millisecond, 10*time.Second, true, func(_ context.Context) (bool, error) { - count, err := QueryLogCountFromLoki(t, suite.Client, labels, "") - if err != nil { - t.Logf("failed to get log count from loki: %v", err) - return false, nil - } - - delta := count - preCount - if delta == 1 { - return true, nil - } - - t.Logf("preCount=%d, count=%d", preCount, count) - return false, nil - }); err != nil { - return false, nil - } - - return true, nil - }); err != nil { - t.Errorf("failed to get log count from loki: %v", err) - } + runLogTest(t, suite, gwAddr, expectedResponse, labels, 1) }) }, } @@ -215,3 +132,42 @@ var ALSTest = suite.ConformanceTest{ }) }, } + +func runLogTest(t *testing.T, suite *suite.ConformanceTestSuite, gwAddr string, + expectedResponse httputils.ExpectedResponse, expectedLabels map[string]string, expectedDelta int) { + if err := wait.PollUntilContextTimeout(context.TODO(), time.Second, time.Minute, true, + func(ctx context.Context) (bool, error) { + // query log count from loki + preCount, err := QueryLogCountFromLoki(t, suite.Client, expectedLabels, "test-annotation-value") + if err != nil { + t.Logf("failed to get log count from loki: %v", err) + return false, nil + } + + httputils.MakeRequestAndExpectEventuallyConsistentResponse(t, suite.RoundTripper, suite.TimeoutConfig, gwAddr, expectedResponse) + + // it will take some time for fluent-bit to collect the log and send to loki + // let's wait for a while + if err := wait.PollUntilContextTimeout(ctx, 500*time.Millisecond, 15*time.Second, true, func(_ context.Context) (bool, error) { + count, err := QueryLogCountFromLoki(t, suite.Client, expectedLabels, "test-annotation-value") + if err != nil { + t.Logf("failed to get log count from loki: %v", err) + return false, nil + } + + delta := count - preCount + if delta == expectedDelta { + return true, nil + } + + t.Logf("preCount=%d, count=%d", preCount, count) + return false, nil + }); err != nil { + return false, nil + } + + return true, nil + }); err != nil { + t.Errorf("failed to get log count from loki: %v", err) + } +} From d98309054b9ecbe26daac527ce3d9f0303919c0c Mon Sep 17 00:00:00 2001 From: zirain Date: Wed, 3 Jul 2024 11:05:44 +0800 Subject: [PATCH 3/4] negative test Signed-off-by: zirain --- test/e2e/tests/accesslog.go | 66 +++++++++++++++++++++++++++++++------ 1 file changed, 56 insertions(+), 10 deletions(-) diff --git a/test/e2e/tests/accesslog.go b/test/e2e/tests/accesslog.go index 24b390d3ae9..5967565ac8c 100644 --- a/test/e2e/tests/accesslog.go +++ b/test/e2e/tests/accesslog.go @@ -29,6 +29,12 @@ var FileAccessLogTest = suite.ConformanceTest{ Description: "Make sure file access log is working", Manifests: []string{"testdata/accesslog-file.yaml"}, Test: func(t *testing.T, suite *suite.ConformanceTestSuite) { + labels := map[string]string{ + "job": "fluentbit", + "k8s_namespace_name": "envoy-gateway-system", + "k8s_container_name": "envoy", + } + t.Run("Positive", func(t *testing.T) { ns := "gateway-conformance-infra" routeNN := types.NamespacedName{Name: "accesslog-file", Namespace: ns} @@ -50,13 +56,29 @@ var FileAccessLogTest = suite.ConformanceTest{ // make sure listener is ready httputils.MakeRequestAndExpectEventuallyConsistentResponse(t, suite.RoundTripper, suite.TimeoutConfig, gwAddr, expectedResponse) - labels := map[string]string{ - "job": "fluentbit", - "k8s_namespace_name": "envoy-gateway-system", - "k8s_container_name": "envoy", + runLogTest(t, suite, gwAddr, expectedResponse, labels, 1) + }) + + t.Run("Negative", func(t *testing.T) { + ns := "gateway-conformance-infra" + routeNN := types.NamespacedName{Name: "accesslog-file", Namespace: ns} + gwNN := types.NamespacedName{Name: "same-namespace", Namespace: ns} + gwAddr := kubernetes.GatewayAndHTTPRoutesMustBeAccepted(t, suite.Client, suite.TimeoutConfig, suite.ControllerName, kubernetes.NewGatewayRef(gwNN), routeNN) + + expectedResponse := httputils.ExpectedResponse{ + Request: httputils.Request{ + Path: "/file", + // envoy will not log this request without the header x-envoy-logged + }, + Response: httputils.Response{ + StatusCode: 200, + }, + Namespace: ns, } + // make sure listener is ready + httputils.MakeRequestAndExpectEventuallyConsistentResponse(t, suite.RoundTripper, suite.TimeoutConfig, gwAddr, expectedResponse) - runLogTest(t, suite, gwAddr, expectedResponse, labels, 1) + runLogTest(t, suite, gwAddr, expectedResponse, labels, 0) }) }, } @@ -66,6 +88,11 @@ var OpenTelemetryTest = suite.ConformanceTest{ Description: "Make sure OpenTelemetry access log is working", Manifests: []string{"testdata/accesslog-otel.yaml"}, Test: func(t *testing.T, suite *suite.ConformanceTestSuite) { + labels := map[string]string{ + "k8s_namespace_name": "envoy-gateway-system", + "exporter": "OTLP", + } + t.Run("Positive", func(t *testing.T) { ns := "gateway-conformance-infra" routeNN := types.NamespacedName{Name: "accesslog-otel", Namespace: ns} @@ -87,12 +114,30 @@ var OpenTelemetryTest = suite.ConformanceTest{ // make sure listener is ready httputils.MakeRequestAndExpectEventuallyConsistentResponse(t, suite.RoundTripper, suite.TimeoutConfig, gwAddr, expectedResponse) - labels := map[string]string{ - "k8s_namespace_name": "envoy-gateway-system", - "exporter": "OTLP", - } runLogTest(t, suite, gwAddr, expectedResponse, labels, 1) }) + + t.Run("Negative", func(t *testing.T) { + ns := "gateway-conformance-infra" + routeNN := types.NamespacedName{Name: "accesslog-otel", Namespace: ns} + gwNN := types.NamespacedName{Name: "same-namespace", Namespace: ns} + gwAddr := kubernetes.GatewayAndHTTPRoutesMustBeAccepted(t, suite.Client, suite.TimeoutConfig, suite.ControllerName, kubernetes.NewGatewayRef(gwNN), routeNN) + + expectedResponse := httputils.ExpectedResponse{ + Request: httputils.Request{ + Path: "/otel", + // envoy will not log this request without the header x-envoy-logged + }, + Response: httputils.Response{ + StatusCode: 200, + }, + Namespace: ns, + } + // make sure listener is ready + httputils.MakeRequestAndExpectEventuallyConsistentResponse(t, suite.RoundTripper, suite.TimeoutConfig, gwAddr, expectedResponse) + + runLogTest(t, suite, gwAddr, expectedResponse, labels, 0) + }) }, } @@ -134,7 +179,8 @@ var ALSTest = suite.ConformanceTest{ } func runLogTest(t *testing.T, suite *suite.ConformanceTestSuite, gwAddr string, - expectedResponse httputils.ExpectedResponse, expectedLabels map[string]string, expectedDelta int) { + expectedResponse httputils.ExpectedResponse, expectedLabels map[string]string, expectedDelta int, +) { if err := wait.PollUntilContextTimeout(context.TODO(), time.Second, time.Minute, true, func(ctx context.Context) (bool, error) { // query log count from loki From 4da1e3c3d2a16a9a3099a71f2c09773cf61fb2d2 Mon Sep 17 00:00:00 2001 From: zirain Date: Wed, 3 Jul 2024 12:10:53 +0800 Subject: [PATCH 4/4] fix match Signed-off-by: zirain --- test/e2e/tests/accesslog.go | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/test/e2e/tests/accesslog.go b/test/e2e/tests/accesslog.go index 5967565ac8c..b0de4543cb7 100644 --- a/test/e2e/tests/accesslog.go +++ b/test/e2e/tests/accesslog.go @@ -34,6 +34,7 @@ var FileAccessLogTest = suite.ConformanceTest{ "k8s_namespace_name": "envoy-gateway-system", "k8s_container_name": "envoy", } + match := "test-annotation-value" t.Run("Positive", func(t *testing.T) { ns := "gateway-conformance-infra" @@ -56,7 +57,7 @@ var FileAccessLogTest = suite.ConformanceTest{ // make sure listener is ready httputils.MakeRequestAndExpectEventuallyConsistentResponse(t, suite.RoundTripper, suite.TimeoutConfig, gwAddr, expectedResponse) - runLogTest(t, suite, gwAddr, expectedResponse, labels, 1) + runLogTest(t, suite, gwAddr, expectedResponse, labels, match, 1) }) t.Run("Negative", func(t *testing.T) { @@ -78,7 +79,7 @@ var FileAccessLogTest = suite.ConformanceTest{ // make sure listener is ready httputils.MakeRequestAndExpectEventuallyConsistentResponse(t, suite.RoundTripper, suite.TimeoutConfig, gwAddr, expectedResponse) - runLogTest(t, suite, gwAddr, expectedResponse, labels, 0) + runLogTest(t, suite, gwAddr, expectedResponse, labels, match, 0) }) }, } @@ -114,7 +115,7 @@ var OpenTelemetryTest = suite.ConformanceTest{ // make sure listener is ready httputils.MakeRequestAndExpectEventuallyConsistentResponse(t, suite.RoundTripper, suite.TimeoutConfig, gwAddr, expectedResponse) - runLogTest(t, suite, gwAddr, expectedResponse, labels, 1) + runLogTest(t, suite, gwAddr, expectedResponse, labels, "", 1) }) t.Run("Negative", func(t *testing.T) { @@ -136,7 +137,7 @@ var OpenTelemetryTest = suite.ConformanceTest{ // make sure listener is ready httputils.MakeRequestAndExpectEventuallyConsistentResponse(t, suite.RoundTripper, suite.TimeoutConfig, gwAddr, expectedResponse) - runLogTest(t, suite, gwAddr, expectedResponse, labels, 0) + runLogTest(t, suite, gwAddr, expectedResponse, labels, "", 0) }) }, } @@ -179,12 +180,12 @@ var ALSTest = suite.ConformanceTest{ } func runLogTest(t *testing.T, suite *suite.ConformanceTestSuite, gwAddr string, - expectedResponse httputils.ExpectedResponse, expectedLabels map[string]string, expectedDelta int, + expectedResponse httputils.ExpectedResponse, expectedLabels map[string]string, expectedMatch string, expectedDelta int, ) { if err := wait.PollUntilContextTimeout(context.TODO(), time.Second, time.Minute, true, func(ctx context.Context) (bool, error) { // query log count from loki - preCount, err := QueryLogCountFromLoki(t, suite.Client, expectedLabels, "test-annotation-value") + preCount, err := QueryLogCountFromLoki(t, suite.Client, expectedLabels, expectedMatch) if err != nil { t.Logf("failed to get log count from loki: %v", err) return false, nil @@ -195,7 +196,7 @@ func runLogTest(t *testing.T, suite *suite.ConformanceTestSuite, gwAddr string, // it will take some time for fluent-bit to collect the log and send to loki // let's wait for a while if err := wait.PollUntilContextTimeout(ctx, 500*time.Millisecond, 15*time.Second, true, func(_ context.Context) (bool, error) { - count, err := QueryLogCountFromLoki(t, suite.Client, expectedLabels, "test-annotation-value") + count, err := QueryLogCountFromLoki(t, suite.Client, expectedLabels, expectedMatch) if err != nil { t.Logf("failed to get log count from loki: %v", err) return false, nil