Skip to content

Commit

Permalink
test: avoid being conflict with well-known ports (#779)
Browse files Browse the repository at this point in the history
Signed-off-by: spacewander <[email protected]>
  • Loading branch information
spacewander authored Oct 29, 2024
1 parent 63f0785 commit 862558a
Show file tree
Hide file tree
Showing 12 changed files with 119 additions and 75 deletions.
5 changes: 5 additions & 0 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -153,6 +153,11 @@ jobs:
plugins-integration-test:
timeout-minutes: 10
runs-on: ubuntu-latest
env:
# to test the custom port feature
TEST_ENVOY_ADMIN_API_PORT: 9901
TEST_ENVOY_CONTROL_PLANE_PORT: 9902
TEST_ENVOY_DATA_PLANE_PORT: 9903
defaults:
run:
working-directory: ./plugins
Expand Down
13 changes: 12 additions & 1 deletion api/plugins/tests/integration/controlplane/control_plane.go
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,18 @@ func (cp *ControlPlane) Start() {
// only use it on Linux.
}

lis, _ := net.Listen("tcp", host+":9999")
port := ":9999"
portEnv := os.Getenv("TEST_ENVOY_CONTROL_PLANE_PORT")
if portEnv != "" {
port = ":" + portEnv
}

lis, err := net.Listen("tcp", host+port)
if err != nil {
logger.Error(err, "failed to listen")
return
}

if err := cp.grpcServer.Serve(lis); err != nil {
logger.Error(err, "failed to start control plane")
}
Expand Down
14 changes: 14 additions & 0 deletions api/plugins/tests/integration/dataplane/bootstrap.go
Original file line number Diff line number Diff line change
Expand Up @@ -149,6 +149,20 @@ func (b *bootstrap) buildConfiguration() (map[string]interface{}, error) {

staticResources := root["static_resources"].(map[string]interface{})
clusters := staticResources["clusters"].([]interface{})

port := "9999"
portEnv := os.Getenv("TEST_ENVOY_CONTROL_PLANE_PORT")
if portEnv != "" {
port = portEnv
}
for _, c := range clusters {
if c.(map[string]interface{})["name"] == "config_server" {
load := c.(map[string]interface{})["load_assignment"].(map[string]interface{})["endpoints"].([]interface{})[0].(map[string]interface{})["lb_endpoints"].([]interface{})[0].(map[string]interface{})["endpoint"].(map[string]interface{})["address"].(map[string]interface{})["socket_address"].(map[string]interface{})
load["port_value"] = port
break
}
}

newClusters := []interface{}{}
for _, c := range b.clusters {
newClusters = append(newClusters, c)
Expand Down
47 changes: 38 additions & 9 deletions api/plugins/tests/integration/dataplane/data_plane.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ import (
"path/filepath"
"regexp"
"runtime"
"strconv"
"strings"
"testing"
"time"
Expand All @@ -54,6 +55,9 @@ type DataPlane struct {
t *testing.T
opt *Option
done chan error

dataPlanePort string
adminAPIPort string
}

type Option struct {
Expand Down Expand Up @@ -189,6 +193,20 @@ func StartDataPlane(t *testing.T, opt *Option) (*DataPlane, error) {
return nil, err
}

adminAPIPort := "9998"
adminAPIPortEnv := os.Getenv("TEST_ENVOY_ADMIN_API_PORT")
if adminAPIPortEnv != "" {
adminAPIPort = adminAPIPortEnv
}
dp.adminAPIPort = adminAPIPort

dataPlanePort := "10000"
dataPlanePortEnv := os.Getenv("TEST_ENVOY_DATA_PLANE_PORT")
if dataPlanePortEnv != "" {
dataPlanePort = dataPlanePortEnv
}
dp.dataPlanePort = dataPlanePort

cmdline := "docker run" +
" --name " + containerName +
" --network " + networkName +
Expand All @@ -199,7 +217,8 @@ func StartDataPlane(t *testing.T, opt *Option) (*DataPlane, error) {
" -v /tmp:/tmp" +
" -e GOCOVERDIR=" + coverDir +
" " + strings.Join(envs, " ") +
" -p 10000:10000 -p 9998:9998 " + hostAddr + " " +
" -p " + dataPlanePort + ":10000 -p " + adminAPIPort + ":9998 " +
hostAddr + " " +
image

content, _ := os.ReadFile(cfgFile.Name())
Expand Down Expand Up @@ -256,7 +275,7 @@ func StartDataPlane(t *testing.T, opt *Option) (*DataPlane, error) {
go func() { done <- cmd.Wait() }()
}()

helper.WaitServiceUp(t, ":10000", "")
helper.WaitServiceUp(t, ":"+dataPlanePort, "")

select {
case err := <-done:
Expand Down Expand Up @@ -381,7 +400,7 @@ func (dp *DataPlane) Patch(path string, header http.Header, body io.Reader) (*ht
}

func (dp *DataPlane) SendAndCancelRequest(path string, after time.Duration) error {
conn, err := net.DialTimeout("tcp", ":10000", 1*time.Second)
conn, err := net.DialTimeout("tcp", ":"+dp.dataPlanePort, 1*time.Second)
if err != nil {
return err
}
Expand All @@ -404,13 +423,13 @@ func (dp *DataPlane) SendAndCancelRequest(path string, after time.Duration) erro
}

func (dp *DataPlane) do(method string, path string, header http.Header, body io.Reader) (*http.Response, error) {
req, err := http.NewRequest(method, "http://localhost:10000"+path, body)
req, err := http.NewRequest(method, "http://localhost:"+dp.dataPlanePort+path, body)
if err != nil {
return nil, err
}
req.Header = header
tr := &http.Transport{DialContext: func(ctx context.Context, proto, addr string) (conn net.Conn, err error) {
return net.DialTimeout("tcp", ":10000", 1*time.Second)
return net.DialTimeout("tcp", ":"+dp.dataPlanePort, 1*time.Second)
}}

client := &http.Client{Transport: tr,
Expand All @@ -424,7 +443,7 @@ func (dp *DataPlane) do(method string, path string, header http.Header, body io.
}

func (dp *DataPlane) doWithTrailer(method string, path string, header http.Header, body io.Reader, trailer http.Header) (*http.Response, error) {
req, err := http.NewRequest(method, "http://localhost:10000"+path, body)
req, err := http.NewRequest(method, "http://localhost:"+dp.dataPlanePort+path, body)
if err != nil {
return nil, err
}
Expand All @@ -434,7 +453,7 @@ func (dp *DataPlane) doWithTrailer(method string, path string, header http.Heade
req.TransferEncoding = []string{"chunked"}
tr := &http.Transport{
DialContext: func(ctx context.Context, proto, addr string) (conn net.Conn, err error) {
return net.DialTimeout("tcp", ":10000", 1*time.Second)
return net.DialTimeout("tcp", ":"+dp.dataPlanePort, 1*time.Second)
},
}

Expand All @@ -451,7 +470,7 @@ func (dp *DataPlane) doWithTrailer(method string, path string, header http.Heade
// Use grpcurl so that the caller can specify the proto file without building the Go code.
// TODO: we can rewrite this in Go.
func (dp *DataPlane) Grpcurl(importPath, protoFile, fullMethodName, req string) ([]byte, error) {
cmd := exec.Command("grpcurl", "-v", "-format-error", "-import-path", importPath, "-proto", protoFile, "-plaintext", "-d", req, ":10000", fullMethodName)
cmd := exec.Command("grpcurl", "-v", "-format-error", "-import-path", importPath, "-proto", protoFile, "-plaintext", "-d", req, ":"+dp.dataPlanePort, fullMethodName)
dp.t.Logf("run grpcurl command: %s", cmd.String())
return cmd.CombinedOutput()
}
Expand Down Expand Up @@ -479,7 +498,7 @@ func (dp *DataPlane) FlushCoverage() error {
}

func (dp *DataPlane) SetLogLevel(loggerName string, level string) error {
req, err := http.NewRequest("POST", fmt.Sprintf("http://0.0.0.0:9998/logging?%s=%s", loggerName, level), bytes.NewReader([]byte{}))
req, err := http.NewRequest("POST", fmt.Sprintf("http://0.0.0.0:%s/logging?%s=%s", dp.adminAPIPort, loggerName, level), bytes.NewReader([]byte{}))
if err != nil {
return err
}
Expand All @@ -497,3 +516,13 @@ func (dp *DataPlane) SetLogLevel(loggerName string, level string) error {

return nil
}

func (dp *DataPlane) AdminAPIPort() int {
p, _ := strconv.Atoi(dp.adminAPIPort)
return p
}

func (dp *DataPlane) Port() int {
p, _ := strconv.Atoi(dp.dataPlanePort)
return p
}
2 changes: 1 addition & 1 deletion api/tests/integration/filtermanager_latest_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -242,7 +242,7 @@ func TestFilterManagerTrailersWithGrpcBackend(t *testing.T) {
}
defer dp.Stop()

helper.WaitServiceUp(t, ":50051", "grpc")
helper.WaitServiceUp(t, ":50001", "grpc")

s := &filtermanager.FilterManagerConfig{
Plugins: []*model.FilterConfig{
Expand Down
2 changes: 1 addition & 1 deletion api/tests/integration/testdata/grpc_backend.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,4 +10,4 @@ load_assignment:
address:
socket_address:
address: grpc
port_value: 50051
port_value: 50001
2 changes: 1 addition & 1 deletion api/tests/integration/testdata/services/docker-compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ services:
grpc:
build: ./grpc
ports:
- "50051:50051"
- "50001:50001"
restart: unless-stopped
networks:
service:
Expand Down
4 changes: 2 additions & 2 deletions api/tests/integration/testdata/services/grpc/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ func (s *sampleServer) Ouch(ctx context.Context, req *HelloRequest) (*HelloRespo

func main() {
// Create a TCP listener
lis, err := net.Listen("tcp", ":50051")
lis, err := net.Listen("tcp", ":50001")
if err != nil {
log.Fatalf("Failed to listen: %v", err)
}
Expand All @@ -42,7 +42,7 @@ func main() {
RegisterSampleServer(s, &sampleServer{})

// Start the server
fmt.Println("Server started. Listening on port :50051")
fmt.Println("Server started. Listening on port :50001")
if err := s.Serve(lis); err != nil {
log.Fatalf("Failed to serve: %v", err)
}
Expand Down
5 changes: 3 additions & 2 deletions plugins/tests/integration/oidc_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ package integration
import (
"encoding/base64"
"encoding/json"
"fmt"
"net/http"
"net/url"
"os/exec"
Expand All @@ -41,7 +42,7 @@ func TestOIDC(t *testing.T) {

helper.WaitServiceUp(t, ":4444", "hydra")

redirectURL := "http://127.0.0.1:10000/echo"
redirectURL := fmt.Sprintf("http://127.0.0.1:%d/echo", dp.Port())
hydraCmd := "hydra create client --response-type code,id_token " +
"--grant-type authorization_code,refresh_token -e http://127.0.0.1:4445 " +
"--redirect-uri " + redirectURL + " --format json"
Expand Down Expand Up @@ -89,7 +90,7 @@ func TestOIDC(t *testing.T) {
encodedURL := strings.Split(u.Query().Get("state"), ".")[1]
b, _ := base64.URLEncoding.DecodeString(encodedURL)
originURL := string(b)
require.Equal(t, "http://localhost:10000/echo?a=1", originURL)
require.Equal(t, fmt.Sprintf("http://localhost:%d/echo?a=1", dp.Port()), originURL)
require.NotEmpty(t, u.Query().Get("nonce"))
require.NotEmpty(t, u.Query().Get("code_challenge"))
cookie := resp.Header.Get("Set-Cookie")
Expand Down
Loading

0 comments on commit 862558a

Please sign in to comment.