Files
higress/test/e2e/conformance/tests/httproute-mirror-target-service.go
2024-09-23 13:53:08 +08:00

108 lines
3.5 KiB
Go

// Copyright (c) 2022 Alibaba Group Holding Ltd.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package tests
import (
"bytes"
"context"
"io"
"strings"
"testing"
"time"
"github.com/alibaba/higress/test/e2e/conformance/utils/http"
"github.com/alibaba/higress/test/e2e/conformance/utils/suite"
v1 "k8s.io/api/core/v1"
meta_v1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/client-go/kubernetes"
"sigs.k8s.io/controller-runtime/pkg/client/config"
)
func init() {
Register(HTTPRouteMirrorTargetService)
}
var HTTPRouteMirrorTargetService = suite.ConformanceTest{
ShortName: "HTTPRouteMirrorTargetService",
Description: "The Ingress in the higress-conformance-infra namespace mirror request to target service",
Features: []suite.SupportedFeature{suite.HTTPConformanceFeature},
Manifests: []string{"tests/httproute-mirror-target-service.yaml"},
Test: func(t *testing.T, suite *suite.ConformanceTestSuite) {
testcases := []http.Assertion{
{
Meta: http.AssertionMeta{
TargetBackend: "infra-backend-v1",
TargetNamespace: "higress-conformance-infra",
},
Request: http.AssertionRequest{
ActualRequest: http.Request{
Path: "/mirror",
},
},
Response: http.AssertionResponse{
ExpectedResponse: http.Response{
StatusCode: 200,
},
},
},
}
t.Run("HTTPRoute mirror request to target service", func(t *testing.T) {
for _, testcase := range testcases {
http.MakeRequestAndExpectEventuallyConsistentResponse(t, suite.RoundTripper, suite.TimeoutConfig, suite.GatewayAddress, testcase)
//check mirror's logs for request
cfg, err := config.GetConfig()
if err != nil {
t.Fatalf("[httproute-mirror] get config failed.")
return
}
clientSet, err := kubernetes.NewForConfig(cfg)
if err != nil {
t.Fatalf("[httproute-mirror] init clientset failed.")
return
}
pods, err := clientSet.CoreV1().Pods("higress-conformance-infra").List(context.Background(), meta_v1.ListOptions{
LabelSelector: meta_v1.FormatLabelSelector(&meta_v1.LabelSelector{MatchLabels: map[string]string{"app": "infra-backend-mirror"}}),
})
if err != nil || len(pods.Items) == 0 {
t.Fatalf("[httproute-mirror] get pods by label of [\"app\": \"infra-backend-mirror\"] failed.")
return
}
req := clientSet.CoreV1().Pods("higress-conformance-infra").GetLogs(pods.Items[0].Name, &v1.PodLogOptions{
Container: "infra-backend-mirror",
SinceTime: &meta_v1.Time{Time: time.Now().Add(-time.Second * 10)},
})
podLogs, err := req.Stream(context.Background())
defer podLogs.Close()
if err != nil {
t.Fatalf("[httproute-mirror] init pod logs stream failed.")
return
}
podBuf := new(bytes.Buffer)
_, err = io.Copy(podBuf, podLogs)
if err != nil {
t.Fatalf("[httproute-mirror] read pod logs stream failed.")
return
}
if !strings.Contains(podBuf.String(), "Echoing back request made to /mirror") {
t.Fatalf("[httproute-mirror] mirror pod hasn't received any mirror requests in logs.")
return
}
}
})
},
}