2020-12-15 16:40:05 +01:00
|
|
|
package gateway
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2024-03-25 14:38:04 +01:00
|
|
|
"errors"
|
2020-12-15 16:40:05 +01:00
|
|
|
"testing"
|
2022-11-16 11:38:07 +01:00
|
|
|
"time"
|
2020-12-15 16:40:05 +01:00
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/stretchr/testify/require"
|
2022-11-16 11:38:07 +01:00
|
|
|
ptypes "github.com/traefik/paerser/types"
|
2023-02-03 15:24:05 +01:00
|
|
|
"github.com/traefik/traefik/v3/pkg/config/dynamic"
|
|
|
|
"github.com/traefik/traefik/v3/pkg/provider"
|
2024-03-25 14:38:04 +01:00
|
|
|
traefikv1alpha1 "github.com/traefik/traefik/v3/pkg/provider/kubernetes/crd/traefikio/v1alpha1"
|
2023-02-03 15:24:05 +01:00
|
|
|
"github.com/traefik/traefik/v3/pkg/tls"
|
2024-01-11 21:36:06 +05:30
|
|
|
"github.com/traefik/traefik/v3/pkg/types"
|
2021-11-09 11:34:06 +01:00
|
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
2024-01-09 10:28:05 +01:00
|
|
|
"k8s.io/utils/ptr"
|
|
|
|
gatev1 "sigs.k8s.io/gateway-api/apis/v1"
|
2024-01-30 16:44:05 +01:00
|
|
|
gatev1beta1 "sigs.k8s.io/gateway-api/apis/v1beta1"
|
2020-12-15 16:40:05 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
var _ provider.Provider = (*Provider)(nil)
|
|
|
|
|
|
|
|
func TestLoadHTTPRoutes(t *testing.T) {
|
|
|
|
testCases := []struct {
|
2024-04-02 17:32:04 +02:00
|
|
|
desc string
|
|
|
|
ingressClass string
|
|
|
|
paths []string
|
|
|
|
expected *dynamic.Configuration
|
|
|
|
entryPoints map[string]Entrypoint
|
|
|
|
experimentalChannel bool
|
2020-12-15 16:40:05 +01:00
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "Empty",
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty because missing entry point",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/simple.yml"},
|
2020-12-15 16:40:05 +01:00
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":443",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty because no http route defined",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/without_httproute.yml"},
|
2020-12-15 16:40:05 +01:00
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by missing GatewayClass",
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/without_gatewayclass.yml"},
|
2020-12-15 16:40:05 +01:00
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Empty caused by unknown GatewayClass controller desc",
|
2020-12-15 16:40:05 +01:00
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/gatewayclass_with_unknown_controller.yml"},
|
2020-12-15 16:40:05 +01:00
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Empty caused by multi ports service with wrong TargetPort",
|
2020-12-15 16:40:05 +01:00
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/with_wrong_service_port.yml"},
|
2020-12-15 16:40:05 +01:00
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by HTTPS without TLS",
|
|
|
|
entryPoints: map[string]Entrypoint{"websecure": {
|
|
|
|
Address: ":443",
|
|
|
|
}},
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/with_protocol_https_without_tls.yml"},
|
2020-12-15 16:40:05 +01:00
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
2021-05-20 11:50:12 +02:00
|
|
|
{
|
|
|
|
desc: "Empty caused by HTTPS with TLS passthrough",
|
|
|
|
entryPoints: map[string]Entrypoint{"websecure": {
|
|
|
|
Address: ":443",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "httproute/with_protocol_https_with_tls_passthrough.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by HTTPRoute with protocol TLS",
|
|
|
|
entryPoints: map[string]Entrypoint{"websecure": {
|
|
|
|
Address: ":443",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "httproute/with_protocol_tls.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by HTTPRoute with protocol TCP",
|
|
|
|
entryPoints: map[string]Entrypoint{"websecure": {
|
|
|
|
Address: ":443",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "httproute/with_protocol_tcp.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by TCPRoute with protocol HTTP",
|
|
|
|
entryPoints: map[string]Entrypoint{"websecure": {
|
|
|
|
Address: ":9000",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "tcproute/with_protocol_http.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by TCPRoute with protocol HTTPS",
|
|
|
|
entryPoints: map[string]Entrypoint{"websecure": {
|
|
|
|
Address: ":9000",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "tcproute/with_protocol_https.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by TLSRoute with protocol TCP",
|
|
|
|
entryPoints: map[string]Entrypoint{"websecure": {
|
|
|
|
Address: ":9001",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "tlsroute/with_protocol_tcp.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by TLSRoute with protocol HTTP",
|
|
|
|
entryPoints: map[string]Entrypoint{"websecure": {
|
|
|
|
Address: ":9001",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "tlsroute/with_protocol_http.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by TLSRoute with protocol HTTPS",
|
|
|
|
entryPoints: map[string]Entrypoint{"websecure": {
|
|
|
|
Address: ":9001",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "tlsroute/with_protocol_https.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused use http entrypoint with tls activated with HTTPRoute",
|
|
|
|
entryPoints: map[string]Entrypoint{"websecure": {
|
|
|
|
Address: ":443",
|
|
|
|
HasHTTPTLSConf: true,
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "httproute/simple_with_tls_entrypoint.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused unsupported HTTPRoute rule",
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "httproute/simple_with_bad_rule.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty because no tcp route defined tls protocol",
|
|
|
|
paths: []string{"services.yml", "tcproute/without_tcproute_tls_protocol.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{"TCP": {
|
|
|
|
Address: ":8080",
|
|
|
|
}},
|
2024-04-02 17:32:04 +02:00
|
|
|
experimentalChannel: true,
|
2021-05-20 11:50:12 +02:00
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{
|
|
|
|
Certificates: []*tls.CertAndStores{
|
|
|
|
{
|
|
|
|
Certificate: tls.Certificate{
|
2024-01-11 21:36:06 +05:30
|
|
|
CertFile: types.FileOrContent("-----BEGIN CERTIFICATE-----\n-----END CERTIFICATE-----"),
|
|
|
|
KeyFile: types.FileOrContent("-----BEGIN PRIVATE KEY-----\n-----END PRIVATE KEY-----"),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Empty caused by HTTPRoute with TLS configuration",
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "httproute/with_tls_configuration.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/simple.yml"},
|
2020-12-15 16:40:05 +01:00
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
2021-02-02 19:36:04 +01:00
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2021-02-02 19:36:04 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-07-15 17:32:11 +05:30
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-02-02 19:36:04 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute, with api@internal service",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/simple_to_api_internal.yml"},
|
2021-02-02 19:36:04 +01:00
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-02-02 19:36:04 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "api@internal",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-02-02 19:36:04 +01:00
|
|
|
},
|
|
|
|
},
|
2021-07-15 17:32:11 +05:30
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-02-02 19:36:04 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute with protocol HTTPS",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/with_protocol_https.yml"},
|
2020-12-15 16:40:05 +01:00
|
|
|
entryPoints: map[string]Entrypoint{"websecure": {
|
|
|
|
Address: ":443",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-websecure-1c0cf64bde37d9d0df06": {
|
|
|
|
EntryPoints: []string{"websecure"},
|
|
|
|
Service: "default-http-app-1-my-gateway-websecure-1c0cf64bde37d9d0df06-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2020-12-15 16:40:05 +01:00
|
|
|
TLS: &dynamic.RouterTLSConfig{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-websecure-1c0cf64bde37d9d0df06-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-07-15 17:32:11 +05:30
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{
|
|
|
|
Certificates: []*tls.CertAndStores{
|
|
|
|
{
|
|
|
|
Certificate: tls.Certificate{
|
2024-01-11 21:36:06 +05:30
|
|
|
CertFile: types.FileOrContent("-----BEGIN CERTIFICATE-----\n-----END CERTIFICATE-----"),
|
|
|
|
KeyFile: types.FileOrContent("-----BEGIN PRIVATE KEY-----\n-----END PRIVATE KEY-----"),
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute, with multiple hosts",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/with_multiple_host.yml"},
|
2020-12-15 16:40:05 +01:00
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
2022-11-28 15:48:05 +01:00
|
|
|
"default-http-app-1-my-gateway-web-66e726cd8903b49727ae": {
|
2020-12-15 16:40:05 +01:00
|
|
|
EntryPoints: []string{"web"},
|
2022-11-28 15:48:05 +01:00
|
|
|
Service: "default-http-app-1-my-gateway-web-66e726cd8903b49727ae-wrr",
|
|
|
|
Rule: "(Host(`foo.com`) || Host(`bar.com`)) && PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
2022-11-28 15:48:05 +01:00
|
|
|
"default-http-app-1-my-gateway-web-66e726cd8903b49727ae-wrr": {
|
2020-12-15 16:40:05 +01:00
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-07-15 17:32:11 +05:30
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
2021-04-29 10:18:04 -05:00
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute, with two hosts one wildcard",
|
|
|
|
paths: []string{"services.yml", "with_two_hosts_one_wildcard.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
2022-11-28 15:48:05 +01:00
|
|
|
"default-http-app-1-my-gateway-web-3b78e2feb3295ddd87f0": {
|
2021-04-29 10:18:04 -05:00
|
|
|
EntryPoints: []string{"web"},
|
2022-11-28 15:48:05 +01:00
|
|
|
Service: "default-http-app-1-my-gateway-web-3b78e2feb3295ddd87f0-wrr",
|
|
|
|
Rule: "(Host(`foo.com`) || HostRegexp(`^[a-zA-Z0-9-]+\\.bar\\.com$`)) && PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
2022-11-28 15:48:05 +01:00
|
|
|
"default-http-app-1-my-gateway-web-3b78e2feb3295ddd87f0-wrr": {
|
2021-04-29 10:18:04 -05:00
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-07-15 17:32:11 +05:30
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute, with one host and a wildcard",
|
|
|
|
paths: []string{"services.yml", "with_two_hosts_wildcard.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
2022-11-28 15:48:05 +01:00
|
|
|
"default-http-app-1-my-gateway-web-b0521a61fb43068694b4": {
|
2021-04-29 10:18:04 -05:00
|
|
|
EntryPoints: []string{"web"},
|
2022-11-28 15:48:05 +01:00
|
|
|
Service: "default-http-app-1-my-gateway-web-b0521a61fb43068694b4-wrr",
|
|
|
|
Rule: "(Host(`foo.com`) || HostRegexp(`^[a-zA-Z0-9-]+\\.foo\\.com$`)) && PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
2022-11-28 15:48:05 +01:00
|
|
|
"default-http-app-1-my-gateway-web-b0521a61fb43068694b4-wrr": {
|
2021-04-29 10:18:04 -05:00
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-07-15 17:32:11 +05:30
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
{
|
|
|
|
desc: "One HTTPRoute with two different rules",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/two_rules.yml"},
|
2020-12-15 16:40:05 +01:00
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2020-12-15 16:40:05 +01:00
|
|
|
Service: "default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr",
|
|
|
|
},
|
|
|
|
"default-http-app-1-my-gateway-web-d737b4933fa88e68ab8a": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bir`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2020-12-15 16:40:05 +01:00
|
|
|
Service: "default-http-app-1-my-gateway-web-d737b4933fa88e68ab8a-wrr",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-http-app-1-my-gateway-web-d737b4933fa88e68ab8a-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami2-8080",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami2-8080": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.3:8080",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.4:8080",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-07-15 17:32:11 +05:30
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "One HTTPRoute with one rule two targets",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/one_rule_two_targets.yml"},
|
2020-12-15 16:40:05 +01:00
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2020-12-15 16:40:05 +01:00
|
|
|
Service: "default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "default-whoami2-8080",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami2-8080": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.3:8080",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.4:8080",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-07-15 17:32:11 +05:30
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Two Gateways and one HTTPRoute",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/with_two_gateways_one_httproute.yml"},
|
2020-12-15 16:40:05 +01:00
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"web": {
|
|
|
|
Address: ":80",
|
|
|
|
},
|
|
|
|
"websecure": {
|
|
|
|
Address: ":443",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-http-web-1c0cf64bde37d9d0df06": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-1-my-gateway-http-web-1c0cf64bde37d9d0df06-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
"default-http-app-1-my-gateway-https-websecure-1c0cf64bde37d9d0df06": {
|
|
|
|
EntryPoints: []string{"websecure"},
|
|
|
|
Service: "default-http-app-1-my-gateway-https-websecure-1c0cf64bde37d9d0df06-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2020-12-15 16:40:05 +01:00
|
|
|
TLS: &dynamic.RouterTLSConfig{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-http-web-1c0cf64bde37d9d0df06-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-http-app-1-my-gateway-https-websecure-1c0cf64bde37d9d0df06-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-07-15 17:32:11 +05:30
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{
|
|
|
|
Certificates: []*tls.CertAndStores{
|
|
|
|
{
|
|
|
|
Certificate: tls.Certificate{
|
2024-01-11 21:36:06 +05:30
|
|
|
CertFile: types.FileOrContent("-----BEGIN CERTIFICATE-----\n-----END CERTIFICATE-----"),
|
|
|
|
KeyFile: types.FileOrContent("-----BEGIN PRIVATE KEY-----\n-----END PRIVATE KEY-----"),
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Gateway with two listeners and one HTTPRoute",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/with_two_listeners_one_httproute.yml"},
|
2020-12-15 16:40:05 +01:00
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"web": {
|
|
|
|
Address: ":80",
|
|
|
|
},
|
|
|
|
"websecure": {
|
|
|
|
Address: ":443",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
"default-http-app-1-my-gateway-websecure-1c0cf64bde37d9d0df06": {
|
|
|
|
EntryPoints: []string{"websecure"},
|
|
|
|
Service: "default-http-app-1-my-gateway-websecure-1c0cf64bde37d9d0df06-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2020-12-15 16:40:05 +01:00
|
|
|
TLS: &dynamic.RouterTLSConfig{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-http-app-1-my-gateway-websecure-1c0cf64bde37d9d0df06-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-07-15 17:32:11 +05:30
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{
|
|
|
|
Certificates: []*tls.CertAndStores{
|
|
|
|
{
|
|
|
|
Certificate: tls.Certificate{
|
2024-01-11 21:36:06 +05:30
|
|
|
CertFile: types.FileOrContent("-----BEGIN CERTIFICATE-----\n-----END CERTIFICATE-----"),
|
|
|
|
KeyFile: types.FileOrContent("-----BEGIN PRIVATE KEY-----\n-----END PRIVATE KEY-----"),
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute, with several rules",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "httproute/with_several_rules.yml"},
|
2020-12-15 16:40:05 +01:00
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
2024-01-23 11:34:05 +01:00
|
|
|
"default-http-app-1-my-gateway-web-4a1b73e6f83804949a37": {
|
2020-12-15 16:40:05 +01:00
|
|
|
EntryPoints: []string{"web"},
|
2024-01-23 11:34:05 +01:00
|
|
|
Service: "default-http-app-1-my-gateway-web-4a1b73e6f83804949a37-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && PathPrefix(`/bar`) && Header(`my-header`,`foo`) && Header(`my-header2`,`bar`)",
|
|
|
|
RuleSyntax: "v3",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
2024-01-23 11:34:05 +01:00
|
|
|
"default-http-app-1-my-gateway-web-aaba0f24fd26e1ca2276": {
|
2020-12-15 16:40:05 +01:00
|
|
|
EntryPoints: []string{"web"},
|
2024-01-23 11:34:05 +01:00
|
|
|
Service: "default-http-app-1-my-gateway-web-aaba0f24fd26e1ca2276-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`) && Header(`my-header`,`bar`)",
|
|
|
|
RuleSyntax: "v3",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
2024-01-23 11:34:05 +01:00
|
|
|
"default-http-app-1-my-gateway-web-4a1b73e6f83804949a37-wrr": {
|
2020-12-15 16:40:05 +01:00
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2024-01-23 11:34:05 +01:00
|
|
|
"default-http-app-1-my-gateway-web-aaba0f24fd26e1ca2276-wrr": {
|
2020-12-15 16:40:05 +01:00
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-07-15 17:32:11 +05:30
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
2021-10-04 15:46:08 +02:00
|
|
|
{
|
|
|
|
desc: "HTTPRoute with Same namespace selector",
|
|
|
|
paths: []string{"services.yml", "httproute/with_namespace_same.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"web": {Address: ":80"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-default-my-gateway-web-efde1997778109a1f6eb": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-default-my-gateway-web-efde1997778109a1f6eb-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/foo`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-default-my-gateway-web-efde1997778109a1f6eb-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "HTTPRoute with All namespace selector",
|
|
|
|
paths: []string{"services.yml", "httproute/with_namespace_all.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"web": {Address: ":80"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-default-my-gateway-web-efde1997778109a1f6eb": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-default-my-gateway-web-efde1997778109a1f6eb-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/foo`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
"bar-http-app-bar-my-gateway-web-66f5c78d03d948e36597": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "bar-http-app-bar-my-gateway-web-66f5c78d03d948e36597-wrr",
|
|
|
|
Rule: "Host(`bar.com`) && Path(`/bar`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-default-my-gateway-web-efde1997778109a1f6eb-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-http-app-bar-my-gateway-web-66f5c78d03d948e36597-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoami-bar-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-whoami-bar-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.11:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.12:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "HTTPRoute with namespace selector",
|
2021-10-04 15:46:08 +02:00
|
|
|
paths: []string{"services.yml", "httproute/with_namespace_selector.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"web": {Address: ":80"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"bar-http-app-bar-my-gateway-web-66f5c78d03d948e36597": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "bar-http-app-bar-my-gateway-web-66f5c78d03d948e36597-wrr",
|
|
|
|
Rule: "Host(`bar.com`) && Path(`/bar`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"bar-http-app-bar-my-gateway-web-66f5c78d03d948e36597-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoami-bar-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-whoami-bar-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.11:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.12:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-12-22 14:02:05 +00:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
2024-04-05 17:18:03 +02:00
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute, request header modifier",
|
|
|
|
paths: []string{"services.yml", "httproute/filter_request_header_modifier.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4-wrr",
|
|
|
|
Rule: "Host(`example.org`) && PathPrefix(`/`)",
|
|
|
|
RuleSyntax: "v3",
|
|
|
|
Middlewares: []string{"default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4-requestheadermodifier-0"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{
|
|
|
|
"default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4-requestheadermodifier-0": {
|
|
|
|
RequestHeaderModifier: &dynamic.RequestHeaderModifier{
|
|
|
|
Set: map[string]string{"X-Foo": "Bar"},
|
|
|
|
Add: map[string]string{"X-Bar": "Foo"},
|
|
|
|
Remove: []string{"X-Baz"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
PassHostHeader: ptr.To(true),
|
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
2022-12-22 14:02:05 +00:00
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute, redirect HTTP to HTTPS",
|
|
|
|
paths: []string{"services.yml", "httproute/filter_http_to_https.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4-wrr",
|
|
|
|
Rule: "Host(`example.org`) && PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2022-12-22 14:02:05 +00:00
|
|
|
Middlewares: []string{"default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4-requestredirect-0"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{
|
|
|
|
"default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4-requestredirect-0": {
|
|
|
|
RedirectRegex: &dynamic.RedirectRegex{
|
|
|
|
Regex: "^[a-z]+:\\/\\/(?P<userInfo>.+@)?(?P<hostname>\\[[\\w:\\.]+\\]|[\\w\\._-]+)(?P<port>:\\d+)?\\/(?P<path>.*)",
|
|
|
|
Replacement: "https://${userinfo}${hostname}${port}/${path}",
|
|
|
|
Permanent: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-12-22 14:02:05 +00:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute, redirect HTTP to HTTPS with hostname",
|
|
|
|
paths: []string{"services.yml", "httproute/filter_http_to_https_with_hostname_and_port.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4-wrr",
|
|
|
|
Rule: "Host(`example.org`) && PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2022-12-22 14:02:05 +00:00
|
|
|
Middlewares: []string{"default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4-requestredirect-0"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{
|
|
|
|
"default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4-requestredirect-0": {
|
|
|
|
RedirectRegex: &dynamic.RedirectRegex{
|
|
|
|
Regex: "^[a-z]+:\\/\\/(?P<userInfo>.+@)?(?P<hostname>\\[[\\w:\\.]+\\]|[\\w\\._-]+)(?P<port>:\\d+)?\\/(?P<path>.*)",
|
|
|
|
Replacement: "http://${userinfo}example.com:443/${path}",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-web-364ce6ec04c3d49b19c4-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
if test.expected == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-04-02 17:32:04 +02:00
|
|
|
p := Provider{EntryPoints: test.entryPoints, ExperimentalChannel: test.experimentalChannel}
|
2024-03-25 14:38:04 +01:00
|
|
|
|
2020-12-15 16:40:05 +01:00
|
|
|
conf := p.loadConfigurationFromGateway(context.Background(), newClientMock(test.paths...))
|
|
|
|
assert.Equal(t, test.expected, conf)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-25 14:38:04 +01:00
|
|
|
func TestLoadHTTPRoutes_backendExtensionRef(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
desc string
|
|
|
|
paths []string
|
|
|
|
groupKindBackendFuncs map[string]map[string]BuildBackendFunc
|
|
|
|
expected *dynamic.Configuration
|
|
|
|
entryPoints map[string]Entrypoint
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute with TraefikService",
|
|
|
|
paths: []string{"services.yml", "httproute/simple_with_TraefikService.yml"},
|
|
|
|
groupKindBackendFuncs: map[string]map[string]BuildBackendFunc{
|
|
|
|
traefikv1alpha1.GroupName: {"TraefikService": func(name, namespace string) (string, *dynamic.Service, error) {
|
|
|
|
return name, nil, nil
|
|
|
|
}},
|
|
|
|
},
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`)",
|
|
|
|
RuleSyntax: "v3",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "whoami",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute with TraefikService with service configuration",
|
|
|
|
paths: []string{"services.yml", "httproute/simple_with_TraefikService.yml"},
|
|
|
|
groupKindBackendFuncs: map[string]map[string]BuildBackendFunc{
|
|
|
|
traefikv1alpha1.GroupName: {"TraefikService": func(name, namespace string) (string, *dynamic.Service, error) {
|
|
|
|
return name, &dynamic.Service{LoadBalancer: &dynamic.ServersLoadBalancer{Servers: []dynamic.Server{{URL: "foobar"}}}}, nil
|
|
|
|
}},
|
|
|
|
},
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`)",
|
|
|
|
RuleSyntax: "v3",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "whoami",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"whoami": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{URL: "foobar"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute with invalid TraefikService kind",
|
|
|
|
paths: []string{"services.yml", "httproute/simple_with_TraefikService.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute with backendFunc error",
|
|
|
|
paths: []string{"services.yml", "httproute/simple_with_TraefikService.yml"},
|
|
|
|
groupKindBackendFuncs: map[string]map[string]BuildBackendFunc{
|
|
|
|
traefikv1alpha1.GroupName: {"TraefikService": func(name, namespace string) (string, *dynamic.Service, error) {
|
|
|
|
return "", nil, errors.New("BOOM")
|
|
|
|
}},
|
|
|
|
},
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple HTTPRoute, with myservice@file service",
|
|
|
|
paths: []string{"services.yml", "httproute/simple_cross_provider.yml"},
|
|
|
|
groupKindBackendFuncs: map[string]map[string]BuildBackendFunc{
|
|
|
|
traefikv1alpha1.GroupName: {"TraefikService": func(name, namespace string) (string, *dynamic.Service, error) {
|
|
|
|
// func should never be executed in case of cross-provider reference.
|
|
|
|
return "", nil, errors.New("BOOM")
|
|
|
|
}},
|
|
|
|
},
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`)",
|
|
|
|
RuleSyntax: "v3",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "service@file",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
PassHostHeader: ptr.To(true),
|
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
if test.expected == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
p := Provider{EntryPoints: test.entryPoints}
|
|
|
|
for group, kindFuncs := range test.groupKindBackendFuncs {
|
|
|
|
for kind, backendFunc := range kindFuncs {
|
|
|
|
p.RegisterBackendFuncs(group, kind, backendFunc)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
conf := p.loadConfigurationFromGateway(context.Background(), newClientMock(test.paths...))
|
|
|
|
assert.Equal(t, test.expected, conf)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestLoadHTTPRoutes_filterExtensionRef(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
desc string
|
|
|
|
groupKindFilterFuncs map[string]map[string]BuildFilterFunc
|
|
|
|
expected *dynamic.Configuration
|
|
|
|
entryPoints map[string]Entrypoint
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "HTTPRoute with ExtensionRef filter",
|
|
|
|
groupKindFilterFuncs: map[string]map[string]BuildFilterFunc{
|
|
|
|
traefikv1alpha1.GroupName: {"Middleware": func(name, namespace string) (string, *dynamic.Middleware, error) {
|
|
|
|
return namespace + "-" + name, nil, nil
|
|
|
|
}},
|
|
|
|
},
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`)",
|
|
|
|
RuleSyntax: "v3",
|
|
|
|
Middlewares: []string{"default-my-middleware"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
PassHostHeader: ptr.To(true),
|
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "HTTPRoute with ExtensionRef filter and create middleware",
|
|
|
|
groupKindFilterFuncs: map[string]map[string]BuildFilterFunc{
|
|
|
|
traefikv1alpha1.GroupName: {"Middleware": func(name, namespace string) (string, *dynamic.Middleware, error) {
|
|
|
|
return namespace + "-" + name, &dynamic.Middleware{Headers: &dynamic.Headers{CustomRequestHeaders: map[string]string{"Test-Header": "Test"}}}, nil
|
|
|
|
}},
|
|
|
|
},
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr",
|
|
|
|
Rule: "Host(`foo.com`) && Path(`/bar`)",
|
|
|
|
RuleSyntax: "v3",
|
|
|
|
Middlewares: []string{"default-my-middleware"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{
|
|
|
|
"default-my-middleware": {Headers: &dynamic.Headers{CustomRequestHeaders: map[string]string{"Test-Header": "Test"}}},
|
|
|
|
},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
PassHostHeader: ptr.To(true),
|
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "ExtensionRef filter: Unknown",
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "ExtensionRef filter with filterFunc error",
|
|
|
|
groupKindFilterFuncs: map[string]map[string]BuildFilterFunc{
|
|
|
|
traefikv1alpha1.GroupName: {"Middleware": func(name, namespace string) (string, *dynamic.Middleware, error) {
|
|
|
|
return "", nil, errors.New("BOOM")
|
|
|
|
}},
|
|
|
|
},
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":80",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
if test.expected == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
p := Provider{EntryPoints: test.entryPoints}
|
|
|
|
for group, kindFuncs := range test.groupKindFilterFuncs {
|
|
|
|
for kind, filterFunc := range kindFuncs {
|
|
|
|
p.RegisterFilterFuncs(group, kind, filterFunc)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
conf := p.loadConfigurationFromGateway(context.Background(), newClientMock([]string{"services.yml", "httproute/filter_extension_ref.yml"}...))
|
|
|
|
assert.Equal(t, test.expected, conf)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-20 11:50:12 +02:00
|
|
|
func TestLoadTCPRoutes(t *testing.T) {
|
2020-12-15 16:40:05 +01:00
|
|
|
testCases := []struct {
|
|
|
|
desc string
|
2021-05-20 11:50:12 +02:00
|
|
|
ingressClass string
|
|
|
|
paths []string
|
|
|
|
expected *dynamic.Configuration
|
|
|
|
entryPoints map[string]Entrypoint
|
2020-12-15 16:40:05 +01:00
|
|
|
}{
|
|
|
|
{
|
2021-05-20 11:50:12 +02:00
|
|
|
desc: "Empty",
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
2021-05-20 11:50:12 +02:00
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty because missing entry point",
|
|
|
|
paths: []string{"services.yml", "tcproute/simple.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{"TCP": {
|
|
|
|
Address: ":8000",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty because no tcp route defined",
|
|
|
|
paths: []string{"services.yml", "tcproute/without_tcproute.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{"TCP": {
|
|
|
|
Address: ":8080",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by missing GatewayClass",
|
|
|
|
entryPoints: map[string]Entrypoint{"TCP": {
|
|
|
|
Address: ":8080",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "tcproute/without_gatewayclass.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Empty caused by unknown GatewayClass controller desc",
|
2021-05-20 11:50:12 +02:00
|
|
|
entryPoints: map[string]Entrypoint{"TCP": {
|
|
|
|
Address: ":8080",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "tcproute/gatewayclass_with_unknown_controller.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Empty caused by HTTPRoute with TLS configuration",
|
|
|
|
entryPoints: map[string]Entrypoint{"web": {
|
|
|
|
Address: ":8080",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "tcproute/with_tls_configuration.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by multi ports service with wrong TargetPort",
|
2021-05-20 11:50:12 +02:00
|
|
|
entryPoints: map[string]Entrypoint{"TCP": {
|
|
|
|
Address: ":8080",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "tcproute/with_wrong_service_port.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Simple TCPRoute",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "tcproute/simple.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tcp": {Address: ":9000"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-1-my-tcp-gateway-tcp-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-1-my-tcp-gateway-tcp-e3b0c44298fc1c149afb-wrr-0",
|
2021-05-20 11:50:12 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-05-20 11:50:12 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-1-my-tcp-gateway-tcp-e3b0c44298fc1c149afb-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Multiple TCPRoute",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "tcproute/with_multiple_routes.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tcp-1": {Address: ":9000"},
|
|
|
|
"tcp-2": {Address: ":10000"},
|
|
|
|
"not-tcp": {Address: ":11000"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-1-my-tcp-gateway-tcp-1-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp-1"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-1-my-tcp-gateway-tcp-1-e3b0c44298fc1c149afb-wrr-0",
|
2021-05-20 11:50:12 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
"default-tcp-app-2-my-tcp-gateway-tcp-2-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp-2"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-2-my-tcp-gateway-tcp-2-e3b0c44298fc1c149afb-wrr-0",
|
2021-05-20 11:50:12 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-05-20 11:50:12 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-1-my-tcp-gateway-tcp-1-e3b0c44298fc1c149afb-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-2-my-tcp-gateway-tcp-2-e3b0c44298fc1c149afb-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-10000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-10000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:10000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:10000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "TCPRoute with multiple rules",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "tcproute/with_multiple_rules.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tcp-1": {Address: ":9000"},
|
|
|
|
"tcp-2": {Address: ":10000"},
|
|
|
|
"not-tcp": {Address: ":11000"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2021-11-09 11:34:06 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-my-tcp-gateway-tcp-1-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp-1"},
|
|
|
|
Service: "default-tcp-app-my-tcp-gateway-tcp-1-e3b0c44298fc1c149afb-wrr",
|
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-11-09 11:34:06 +01:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
|
|
|
"default-tcp-app-my-tcp-gateway-tcp-1-e3b0c44298fc1c149afb-wrr": {
|
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-tcp-app-my-tcp-gateway-tcp-1-e3b0c44298fc1c149afb-wrr-0",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "default-tcp-app-my-tcp-gateway-tcp-1-e3b0c44298fc1c149afb-wrr-1",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-tcp-app-my-tcp-gateway-tcp-1-e3b0c44298fc1c149afb-wrr-0": {
|
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-tcp-app-my-tcp-gateway-tcp-1-e3b0c44298fc1c149afb-wrr-1": {
|
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-10000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-10000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:10000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:10000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple TCPRoute, with backendRef",
|
|
|
|
paths: []string{"services.yml", "tcproute/simple_cross_provider.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tcp": {Address: ":9000"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-1-my-gateway-tcp-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-1-my-gateway-tcp-e3b0c44298fc1c149afb-wrr-0",
|
2021-05-20 11:50:12 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-05-20 11:50:12 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-1-my-gateway-tcp-e3b0c44298fc1c149afb-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "service@file",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple TCPRoute, with TLS",
|
|
|
|
paths: []string{"services.yml", "tcproute/with_protocol_tls.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9000"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-1-my-gateway-tls-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tls"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-1-my-gateway-tls-e3b0c44298fc1c149afb-wrr-0",
|
2021-05-20 11:50:12 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{},
|
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-05-20 11:50:12 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-1-my-gateway-tls-e3b0c44298fc1c149afb-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
}},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{
|
|
|
|
Certificates: []*tls.CertAndStores{
|
|
|
|
{
|
|
|
|
Certificate: tls.Certificate{
|
2024-01-11 21:36:06 +05:30
|
|
|
CertFile: types.FileOrContent("-----BEGIN CERTIFICATE-----\n-----END CERTIFICATE-----"),
|
|
|
|
KeyFile: types.FileOrContent("-----BEGIN PRIVATE KEY-----\n-----END PRIVATE KEY-----"),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-10-04 15:46:08 +02:00
|
|
|
desc: "TCPRoute with Same namespace selector",
|
|
|
|
paths: []string{"services.yml", "tcproute/with_namespace_same.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tcp": {Address: ":9000"},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2021-10-04 15:46:08 +02:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-default-my-tcp-gateway-tcp-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-default-my-tcp-gateway-tcp-e3b0c44298fc1c149afb-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-10-04 15:46:08 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-default-my-tcp-gateway-tcp-e3b0c44298fc1c149afb-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-10-04 15:46:08 +02:00
|
|
|
desc: "TCPRoute with All namespace selector",
|
|
|
|
paths: []string{"services.yml", "tcproute/with_namespace_all.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tcp": {Address: ":9000"},
|
|
|
|
},
|
2021-05-20 11:50:12 +02:00
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2021-10-04 15:46:08 +02:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-default-my-tcp-gateway-tcp-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-default-my-tcp-gateway-tcp-e3b0c44298fc1c149afb-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
"bar-tcp-app-bar-my-tcp-gateway-tcp-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "bar-tcp-app-bar-my-tcp-gateway-tcp-e3b0c44298fc1c149afb-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-default-my-tcp-gateway-tcp-e3b0c44298fc1c149afb-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"bar-tcp-app-bar-my-tcp-gateway-tcp-e3b0c44298fc1c149afb-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoamitcp-bar-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-whoamitcp-bar-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.13:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.14:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "TCPRoute with namespace selector",
|
2021-10-04 15:46:08 +02:00
|
|
|
paths: []string{"services.yml", "tcproute/with_namespace_selector.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tcp": {Address: ":9000"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"bar-tcp-app-bar-my-tcp-gateway-tcp-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "bar-tcp-app-bar-my-tcp-gateway-tcp-e3b0c44298fc1c149afb-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"bar-tcp-app-bar-my-tcp-gateway-tcp-e3b0c44298fc1c149afb-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoamitcp-bar-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-whoamitcp-bar-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.13:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.14:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
if test.expected == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-04-02 17:32:04 +02:00
|
|
|
p := Provider{EntryPoints: test.entryPoints, ExperimentalChannel: true}
|
2021-10-04 15:46:08 +02:00
|
|
|
conf := p.loadConfigurationFromGateway(context.Background(), newClientMock(test.paths...))
|
|
|
|
assert.Equal(t, test.expected, conf)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestLoadTLSRoutes(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
desc string
|
|
|
|
ingressClass string
|
|
|
|
paths []string
|
|
|
|
expected *dynamic.Configuration
|
|
|
|
entryPoints map[string]Entrypoint
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "Empty",
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty because no matching entry point",
|
|
|
|
paths: []string{"services.yml", "tlsroute/simple_TLS_to_TCPRoute.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{"TCP": {
|
|
|
|
Address: ":8000",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty because no tls route defined",
|
|
|
|
paths: []string{"services.yml", "tlsroute/without_tlsroute.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{"TCP": {
|
|
|
|
Address: ":8080",
|
|
|
|
}},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
2021-05-20 11:50:12 +02:00
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by missing GatewayClass",
|
|
|
|
entryPoints: map[string]Entrypoint{"TCP": {
|
|
|
|
Address: ":8080",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "tlsroute/without_gatewayclass.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Empty caused by unknown GatewayClass controller desc",
|
2021-05-20 11:50:12 +02:00
|
|
|
entryPoints: map[string]Entrypoint{"TCP": {
|
|
|
|
Address: ":8080",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "tlsroute/gatewayclass_with_unknown_controller.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Empty caused by multi ports service with wrong TargetPort",
|
2021-05-20 11:50:12 +02:00
|
|
|
entryPoints: map[string]Entrypoint{"TCP": {
|
|
|
|
Address: ":8080",
|
|
|
|
}},
|
|
|
|
paths: []string{"services.yml", "tlsroute/with_wrong_service_port.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Empty caused by mixed routes with wrong parent ref",
|
2021-05-20 11:50:12 +02:00
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tcp": {
|
|
|
|
Address: ":9000",
|
|
|
|
},
|
|
|
|
"tcp-tls": {
|
|
|
|
Address: ":9443",
|
|
|
|
},
|
|
|
|
"http": {
|
|
|
|
Address: ":80",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
paths: []string{"services.yml", "mixed/with_wrong_routes_selector.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Empty caused by simple TLSRoute with invalid SNI matching",
|
|
|
|
paths: []string{"services.yml", "tlsroute/with_invalid_SNI_matching.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9001"},
|
|
|
|
},
|
2021-05-20 11:50:12 +02:00
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Simple TLS listener to TCPRoute in Terminate mode",
|
|
|
|
paths: []string{"services.yml", "tlsroute/simple_TLS_to_TCPRoute.yml"},
|
2021-05-20 11:50:12 +02:00
|
|
|
entryPoints: map[string]Entrypoint{
|
2021-11-09 11:34:06 +01:00
|
|
|
"tcp": {Address: ":9000"},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2021-11-09 11:34:06 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-1-my-tls-gateway-tcp-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
|
|
|
Service: "default-tcp-app-1-my-tls-gateway-tcp-e3b0c44298fc1c149afb-wrr-0",
|
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-11-09 11:34:06 +01:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{},
|
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-11-09 11:34:06 +01:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
|
|
|
"default-tcp-app-1-my-tls-gateway-tcp-e3b0c44298fc1c149afb-wrr-0": {
|
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
TLS: &dynamic.TLSConfiguration{
|
|
|
|
Certificates: []*tls.CertAndStores{
|
|
|
|
{
|
|
|
|
Certificate: tls.Certificate{
|
2024-01-11 21:36:06 +05:30
|
|
|
CertFile: types.FileOrContent("-----BEGIN CERTIFICATE-----\n-----END CERTIFICATE-----"),
|
|
|
|
KeyFile: types.FileOrContent("-----BEGIN PRIVATE KEY-----\n-----END PRIVATE KEY-----"),
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Simple TLS listener to TCPRoute in Passthrough mode",
|
|
|
|
paths: []string{"services.yml", "tlsroute/simple_TLS_to_TCPRoute_passthrough.yml"},
|
2021-05-20 11:50:12 +02:00
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tcp": {Address: ":9000"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-1-my-tls-gateway-tcp-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-1-my-tls-gateway-tcp-e3b0c44298fc1c149afb-wrr-0",
|
2021-05-20 11:50:12 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-11-09 11:34:06 +01:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-05-20 11:50:12 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-1-my-tls-gateway-tcp-e3b0c44298fc1c149afb-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple TLS listener to TLSRoute",
|
|
|
|
paths: []string{"services.yml", "tlsroute/simple_TLS_to_TLSRoute.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tcp": {Address: ":9000"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-1-my-tls-gateway-tcp-f0dd0dd89f82eae1c270": {
|
2021-05-20 11:50:12 +02:00
|
|
|
EntryPoints: []string{"tcp"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tls-app-1-my-tls-gateway-tcp-f0dd0dd89f82eae1c270-wrr-0",
|
|
|
|
Rule: "HostSNI(`foo.example.com`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-05-20 11:50:12 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-1-my-tls-gateway-tcp-f0dd0dd89f82eae1c270-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Multiple TLSRoute",
|
2021-05-20 11:50:12 +02:00
|
|
|
paths: []string{"services.yml", "tlsroute/with_multiple_routes_kind.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9000"},
|
|
|
|
"tcp": {Address: ":10000"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-1-my-tls-gateway-tls-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tls"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-1-my-tls-gateway-tls-e3b0c44298fc1c149afb-wrr-0",
|
2021-05-20 11:50:12 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{},
|
|
|
|
},
|
|
|
|
"default-tls-app-1-my-tls-gateway-tcp-673acf455cb2dab0b43a": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tls-app-1-my-tls-gateway-tcp-673acf455cb2dab0b43a-wrr-0",
|
2021-05-20 11:50:12 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-05-20 11:50:12 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-1-my-tls-gateway-tls-e3b0c44298fc1c149afb-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-1-my-tls-gateway-tcp-673acf455cb2dab0b43a-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-10000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-10000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:10000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:10000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{
|
|
|
|
Certificates: []*tls.CertAndStores{
|
|
|
|
{
|
|
|
|
Certificate: tls.Certificate{
|
2024-01-11 21:36:06 +05:30
|
|
|
CertFile: types.FileOrContent("-----BEGIN CERTIFICATE-----\n-----END CERTIFICATE-----"),
|
|
|
|
KeyFile: types.FileOrContent("-----BEGIN PRIVATE KEY-----\n-----END PRIVATE KEY-----"),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple TLSRoute, with backendRef",
|
|
|
|
paths: []string{"services.yml", "tlsroute/simple_cross_provider.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9000"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-1-my-gateway-tls-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tls"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-1-my-gateway-tls-e3b0c44298fc1c149afb-wrr-0",
|
2021-05-20 11:50:12 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{},
|
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-05-20 11:50:12 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-1-my-gateway-tls-e3b0c44298fc1c149afb-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "service@file",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{
|
|
|
|
Certificates: []*tls.CertAndStores{
|
|
|
|
{
|
|
|
|
Certificate: tls.Certificate{
|
2024-01-11 21:36:06 +05:30
|
|
|
CertFile: types.FileOrContent("-----BEGIN CERTIFICATE-----\n-----END CERTIFICATE-----"),
|
|
|
|
KeyFile: types.FileOrContent("-----BEGIN PRIVATE KEY-----\n-----END PRIVATE KEY-----"),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple TLSRoute, with Passthrough and TLS configuration should raise a warn",
|
|
|
|
paths: []string{"services.yml", "tlsroute/with_passthrough_tls.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9001"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-1-my-gateway-tls-f0dd0dd89f82eae1c270": {
|
2021-05-20 11:50:12 +02:00
|
|
|
EntryPoints: []string{"tls"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tls-app-1-my-gateway-tls-f0dd0dd89f82eae1c270-wrr-0",
|
|
|
|
Rule: "HostSNI(`foo.example.com`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-05-20 11:50:12 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-1-my-gateway-tls-f0dd0dd89f82eae1c270-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple TLSRoute, with Passthrough",
|
|
|
|
paths: []string{"services.yml", "tlsroute/with_passthrough.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9001"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-1-my-gateway-tls-f0dd0dd89f82eae1c270": {
|
2021-05-20 11:50:12 +02:00
|
|
|
EntryPoints: []string{"tls"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tls-app-1-my-gateway-tls-f0dd0dd89f82eae1c270-wrr-0",
|
|
|
|
Rule: "HostSNI(`foo.example.com`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-05-20 11:50:12 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-1-my-gateway-tls-f0dd0dd89f82eae1c270-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple TLSRoute, with single SNI matching",
|
|
|
|
paths: []string{"services.yml", "tlsroute/with_SNI_matching.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9001"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-1-my-gateway-tls-f0dd0dd89f82eae1c270": {
|
2021-05-20 11:50:12 +02:00
|
|
|
EntryPoints: []string{"tls"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tls-app-1-my-gateway-tls-f0dd0dd89f82eae1c270-wrr-0",
|
|
|
|
Rule: "HostSNI(`foo.example.com`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-05-20 11:50:12 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-1-my-gateway-tls-f0dd0dd89f82eae1c270-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Simple TLSRoute, with multiple SNI matching",
|
|
|
|
paths: []string{"services.yml", "tlsroute/with_multiple_SNI_matching.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9001"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
2022-12-12 12:30:05 -03:00
|
|
|
"default-tls-app-1-my-gateway-tls-d5342d75658583f03593": {
|
2021-05-20 11:50:12 +02:00
|
|
|
EntryPoints: []string{"tls"},
|
2022-12-12 12:30:05 -03:00
|
|
|
Service: "default-tls-app-1-my-gateway-tls-d5342d75658583f03593-wrr-0",
|
|
|
|
Rule: "HostSNI(`foo.example.com`) || HostSNI(`bar.example.com`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-05-20 11:50:12 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2022-12-12 12:30:05 -03:00
|
|
|
"default-tls-app-1-my-gateway-tls-d5342d75658583f03593-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-10-04 15:46:08 +02:00
|
|
|
desc: "TLSRoute with Same namespace selector",
|
|
|
|
paths: []string{"services.yml", "tlsroute/with_namespace_same.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9001"},
|
|
|
|
},
|
2021-05-20 11:50:12 +02:00
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2021-10-04 15:46:08 +02:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tls-app-default-my-gateway-tls-06ae57dcf13ab4c60ee5": {
|
|
|
|
EntryPoints: []string{"tls"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tls-app-default-my-gateway-tls-06ae57dcf13ab4c60ee5-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`foo.default`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-10-04 15:46:08 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-default-my-gateway-tls-06ae57dcf13ab4c60ee5-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "TLSRoute with All namespace selector",
|
|
|
|
paths: []string{"services.yml", "tlsroute/with_namespace_all.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9001"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tls-app-default-my-gateway-tls-06ae57dcf13ab4c60ee5": {
|
|
|
|
EntryPoints: []string{"tls"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tls-app-default-my-gateway-tls-06ae57dcf13ab4c60ee5-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`foo.default`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-tls-app-bar-my-gateway-tls-2279fe75c5156dc5eb26": {
|
|
|
|
EntryPoints: []string{"tls"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "bar-tls-app-bar-my-gateway-tls-2279fe75c5156dc5eb26-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`foo.bar`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-default-my-gateway-tls-06ae57dcf13ab4c60ee5-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"bar-tls-app-bar-my-gateway-tls-2279fe75c5156dc5eb26-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoamitcp-bar-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-whoamitcp-bar-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.13:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.14:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "TLSRoute with namespace selector",
|
2021-10-04 15:46:08 +02:00
|
|
|
paths: []string{"services.yml", "tlsroute/with_namespace_selector.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9001"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"bar-tls-app-bar-my-gateway-tls-2279fe75c5156dc5eb26": {
|
|
|
|
EntryPoints: []string{"tls"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "bar-tls-app-bar-my-gateway-tls-2279fe75c5156dc5eb26-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`foo.bar`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"bar-tls-app-bar-my-gateway-tls-2279fe75c5156dc5eb26-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoamitcp-bar-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-whoamitcp-bar-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.13:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.14:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
2021-05-20 11:50:12 +02:00
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "TLSRoute with multiple rules",
|
|
|
|
paths: []string{"services.yml", "tlsroute/with_multiple_rules.yml"},
|
2021-05-20 11:50:12 +02:00
|
|
|
entryPoints: map[string]Entrypoint{
|
2021-11-09 11:34:06 +01:00
|
|
|
"tcp-1": {Address: ":9000"},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2021-11-09 11:34:06 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tls-app-my-gateway-tcp-1-673acf455cb2dab0b43a": {
|
|
|
|
EntryPoints: []string{"tcp-1"},
|
|
|
|
Service: "default-tls-app-my-gateway-tcp-1-673acf455cb2dab0b43a-wrr",
|
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-11-09 11:34:06 +01:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-11-09 11:34:06 +01:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
|
|
|
"default-tls-app-my-gateway-tcp-1-673acf455cb2dab0b43a-wrr": {
|
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-tls-app-my-gateway-tcp-1-673acf455cb2dab0b43a-wrr-0",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "default-tls-app-my-gateway-tcp-1-673acf455cb2dab0b43a-wrr-1",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-tls-app-my-gateway-tcp-1-673acf455cb2dab0b43a-wrr-0": {
|
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-tls-app-my-gateway-tcp-1-673acf455cb2dab0b43a-wrr-1": {
|
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-10000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-10000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:10000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:10000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
if test.expected == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-04-02 17:32:04 +02:00
|
|
|
p := Provider{EntryPoints: test.entryPoints, ExperimentalChannel: true}
|
2021-11-09 11:34:06 +01:00
|
|
|
conf := p.loadConfigurationFromGateway(context.Background(), newClientMock(test.paths...))
|
|
|
|
assert.Equal(t, test.expected, conf)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestLoadMixedRoutes(t *testing.T) {
|
|
|
|
testCases := []struct {
|
2024-04-02 17:32:04 +02:00
|
|
|
desc string
|
|
|
|
ingressClass string
|
|
|
|
paths []string
|
|
|
|
expected *dynamic.Configuration
|
|
|
|
entryPoints map[string]Entrypoint
|
|
|
|
experimentalChannel bool
|
2021-11-09 11:34:06 +01:00
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "Empty",
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by unsupported listener.Protocol",
|
|
|
|
paths: []string{"services.yml", "mixed/with_bad_listener_protocol.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"web": {Address: ":9080"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by unsupported listener.Route.Kind",
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"web": {Address: ":9080"},
|
|
|
|
},
|
|
|
|
paths: []string{"services.yml", "mixed/with_bad_listener_route_kind.yml"},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty caused by listener.Protocol does not support listener.Route.Kind",
|
|
|
|
paths: []string{"services.yml", "mixed/with_incompatible_protocol_and_route_kind.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"web": {Address: ":9080"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Mixed routes",
|
|
|
|
paths: []string{"services.yml", "mixed/simple.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"web": {Address: ":9080"},
|
|
|
|
"websecure": {Address: ":9443"},
|
|
|
|
"tcp": {Address: ":9000"},
|
|
|
|
"tls-1": {Address: ":10000"},
|
|
|
|
"tls-2": {Address: ":11000"},
|
|
|
|
},
|
2024-04-02 17:32:04 +02:00
|
|
|
experimentalChannel: true,
|
2021-05-20 11:50:12 +02:00
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-1-my-gateway-tcp-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-1-my-gateway-tcp-e3b0c44298fc1c149afb-wrr-0",
|
2021-05-20 11:50:12 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
"default-tcp-app-1-my-gateway-tls-1-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tls-1"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-1-my-gateway-tls-1-e3b0c44298fc1c149afb-wrr-0",
|
2021-05-20 11:50:12 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-1-my-gateway-tls-2-59130f7db6718b7700c1": {
|
2021-05-20 11:50:12 +02:00
|
|
|
EntryPoints: []string{"tls-2"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tls-app-1-my-gateway-tls-2-59130f7db6718b7700c1-wrr-0",
|
|
|
|
Rule: "HostSNI(`pass.tls.foo.example.com`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-06-11 15:30:05 +02:00
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
2021-05-20 11:50:12 +02:00
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-1-my-gateway-tcp-e3b0c44298fc1c149afb-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-1-my-gateway-tls-1-e3b0c44298fc1c149afb-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-1-my-gateway-tls-2-59130f7db6718b7700c1-wrr-0": {
|
2021-05-20 11:50:12 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-1-my-gateway-web-a431b128267aabc954fd": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-1-my-gateway-web-a431b128267aabc954fd-wrr",
|
|
|
|
Rule: "PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
"default-http-app-1-my-gateway-websecure-a431b128267aabc954fd": {
|
|
|
|
EntryPoints: []string{"websecure"},
|
|
|
|
Service: "default-http-app-1-my-gateway-websecure-a431b128267aabc954fd-wrr",
|
|
|
|
Rule: "PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-05-20 11:50:12 +02:00
|
|
|
TLS: &dynamic.RouterTLSConfig{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-1-my-gateway-web-a431b128267aabc954fd-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-http-app-1-my-gateway-websecure-a431b128267aabc954fd-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-07-15 17:32:11 +05:30
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{
|
|
|
|
Certificates: []*tls.CertAndStores{
|
|
|
|
{
|
|
|
|
Certificate: tls.Certificate{
|
2024-01-11 21:36:06 +05:30
|
|
|
CertFile: types.FileOrContent("-----BEGIN CERTIFICATE-----\n-----END CERTIFICATE-----"),
|
|
|
|
KeyFile: types.FileOrContent("-----BEGIN PRIVATE KEY-----\n-----END PRIVATE KEY-----"),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2022-06-23 11:58:09 +02:00
|
|
|
desc: "Empty caused by mixed routes with multiple listeners using same hostname, port and protocol",
|
|
|
|
paths: []string{"services.yml", "mixed/with_multiple_listeners_using_same_hostname_port_protocol.yml"},
|
2021-05-20 11:50:12 +02:00
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"web": {Address: ":9080"},
|
|
|
|
"tcp": {Address: ":9000"},
|
|
|
|
"tls": {Address: ":9001"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
2022-12-09 09:58:05 +01:00
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
2021-07-15 17:32:11 +05:30
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
2021-10-04 15:46:08 +02:00
|
|
|
{
|
|
|
|
desc: "Mixed routes with Same namespace selector",
|
|
|
|
paths: []string{"services.yml", "mixed/with_namespace_same.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"web": {Address: ":9080"},
|
|
|
|
"websecure": {Address: ":9443"},
|
|
|
|
"tcp": {Address: ":9000"},
|
|
|
|
"tls-1": {Address: ":10000"},
|
|
|
|
"tls-2": {Address: ":11000"},
|
|
|
|
},
|
2024-04-02 17:32:04 +02:00
|
|
|
experimentalChannel: true,
|
2021-10-04 15:46:08 +02:00
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-default-my-gateway-tcp-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-default-my-gateway-tcp-e3b0c44298fc1c149afb-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
"default-tcp-app-default-my-gateway-tls-1-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tls-1"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-default-my-gateway-tls-1-e3b0c44298fc1c149afb-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-default-my-gateway-tls-2-59130f7db6718b7700c1": {
|
2021-10-04 15:46:08 +02:00
|
|
|
EntryPoints: []string{"tls-2"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tls-app-default-my-gateway-tls-2-59130f7db6718b7700c1-wrr-0",
|
|
|
|
Rule: "HostSNI(`pass.tls.foo.example.com`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-default-my-gateway-tcp-e3b0c44298fc1c149afb-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-default-my-gateway-tls-1-e3b0c44298fc1c149afb-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-default-my-gateway-tls-2-59130f7db6718b7700c1-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-default-my-gateway-web-a431b128267aabc954fd": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-default-my-gateway-web-a431b128267aabc954fd-wrr",
|
|
|
|
Rule: "PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
"default-http-app-default-my-gateway-websecure-a431b128267aabc954fd": {
|
|
|
|
EntryPoints: []string{"websecure"},
|
|
|
|
Service: "default-http-app-default-my-gateway-websecure-a431b128267aabc954fd-wrr",
|
|
|
|
Rule: "PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTLSConfig{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-default-my-gateway-web-a431b128267aabc954fd-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-http-app-default-my-gateway-websecure-a431b128267aabc954fd-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{
|
|
|
|
Certificates: []*tls.CertAndStores{
|
|
|
|
{
|
|
|
|
Certificate: tls.Certificate{
|
2024-01-11 21:36:06 +05:30
|
|
|
CertFile: types.FileOrContent("-----BEGIN CERTIFICATE-----\n-----END CERTIFICATE-----"),
|
|
|
|
KeyFile: types.FileOrContent("-----BEGIN PRIVATE KEY-----\n-----END PRIVATE KEY-----"),
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Mixed routes with All namespace selector",
|
|
|
|
paths: []string{"services.yml", "mixed/with_namespace_all.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"web": {Address: ":9080"},
|
|
|
|
"websecure": {Address: ":9443"},
|
|
|
|
"tcp": {Address: ":9000"},
|
|
|
|
"tls-1": {Address: ":10000"},
|
|
|
|
"tls-2": {Address: ":11000"},
|
|
|
|
},
|
2024-04-02 17:32:04 +02:00
|
|
|
experimentalChannel: true,
|
2021-10-04 15:46:08 +02:00
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-default-my-gateway-tcp-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-default-my-gateway-tcp-e3b0c44298fc1c149afb-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
"default-tcp-app-default-my-gateway-tls-1-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tls-1"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tcp-app-default-my-gateway-tls-1-e3b0c44298fc1c149afb-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-default-my-gateway-tls-2-59130f7db6718b7700c1": {
|
2021-10-04 15:46:08 +02:00
|
|
|
EntryPoints: []string{"tls-2"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "default-tls-app-default-my-gateway-tls-2-59130f7db6718b7700c1-wrr-0",
|
|
|
|
Rule: "HostSNI(`pass.tls.foo.example.com`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-tcp-app-bar-my-gateway-tcp-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "bar-tcp-app-bar-my-gateway-tcp-e3b0c44298fc1c149afb-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
"bar-tcp-app-bar-my-gateway-tls-1-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tls-1"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "bar-tcp-app-bar-my-gateway-tls-1-e3b0c44298fc1c149afb-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-default-my-gateway-tcp-e3b0c44298fc1c149afb-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tcp-app-default-my-gateway-tls-1-e3b0c44298fc1c149afb-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"default-tls-app-default-my-gateway-tls-2-59130f7db6718b7700c1-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-whoamitcp-bar-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.13:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.14:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"bar-tcp-app-bar-my-gateway-tcp-e3b0c44298fc1c149afb-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoamitcp-bar-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"bar-tcp-app-bar-my-gateway-tls-1-e3b0c44298fc1c149afb-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoamitcp-bar-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-default-my-gateway-web-a431b128267aabc954fd": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-default-my-gateway-web-a431b128267aabc954fd-wrr",
|
|
|
|
Rule: "PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
"default-http-app-default-my-gateway-websecure-a431b128267aabc954fd": {
|
|
|
|
EntryPoints: []string{"websecure"},
|
|
|
|
Service: "default-http-app-default-my-gateway-websecure-a431b128267aabc954fd-wrr",
|
|
|
|
Rule: "PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTLSConfig{},
|
|
|
|
},
|
|
|
|
"bar-http-app-bar-my-gateway-web-a431b128267aabc954fd": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "bar-http-app-bar-my-gateway-web-a431b128267aabc954fd-wrr",
|
|
|
|
Rule: "PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
"bar-http-app-bar-my-gateway-websecure-a431b128267aabc954fd": {
|
|
|
|
EntryPoints: []string{"websecure"},
|
|
|
|
Service: "bar-http-app-bar-my-gateway-websecure-a431b128267aabc954fd-wrr",
|
|
|
|
Rule: "PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTLSConfig{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-default-my-gateway-web-a431b128267aabc954fd-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-http-app-default-my-gateway-websecure-a431b128267aabc954fd-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-whoami-bar-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.11:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.12:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-http-app-bar-my-gateway-web-a431b128267aabc954fd-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoami-bar-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-http-app-bar-my-gateway-websecure-a431b128267aabc954fd-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoami-bar-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{
|
|
|
|
Certificates: []*tls.CertAndStores{
|
|
|
|
{
|
|
|
|
Certificate: tls.Certificate{
|
2024-01-11 21:36:06 +05:30
|
|
|
CertFile: types.FileOrContent("-----BEGIN CERTIFICATE-----\n-----END CERTIFICATE-----"),
|
|
|
|
KeyFile: types.FileOrContent("-----BEGIN PRIVATE KEY-----\n-----END PRIVATE KEY-----"),
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Mixed routes with Selector Route Binding",
|
|
|
|
paths: []string{"services.yml", "mixed/with_namespace_selector.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"web": {Address: ":9080"},
|
|
|
|
"websecure": {Address: ":9443"},
|
|
|
|
"tcp": {Address: ":9000"},
|
|
|
|
"tls-1": {Address: ":10000"},
|
|
|
|
"tls-2": {Address: ":11000"},
|
|
|
|
},
|
2024-04-02 17:32:04 +02:00
|
|
|
experimentalChannel: true,
|
2021-10-04 15:46:08 +02:00
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"bar-tcp-app-bar-my-gateway-tcp-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "bar-tcp-app-bar-my-gateway-tcp-e3b0c44298fc1c149afb-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
"bar-tcp-app-bar-my-gateway-tls-1-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tls-1"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "bar-tcp-app-bar-my-gateway-tls-1-e3b0c44298fc1c149afb-wrr-0",
|
2021-10-04 15:46:08 +02:00
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"bar-tls-app-bar-my-gateway-tls-2-59130f7db6718b7700c1": {
|
2021-10-04 15:46:08 +02:00
|
|
|
EntryPoints: []string{"tls-2"},
|
2021-11-09 11:34:06 +01:00
|
|
|
Service: "bar-tls-app-bar-my-gateway-tls-2-59130f7db6718b7700c1-wrr-0",
|
|
|
|
Rule: "HostSNI(`pass.tls.foo.example.com`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{
|
|
|
|
Passthrough: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{
|
|
|
|
"bar-whoamitcp-bar-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.13:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.14:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"bar-tcp-app-bar-my-gateway-tcp-e3b0c44298fc1c149afb-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoamitcp-bar-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"bar-tcp-app-bar-my-gateway-tls-1-e3b0c44298fc1c149afb-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoamitcp-bar-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
"bar-tls-app-bar-my-gateway-tls-2-59130f7db6718b7700c1-wrr-0": {
|
2021-10-04 15:46:08 +02:00
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoamitcp-bar-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"bar-http-app-bar-my-gateway-web-a431b128267aabc954fd": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "bar-http-app-bar-my-gateway-web-a431b128267aabc954fd-wrr",
|
|
|
|
Rule: "PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
"bar-http-app-bar-my-gateway-websecure-a431b128267aabc954fd": {
|
|
|
|
EntryPoints: []string{"websecure"},
|
|
|
|
Service: "bar-http-app-bar-my-gateway-websecure-a431b128267aabc954fd-wrr",
|
|
|
|
Rule: "PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-10-04 15:46:08 +02:00
|
|
|
TLS: &dynamic.RouterTLSConfig{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"bar-whoami-bar-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.11:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.12:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-http-app-bar-my-gateway-web-a431b128267aabc954fd-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoami-bar-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"bar-http-app-bar-my-gateway-websecure-a431b128267aabc954fd-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "bar-whoami-bar-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{
|
|
|
|
Certificates: []*tls.CertAndStores{
|
|
|
|
{
|
|
|
|
Certificate: tls.Certificate{
|
2024-01-11 21:36:06 +05:30
|
|
|
CertFile: types.FileOrContent("-----BEGIN CERTIFICATE-----\n-----END CERTIFICATE-----"),
|
|
|
|
KeyFile: types.FileOrContent("-----BEGIN PRIVATE KEY-----\n-----END PRIVATE KEY-----"),
|
2021-10-04 15:46:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
{
|
|
|
|
desc: "Mixed routes with core group",
|
|
|
|
paths: []string{"services.yml", "mixed/with_core_group.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"web": {Address: ":9080"},
|
|
|
|
"websecure": {Address: ":9443"},
|
|
|
|
"tcp": {Address: ":9000"},
|
|
|
|
"tls": {Address: ":10000"},
|
|
|
|
},
|
2024-04-02 17:32:04 +02:00
|
|
|
experimentalChannel: true,
|
2021-11-09 11:34:06 +01:00
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-default-my-gateway-tcp-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tcp"},
|
|
|
|
Service: "default-tcp-app-default-my-gateway-tcp-e3b0c44298fc1c149afb-wrr-0",
|
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
"default-tcp-app-default-my-gateway-tls-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tls"},
|
|
|
|
Service: "default-tcp-app-default-my-gateway-tls-e3b0c44298fc1c149afb-wrr-0",
|
|
|
|
Rule: "HostSNI(`*`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-11-09 11:34:06 +01:00
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{
|
|
|
|
"default-tcp-app-default-my-gateway-tcp-e3b0c44298fc1c149afb-wrr-0": {
|
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-tcp-app-default-my-gateway-tls-e3b0c44298fc1c149afb-wrr-0": {
|
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-09 09:58:05 +01:00
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{
|
|
|
|
"default-http-app-default-my-gateway-web-a431b128267aabc954fd": {
|
|
|
|
EntryPoints: []string{"web"},
|
|
|
|
Service: "default-http-app-default-my-gateway-web-a431b128267aabc954fd-wrr",
|
|
|
|
Rule: "PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
"default-http-app-default-my-gateway-websecure-a431b128267aabc954fd": {
|
|
|
|
EntryPoints: []string{"websecure"},
|
|
|
|
Service: "default-http-app-default-my-gateway-websecure-a431b128267aabc954fd-wrr",
|
|
|
|
Rule: "PathPrefix(`/`)",
|
2024-01-23 11:34:05 +01:00
|
|
|
RuleSyntax: "v3",
|
2021-11-09 11:34:06 +01:00
|
|
|
TLS: &dynamic.RouterTLSConfig{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{
|
|
|
|
"default-http-app-default-my-gateway-web-a431b128267aabc954fd-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-http-app-default-my-gateway-websecure-a431b128267aabc954fd-wrr": {
|
|
|
|
Weighted: &dynamic.WeightedRoundRobin{
|
|
|
|
Services: []dynamic.WRRService{
|
|
|
|
{
|
|
|
|
Name: "default-whoami-80",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoami-80": {
|
|
|
|
LoadBalancer: &dynamic.ServersLoadBalancer{
|
|
|
|
Servers: []dynamic.Server{
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.1:80",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
URL: "http://10.10.0.2:80",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
PassHostHeader: ptr.To(true),
|
2022-11-16 11:38:07 +01:00
|
|
|
ResponseForwarding: &dynamic.ResponseForwarding{
|
|
|
|
FlushInterval: ptypes.Duration(100 * time.Millisecond),
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{
|
|
|
|
Certificates: []*tls.CertAndStores{
|
|
|
|
{
|
|
|
|
Certificate: tls.Certificate{
|
2024-01-11 21:36:06 +05:30
|
|
|
CertFile: types.FileOrContent("-----BEGIN CERTIFICATE-----\n-----END CERTIFICATE-----"),
|
|
|
|
KeyFile: types.FileOrContent("-----BEGIN PRIVATE KEY-----\n-----END PRIVATE KEY-----"),
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-05-20 11:50:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
if test.expected == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-04-02 17:32:04 +02:00
|
|
|
p := Provider{EntryPoints: test.entryPoints, ExperimentalChannel: test.experimentalChannel}
|
2021-05-20 11:50:12 +02:00
|
|
|
conf := p.loadConfigurationFromGateway(context.Background(), newClientMock(test.paths...))
|
|
|
|
assert.Equal(t, test.expected, conf)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-30 16:44:05 +01:00
|
|
|
func TestLoadRoutesWithReferenceGrants(t *testing.T) {
|
|
|
|
testCases := []struct {
|
2024-04-02 17:32:04 +02:00
|
|
|
desc string
|
|
|
|
ingressClass string
|
|
|
|
paths []string
|
|
|
|
expected *dynamic.Configuration
|
|
|
|
entryPoints map[string]Entrypoint
|
|
|
|
experimentalChannel bool
|
2024-01-30 16:44:05 +01:00
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "Empty",
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty because ReferenceGrant for Secret is missing",
|
|
|
|
paths: []string{"services.yml", "referencegrant/for_secret_missing.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9000"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty because ReferenceGrant spec.from does not match",
|
|
|
|
paths: []string{"services.yml", "referencegrant/for_secret_not_matching_from.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9000"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty because ReferenceGrant spec.to does not match",
|
|
|
|
paths: []string{"services.yml", "referencegrant/for_secret_not_matching_to.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9000"},
|
|
|
|
},
|
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "For Secret",
|
|
|
|
paths: []string{"services.yml", "referencegrant/for_secret.yml"},
|
|
|
|
entryPoints: map[string]Entrypoint{
|
|
|
|
"tls": {Address: ":9000"},
|
|
|
|
},
|
2024-04-02 17:32:04 +02:00
|
|
|
experimentalChannel: true,
|
2024-01-30 16:44:05 +01:00
|
|
|
expected: &dynamic.Configuration{
|
|
|
|
UDP: &dynamic.UDPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.UDPRouter{},
|
|
|
|
Services: map[string]*dynamic.UDPService{},
|
|
|
|
},
|
|
|
|
TCP: &dynamic.TCPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.TCPRouter{
|
|
|
|
"default-tcp-app-1-my-gateway-tls-e3b0c44298fc1c149afb": {
|
|
|
|
EntryPoints: []string{"tls"},
|
|
|
|
Service: "default-tcp-app-1-my-gateway-tls-e3b0c44298fc1c149afb-wrr-0",
|
|
|
|
Rule: "HostSNI(`*`)",
|
|
|
|
RuleSyntax: "v3",
|
|
|
|
TLS: &dynamic.RouterTCPTLSConfig{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Middlewares: map[string]*dynamic.TCPMiddleware{},
|
|
|
|
Services: map[string]*dynamic.TCPService{
|
|
|
|
"default-tcp-app-1-my-gateway-tls-e3b0c44298fc1c149afb-wrr-0": {
|
|
|
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
|
|
|
Services: []dynamic.TCPWRRService{{
|
|
|
|
Name: "default-whoamitcp-9000",
|
|
|
|
Weight: func(i int) *int { return &i }(1),
|
|
|
|
}},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"default-whoamitcp-9000": {
|
|
|
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{
|
|
|
|
Servers: []dynamic.TCPServer{
|
|
|
|
{
|
|
|
|
Address: "10.10.0.9:9000",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Address: "10.10.0.10:9000",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServersTransports: map[string]*dynamic.TCPServersTransport{},
|
|
|
|
},
|
|
|
|
HTTP: &dynamic.HTTPConfiguration{
|
|
|
|
Routers: map[string]*dynamic.Router{},
|
|
|
|
Middlewares: map[string]*dynamic.Middleware{},
|
|
|
|
Services: map[string]*dynamic.Service{},
|
|
|
|
ServersTransports: map[string]*dynamic.ServersTransport{},
|
|
|
|
},
|
|
|
|
TLS: &dynamic.TLSConfiguration{
|
|
|
|
Certificates: []*tls.CertAndStores{
|
|
|
|
{
|
|
|
|
Certificate: tls.Certificate{
|
|
|
|
CertFile: types.FileOrContent("-----BEGIN CERTIFICATE-----\n-----END CERTIFICATE-----"),
|
|
|
|
KeyFile: types.FileOrContent("-----BEGIN PRIVATE KEY-----\n-----END PRIVATE KEY-----"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
if test.expected == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-04-02 17:32:04 +02:00
|
|
|
p := Provider{EntryPoints: test.entryPoints, ExperimentalChannel: test.experimentalChannel}
|
2024-01-30 16:44:05 +01:00
|
|
|
conf := p.loadConfigurationFromGateway(context.Background(), newClientMock(test.paths...))
|
|
|
|
assert.Equal(t, test.expected, conf)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-11-09 11:34:06 +01:00
|
|
|
func Test_hostRule(t *testing.T) {
|
2021-05-20 11:50:12 +02:00
|
|
|
testCases := []struct {
|
|
|
|
desc string
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames []gatev1.Hostname
|
2021-05-20 11:50:12 +02:00
|
|
|
expectedRule string
|
|
|
|
expectErr bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "Empty rule and matches",
|
|
|
|
expectedRule: "",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "One Host",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{
|
2021-11-09 11:34:06 +01:00
|
|
|
"Foo",
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
expectedRule: "Host(`Foo`)",
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
{
|
|
|
|
desc: "Multiple Hosts",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{
|
2021-11-09 11:34:06 +01:00
|
|
|
"Foo",
|
|
|
|
"Bar",
|
|
|
|
"Bir",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
2022-11-28 15:48:05 +01:00
|
|
|
expectedRule: "(Host(`Foo`) || Host(`Bar`) || Host(`Bir`))",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Multiple Hosts with empty one",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{
|
2021-11-09 11:34:06 +01:00
|
|
|
"Foo",
|
|
|
|
"",
|
|
|
|
"Bir",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
2021-04-29 10:18:04 -05:00
|
|
|
expectedRule: "",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Multiple empty hosts",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{
|
2021-11-09 11:34:06 +01:00
|
|
|
"",
|
|
|
|
"",
|
|
|
|
"",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
expectedRule: "",
|
|
|
|
},
|
2021-04-29 10:18:04 -05:00
|
|
|
{
|
|
|
|
desc: "Several Host and wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{
|
2021-11-09 11:34:06 +01:00
|
|
|
"*.bar.foo",
|
|
|
|
"bar.foo",
|
|
|
|
"foo.foo",
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
2022-11-28 15:48:05 +01:00
|
|
|
expectedRule: "(HostRegexp(`^[a-zA-Z0-9-]+\\.bar\\.foo$`) || Host(`bar.foo`) || Host(`foo.foo`))",
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Host with wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{
|
2021-11-09 11:34:06 +01:00
|
|
|
"*.bar.foo",
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
2022-11-28 15:48:05 +01:00
|
|
|
expectedRule: "HostRegexp(`^[a-zA-Z0-9-]+\\.bar\\.foo$`)",
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Alone wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{
|
2021-11-09 11:34:06 +01:00
|
|
|
"*",
|
|
|
|
"*.foo.foo",
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Multiple alone Wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{
|
2021-11-09 11:34:06 +01:00
|
|
|
"foo.foo",
|
|
|
|
"*.*",
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
|
|
|
expectErr: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Multiple Wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{
|
2021-11-09 11:34:06 +01:00
|
|
|
"foo.foo",
|
|
|
|
"*.toto.*.bar.foo",
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
|
|
|
expectErr: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Multiple subdomain with misplaced wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{
|
2021-11-09 11:34:06 +01:00
|
|
|
"foo.foo",
|
|
|
|
"toto.*.bar.foo",
|
2021-04-29 10:18:04 -05:00
|
|
|
},
|
|
|
|
expectErr: true,
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
2021-11-09 11:34:06 +01:00
|
|
|
rule, err := hostRule(test.hostnames)
|
2020-12-15 16:40:05 +01:00
|
|
|
|
2021-04-29 10:18:04 -05:00
|
|
|
assert.Equal(t, test.expectedRule, rule)
|
|
|
|
if test.expectErr {
|
|
|
|
assert.Error(t, err)
|
|
|
|
}
|
2020-12-15 16:40:05 +01:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-11-09 11:34:06 +01:00
|
|
|
func Test_extractRule(t *testing.T) {
|
2020-12-15 16:40:05 +01:00
|
|
|
testCases := []struct {
|
|
|
|
desc string
|
2024-01-09 10:28:05 +01:00
|
|
|
routeRule gatev1.HTTPRouteRule
|
2020-12-15 16:40:05 +01:00
|
|
|
hostRule string
|
|
|
|
expectedRule string
|
|
|
|
expectedError bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "Empty rule and matches",
|
|
|
|
expectedRule: "PathPrefix(`/`)",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "One Host rule without matches",
|
|
|
|
hostRule: "Host(`foo.com`)",
|
|
|
|
expectedRule: "Host(`foo.com`) && PathPrefix(`/`)",
|
|
|
|
},
|
2021-07-15 17:20:08 +02:00
|
|
|
{
|
|
|
|
desc: "One HTTPRouteMatch with nil HTTPHeaderMatch",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeRule: gatev1.HTTPRouteRule{
|
|
|
|
Matches: []gatev1.HTTPRouteMatch{
|
2021-07-15 17:20:08 +02:00
|
|
|
{Headers: nil},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedRule: "",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "One HTTPRouteMatch with nil HTTPHeaderMatch Type",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeRule: gatev1.HTTPRouteRule{
|
|
|
|
Matches: []gatev1.HTTPRouteMatch{
|
2021-07-15 17:20:08 +02:00
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Headers: []gatev1.HTTPHeaderMatch{
|
2021-11-09 11:34:06 +01:00
|
|
|
{Type: nil, Name: "foo", Value: "bar"},
|
2021-07-15 17:20:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedRule: "",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "One HTTPRouteMatch with nil HTTPPathMatch",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeRule: gatev1.HTTPRouteRule{
|
|
|
|
Matches: []gatev1.HTTPRouteMatch{
|
2021-07-15 17:20:08 +02:00
|
|
|
{Path: nil},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedRule: "",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "One HTTPRouteMatch with nil HTTPPathMatch Type",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeRule: gatev1.HTTPRouteRule{
|
|
|
|
Matches: []gatev1.HTTPRouteMatch{
|
2021-07-15 17:20:08 +02:00
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Path: &gatev1.HTTPPathMatch{
|
2021-07-15 17:20:08 +02:00
|
|
|
Type: nil,
|
2024-01-09 10:28:05 +01:00
|
|
|
Value: ptr.To("/foo/"),
|
2021-07-15 17:20:08 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedRule: "",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "One HTTPRouteMatch with nil HTTPPathMatch Values",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeRule: gatev1.HTTPRouteRule{
|
|
|
|
Matches: []gatev1.HTTPRouteMatch{
|
2021-07-15 17:20:08 +02:00
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Path: &gatev1.HTTPPathMatch{
|
|
|
|
Type: pathMatchTypePtr(gatev1.PathMatchExact),
|
2021-07-15 17:20:08 +02:00
|
|
|
Value: nil,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedRule: "",
|
|
|
|
},
|
2020-12-15 16:40:05 +01:00
|
|
|
{
|
|
|
|
desc: "One Path in matches",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeRule: gatev1.HTTPRouteRule{
|
|
|
|
Matches: []gatev1.HTTPRouteMatch{
|
2020-12-15 16:40:05 +01:00
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Path: &gatev1.HTTPPathMatch{
|
|
|
|
Type: pathMatchTypePtr(gatev1.PathMatchExact),
|
|
|
|
Value: ptr.To("/foo/"),
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedRule: "Path(`/foo/`)",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "One Path in matches and another unknown",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeRule: gatev1.HTTPRouteRule{
|
|
|
|
Matches: []gatev1.HTTPRouteMatch{
|
2020-12-15 16:40:05 +01:00
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Path: &gatev1.HTTPPathMatch{
|
|
|
|
Type: pathMatchTypePtr(gatev1.PathMatchExact),
|
|
|
|
Value: ptr.To("/foo/"),
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Path: &gatev1.HTTPPathMatch{
|
2021-11-09 11:34:06 +01:00
|
|
|
Type: pathMatchTypePtr("unknown"),
|
2024-01-09 10:28:05 +01:00
|
|
|
Value: ptr.To("/foo/"),
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedError: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "One Path in matches and another empty",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeRule: gatev1.HTTPRouteRule{
|
|
|
|
Matches: []gatev1.HTTPRouteMatch{
|
2020-12-15 16:40:05 +01:00
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Path: &gatev1.HTTPPathMatch{
|
|
|
|
Type: pathMatchTypePtr(gatev1.PathMatchExact),
|
|
|
|
Value: ptr.To("/foo/"),
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedRule: "Path(`/foo/`)",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Path OR Header rules",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeRule: gatev1.HTTPRouteRule{
|
|
|
|
Matches: []gatev1.HTTPRouteMatch{
|
2020-12-15 16:40:05 +01:00
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Path: &gatev1.HTTPPathMatch{
|
|
|
|
Type: pathMatchTypePtr(gatev1.PathMatchExact),
|
|
|
|
Value: ptr.To("/foo/"),
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Headers: []gatev1.HTTPHeaderMatch{
|
2021-11-09 11:34:06 +01:00
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Type: headerMatchTypePtr(gatev1.HeaderMatchExact),
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "my-header",
|
|
|
|
Value: "foo",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2024-01-23 11:34:05 +01:00
|
|
|
expectedRule: "Path(`/foo/`) || Header(`my-header`,`foo`)",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Path && Header rules",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeRule: gatev1.HTTPRouteRule{
|
|
|
|
Matches: []gatev1.HTTPRouteMatch{
|
2020-12-15 16:40:05 +01:00
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Path: &gatev1.HTTPPathMatch{
|
|
|
|
Type: pathMatchTypePtr(gatev1.PathMatchExact),
|
|
|
|
Value: ptr.To("/foo/"),
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
Headers: []gatev1.HTTPHeaderMatch{
|
2021-11-09 11:34:06 +01:00
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Type: headerMatchTypePtr(gatev1.HeaderMatchExact),
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "my-header",
|
|
|
|
Value: "foo",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2024-01-23 11:34:05 +01:00
|
|
|
expectedRule: "Path(`/foo/`) && Header(`my-header`,`foo`)",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Host && Path && Header rules",
|
|
|
|
hostRule: "Host(`foo.com`)",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeRule: gatev1.HTTPRouteRule{
|
|
|
|
Matches: []gatev1.HTTPRouteMatch{
|
2020-12-15 16:40:05 +01:00
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Path: &gatev1.HTTPPathMatch{
|
|
|
|
Type: pathMatchTypePtr(gatev1.PathMatchExact),
|
|
|
|
Value: ptr.To("/foo/"),
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
Headers: []gatev1.HTTPHeaderMatch{
|
2021-11-09 11:34:06 +01:00
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Type: headerMatchTypePtr(gatev1.HeaderMatchExact),
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "my-header",
|
|
|
|
Value: "foo",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2024-01-23 11:34:05 +01:00
|
|
|
expectedRule: "Host(`foo.com`) && Path(`/foo/`) && Header(`my-header`,`foo`)",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Host && (Path || Header) rules",
|
|
|
|
hostRule: "Host(`foo.com`)",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeRule: gatev1.HTTPRouteRule{
|
|
|
|
Matches: []gatev1.HTTPRouteMatch{
|
2020-12-15 16:40:05 +01:00
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Path: &gatev1.HTTPPathMatch{
|
|
|
|
Type: pathMatchTypePtr(gatev1.PathMatchExact),
|
|
|
|
Value: ptr.To("/foo/"),
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Headers: []gatev1.HTTPHeaderMatch{
|
2021-11-09 11:34:06 +01:00
|
|
|
{
|
2024-01-09 10:28:05 +01:00
|
|
|
Type: headerMatchTypePtr(gatev1.HeaderMatchExact),
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "my-header",
|
|
|
|
Value: "foo",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2024-01-23 11:34:05 +01:00
|
|
|
expectedRule: "Host(`foo.com`) && (Path(`/foo/`) || Header(`my-header`,`foo`))",
|
2020-12-15 16:40:05 +01:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
rule, err := extractRule(test.routeRule, test.hostRule)
|
|
|
|
if test.expectedError {
|
|
|
|
assert.Error(t, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
assert.Equal(t, test.expectedRule, rule)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2021-05-20 11:50:12 +02:00
|
|
|
|
2021-11-09 11:34:06 +01:00
|
|
|
func Test_hostSNIRule(t *testing.T) {
|
2021-05-20 11:50:12 +02:00
|
|
|
testCases := []struct {
|
|
|
|
desc string
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames []gatev1.Hostname
|
2021-05-20 11:50:12 +02:00
|
|
|
expectedRule string
|
|
|
|
expectError bool
|
|
|
|
}{
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Empty",
|
2021-05-20 11:50:12 +02:00
|
|
|
expectedRule: "HostSNI(`*`)",
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Empty hostname",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{""},
|
2021-05-20 11:50:12 +02:00
|
|
|
expectedRule: "HostSNI(`*`)",
|
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Unsupported wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"*"},
|
2021-11-09 11:34:06 +01:00
|
|
|
expectError: true,
|
|
|
|
},
|
2022-12-12 12:30:05 -03:00
|
|
|
{
|
|
|
|
desc: "Supported wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"*.foo"},
|
2022-12-12 12:30:05 -03:00
|
|
|
expectedRule: "HostSNIRegexp(`^[a-zA-Z0-9-]+\\.foo$`)",
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
{
|
|
|
|
desc: "Multiple malformed wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"*.foo.*"},
|
2021-11-09 11:34:06 +01:00
|
|
|
expectError: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Some empty hostnames",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"foo", "", "bar"},
|
2022-12-12 12:30:05 -03:00
|
|
|
expectedRule: "HostSNI(`foo`) || HostSNI(`bar`)",
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Valid hostname",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"foo"},
|
2021-11-09 11:34:06 +01:00
|
|
|
expectedRule: "HostSNI(`foo`)",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Multiple valid hostnames",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"foo", "bar"},
|
2022-12-12 12:30:05 -03:00
|
|
|
expectedRule: "HostSNI(`foo`) || HostSNI(`bar`)",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Multiple valid hostnames with wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"bar.foo", "foo.foo", "*.foo"},
|
2022-12-12 12:30:05 -03:00
|
|
|
expectedRule: "HostSNI(`bar.foo`) || HostSNI(`foo.foo`) || HostSNIRegexp(`^[a-zA-Z0-9-]+\\.foo$`)",
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Multiple overlapping hostnames",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"foo", "bar", "foo", "baz"},
|
2022-12-12 12:30:05 -03:00
|
|
|
expectedRule: "HostSNI(`foo`) || HostSNI(`bar`) || HostSNI(`baz`)",
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
rule, err := hostSNIRule(test.hostnames)
|
|
|
|
if test.expectError {
|
|
|
|
assert.Error(t, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
assert.Equal(t, test.expectedRule, rule)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_shouldAttach(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
desc string
|
2024-01-09 10:28:05 +01:00
|
|
|
gateway *gatev1.Gateway
|
|
|
|
listener gatev1.Listener
|
2021-11-09 11:34:06 +01:00
|
|
|
routeNamespace string
|
2024-01-09 10:28:05 +01:00
|
|
|
routeSpec gatev1.CommonRouteSpec
|
2021-11-09 11:34:06 +01:00
|
|
|
expectedAttach bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "No ParentRefs",
|
2024-01-09 10:28:05 +01:00
|
|
|
gateway: &gatev1.Gateway{
|
2021-11-09 11:34:06 +01:00
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: "default",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "foo",
|
|
|
|
},
|
|
|
|
routeNamespace: "default",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeSpec: gatev1.CommonRouteSpec{
|
2021-11-09 11:34:06 +01:00
|
|
|
ParentRefs: nil,
|
|
|
|
},
|
|
|
|
expectedAttach: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Unsupported Kind",
|
2024-01-09 10:28:05 +01:00
|
|
|
gateway: &gatev1.Gateway{
|
2021-11-09 11:34:06 +01:00
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: "default",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "foo",
|
|
|
|
},
|
|
|
|
routeNamespace: "default",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeSpec: gatev1.CommonRouteSpec{
|
|
|
|
ParentRefs: []gatev1.ParentReference{
|
2021-05-20 11:50:12 +02:00
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
SectionName: sectionNamePtr("bar"),
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: namespacePtr("default"),
|
|
|
|
Kind: kindPtr("Foo"),
|
2024-01-09 10:28:05 +01:00
|
|
|
Group: groupPtr(gatev1.GroupName),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
expectedAttach: false,
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Unsupported Group",
|
2024-01-09 10:28:05 +01:00
|
|
|
gateway: &gatev1.Gateway{
|
2021-11-09 11:34:06 +01:00
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: "default",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "foo",
|
|
|
|
},
|
|
|
|
routeNamespace: "default",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeSpec: gatev1.CommonRouteSpec{
|
|
|
|
ParentRefs: []gatev1.ParentReference{
|
2021-05-20 11:50:12 +02:00
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
SectionName: sectionNamePtr("bar"),
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: namespacePtr("default"),
|
|
|
|
Kind: kindPtr("Gateway"),
|
|
|
|
Group: groupPtr("foo.com"),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
expectedAttach: false,
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Kind is nil",
|
2024-01-09 10:28:05 +01:00
|
|
|
gateway: &gatev1.Gateway{
|
2021-11-09 11:34:06 +01:00
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: "default",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "foo",
|
|
|
|
},
|
|
|
|
routeNamespace: "default",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeSpec: gatev1.CommonRouteSpec{
|
|
|
|
ParentRefs: []gatev1.ParentReference{
|
2021-05-20 11:50:12 +02:00
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
SectionName: sectionNamePtr("bar"),
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: namespacePtr("default"),
|
2024-01-09 10:28:05 +01:00
|
|
|
Group: groupPtr(gatev1.GroupName),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
expectedAttach: false,
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Group is nil",
|
2024-01-09 10:28:05 +01:00
|
|
|
gateway: &gatev1.Gateway{
|
2021-11-09 11:34:06 +01:00
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: "default",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "foo",
|
|
|
|
},
|
|
|
|
routeNamespace: "default",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeSpec: gatev1.CommonRouteSpec{
|
|
|
|
ParentRefs: []gatev1.ParentReference{
|
2021-05-20 11:50:12 +02:00
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
SectionName: sectionNamePtr("bar"),
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: namespacePtr("default"),
|
|
|
|
Kind: kindPtr("Gateway"),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
expectedAttach: false,
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "SectionName does not match a listener desc",
|
2024-01-09 10:28:05 +01:00
|
|
|
gateway: &gatev1.Gateway{
|
2021-11-09 11:34:06 +01:00
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: "default",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "foo",
|
|
|
|
},
|
|
|
|
routeNamespace: "default",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeSpec: gatev1.CommonRouteSpec{
|
|
|
|
ParentRefs: []gatev1.ParentReference{
|
2021-05-20 11:50:12 +02:00
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
SectionName: sectionNamePtr("bar"),
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: namespacePtr("default"),
|
2024-01-09 10:28:05 +01:00
|
|
|
Group: groupPtr(gatev1.GroupName),
|
2021-11-09 11:34:06 +01:00
|
|
|
Kind: kindPtr("Gateway"),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
expectedAttach: false,
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Namespace does not match the Gateway namespace",
|
2024-01-09 10:28:05 +01:00
|
|
|
gateway: &gatev1.Gateway{
|
2021-11-09 11:34:06 +01:00
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: "default",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "foo",
|
|
|
|
},
|
|
|
|
routeNamespace: "default",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeSpec: gatev1.CommonRouteSpec{
|
|
|
|
ParentRefs: []gatev1.ParentReference{
|
2021-05-20 11:50:12 +02:00
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
SectionName: sectionNamePtr("bar"),
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: namespacePtr("bar"),
|
2024-01-09 10:28:05 +01:00
|
|
|
Group: groupPtr(gatev1.GroupName),
|
2021-11-09 11:34:06 +01:00
|
|
|
Kind: kindPtr("Gateway"),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
expectedAttach: false,
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Route namespace does not match the Gateway namespace",
|
2024-01-09 10:28:05 +01:00
|
|
|
gateway: &gatev1.Gateway{
|
2021-11-09 11:34:06 +01:00
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: "default",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "foo",
|
|
|
|
},
|
|
|
|
routeNamespace: "bar",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeSpec: gatev1.CommonRouteSpec{
|
|
|
|
ParentRefs: []gatev1.ParentReference{
|
2021-05-20 11:50:12 +02:00
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
SectionName: sectionNamePtr("bar"),
|
|
|
|
Name: "gateway",
|
2024-01-09 10:28:05 +01:00
|
|
|
Group: groupPtr(gatev1.GroupName),
|
2021-11-09 11:34:06 +01:00
|
|
|
Kind: kindPtr("Gateway"),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
expectedAttach: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Unsupported Kind",
|
2024-01-09 10:28:05 +01:00
|
|
|
gateway: &gatev1.Gateway{
|
2021-11-09 11:34:06 +01:00
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: "default",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "foo",
|
|
|
|
},
|
|
|
|
routeNamespace: "default",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeSpec: gatev1.CommonRouteSpec{
|
|
|
|
ParentRefs: []gatev1.ParentReference{
|
2021-11-09 11:34:06 +01:00
|
|
|
{
|
|
|
|
SectionName: sectionNamePtr("bar"),
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: namespacePtr("default"),
|
|
|
|
Kind: kindPtr("Gateway"),
|
2024-01-09 10:28:05 +01:00
|
|
|
Group: groupPtr(gatev1.GroupName),
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedAttach: false,
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Route namespace matches the Gateway namespace",
|
2024-01-09 10:28:05 +01:00
|
|
|
gateway: &gatev1.Gateway{
|
2021-11-09 11:34:06 +01:00
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: "default",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "foo",
|
|
|
|
},
|
|
|
|
routeNamespace: "default",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeSpec: gatev1.CommonRouteSpec{
|
|
|
|
ParentRefs: []gatev1.ParentReference{
|
2021-05-20 11:50:12 +02:00
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
SectionName: sectionNamePtr("foo"),
|
|
|
|
Name: "gateway",
|
|
|
|
Kind: kindPtr("Gateway"),
|
2024-01-09 10:28:05 +01:00
|
|
|
Group: groupPtr(gatev1.GroupName),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedAttach: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Namespace matches the Gateway namespace",
|
2024-01-09 10:28:05 +01:00
|
|
|
gateway: &gatev1.Gateway{
|
2021-11-09 11:34:06 +01:00
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: "default",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "foo",
|
|
|
|
},
|
|
|
|
routeNamespace: "bar",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeSpec: gatev1.CommonRouteSpec{
|
|
|
|
ParentRefs: []gatev1.ParentReference{
|
2021-05-20 11:50:12 +02:00
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
SectionName: sectionNamePtr("foo"),
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: namespacePtr("default"),
|
|
|
|
Kind: kindPtr("Gateway"),
|
2024-01-09 10:28:05 +01:00
|
|
|
Group: groupPtr(gatev1.GroupName),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
expectedAttach: true,
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
desc: "Only one ParentRef matches the Gateway",
|
2024-01-09 10:28:05 +01:00
|
|
|
gateway: &gatev1.Gateway{
|
2021-11-09 11:34:06 +01:00
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "gateway",
|
|
|
|
Namespace: "default",
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "foo",
|
|
|
|
},
|
|
|
|
routeNamespace: "bar",
|
2024-01-09 10:28:05 +01:00
|
|
|
routeSpec: gatev1.CommonRouteSpec{
|
|
|
|
ParentRefs: []gatev1.ParentReference{
|
2021-05-20 11:50:12 +02:00
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "gateway2",
|
|
|
|
Namespace: namespacePtr("default"),
|
|
|
|
Kind: kindPtr("Gateway"),
|
2024-01-09 10:28:05 +01:00
|
|
|
Group: groupPtr(gatev1.GroupName),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
{
|
2021-11-09 11:34:06 +01:00
|
|
|
Name: "gateway",
|
|
|
|
Namespace: namespacePtr("default"),
|
|
|
|
Kind: kindPtr("Gateway"),
|
2024-01-09 10:28:05 +01:00
|
|
|
Group: groupPtr(gatev1.GroupName),
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-09 11:34:06 +01:00
|
|
|
expectedAttach: true,
|
2021-05-20 11:50:12 +02:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
2021-11-09 11:34:06 +01:00
|
|
|
got := shouldAttach(test.gateway, test.listener, test.routeNamespace, test.routeSpec)
|
|
|
|
assert.Equal(t, test.expectedAttach, got)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_matchingHostnames(t *testing.T) {
|
2022-06-23 11:58:09 +02:00
|
|
|
testCases := []struct {
|
2021-11-09 11:34:06 +01:00
|
|
|
desc string
|
2024-01-09 10:28:05 +01:00
|
|
|
listener gatev1.Listener
|
|
|
|
hostnames []gatev1.Hostname
|
|
|
|
want []gatev1.Hostname
|
2021-11-09 11:34:06 +01:00
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "Empty",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Only listener hostname",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Hostname: hostnamePtr("foo.com"),
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
want: []gatev1.Hostname{"foo.com"},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Only Route hostname",
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"foo.com"},
|
|
|
|
want: []gatev1.Hostname{"foo.com"},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Matching hostname",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Hostname: hostnamePtr("foo.com"),
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"foo.com"},
|
|
|
|
want: []gatev1.Hostname{"foo.com"},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Matching hostname with wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Hostname: hostnamePtr("*.foo.com"),
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"*.foo.com"},
|
|
|
|
want: []gatev1.Hostname{"*.foo.com"},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Matching subdomain with listener wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Hostname: hostnamePtr("*.foo.com"),
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"bar.foo.com"},
|
|
|
|
want: []gatev1.Hostname{"bar.foo.com"},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Matching subdomain with route hostname wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Hostname: hostnamePtr("bar.foo.com"),
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"*.foo.com"},
|
|
|
|
want: []gatev1.Hostname{"bar.foo.com"},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Non matching root domain with listener wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Hostname: hostnamePtr("*.foo.com"),
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"foo.com"},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Non matching root domain with route hostname wildcard",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Hostname: hostnamePtr("foo.com"),
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"*.foo.com"},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Multiple route hostnames with one matching route hostname",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Hostname: hostnamePtr("*.foo.com"),
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"bar.com", "test.foo.com", "test.buz.com"},
|
|
|
|
want: []gatev1.Hostname{"test.foo.com"},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Multiple route hostnames with non matching route hostname",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Hostname: hostnamePtr("*.fuz.com"),
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"bar.com", "test.foo.com", "test.buz.com"},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Multiple route hostnames with multiple matching route hostnames",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2021-11-09 11:34:06 +01:00
|
|
|
Hostname: hostnamePtr("*.foo.com"),
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
hostnames: []gatev1.Hostname{"toto.foo.com", "test.foo.com", "test.buz.com"},
|
|
|
|
want: []gatev1.Hostname{"toto.foo.com", "test.foo.com"},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2022-06-23 11:58:09 +02:00
|
|
|
for _, test := range testCases {
|
2021-11-09 11:34:06 +01:00
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
got := matchingHostnames(test.listener, test.hostnames)
|
|
|
|
assert.Equal(t, test.want, got)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_getAllowedRoutes(t *testing.T) {
|
2022-06-23 11:58:09 +02:00
|
|
|
testCases := []struct {
|
2021-11-09 11:34:06 +01:00
|
|
|
desc string
|
2024-01-09 10:28:05 +01:00
|
|
|
listener gatev1.Listener
|
|
|
|
supportedRouteKinds []gatev1.RouteGroupKind
|
|
|
|
wantKinds []gatev1.RouteGroupKind
|
2021-11-09 11:34:06 +01:00
|
|
|
wantErr bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "Empty",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Empty AllowedRoutes",
|
2024-01-09 10:28:05 +01:00
|
|
|
supportedRouteKinds: []gatev1.RouteGroupKind{
|
|
|
|
{Kind: kindTLSRoute, Group: groupPtr(gatev1.GroupName)},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
wantKinds: []gatev1.RouteGroupKind{
|
|
|
|
{Kind: kindTLSRoute, Group: groupPtr(gatev1.GroupName)},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "AllowedRoutes with unsupported Group",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
|
|
|
AllowedRoutes: &gatev1.AllowedRoutes{
|
|
|
|
Kinds: []gatev1.RouteGroupKind{{
|
2021-11-09 11:34:06 +01:00
|
|
|
Kind: kindTLSRoute, Group: groupPtr("foo"),
|
|
|
|
}},
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
supportedRouteKinds: []gatev1.RouteGroupKind{
|
|
|
|
{Kind: kindTLSRoute, Group: groupPtr(gatev1.GroupName)},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
wantErr: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "AllowedRoutes with nil Group",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
|
|
|
AllowedRoutes: &gatev1.AllowedRoutes{
|
|
|
|
Kinds: []gatev1.RouteGroupKind{{
|
2021-11-09 11:34:06 +01:00
|
|
|
Kind: kindTLSRoute, Group: nil,
|
|
|
|
}},
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
supportedRouteKinds: []gatev1.RouteGroupKind{
|
|
|
|
{Kind: kindTLSRoute, Group: groupPtr(gatev1.GroupName)},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
wantErr: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "AllowedRoutes with unsupported Kind",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
|
|
|
AllowedRoutes: &gatev1.AllowedRoutes{
|
|
|
|
Kinds: []gatev1.RouteGroupKind{{
|
|
|
|
Kind: "foo", Group: groupPtr(gatev1.GroupName),
|
2021-11-09 11:34:06 +01:00
|
|
|
}},
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
supportedRouteKinds: []gatev1.RouteGroupKind{
|
|
|
|
{Kind: kindTLSRoute, Group: groupPtr(gatev1.GroupName)},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
wantErr: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Supported AllowedRoutes",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
|
|
|
AllowedRoutes: &gatev1.AllowedRoutes{
|
|
|
|
Kinds: []gatev1.RouteGroupKind{{
|
|
|
|
Kind: kindTLSRoute, Group: groupPtr(gatev1.GroupName),
|
2021-11-09 11:34:06 +01:00
|
|
|
}},
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
supportedRouteKinds: []gatev1.RouteGroupKind{
|
|
|
|
{Kind: kindTLSRoute, Group: groupPtr(gatev1.GroupName)},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
wantKinds: []gatev1.RouteGroupKind{
|
|
|
|
{Kind: kindTLSRoute, Group: groupPtr(gatev1.GroupName)},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "Supported AllowedRoutes with duplicates",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
|
|
|
AllowedRoutes: &gatev1.AllowedRoutes{
|
|
|
|
Kinds: []gatev1.RouteGroupKind{
|
|
|
|
{Kind: kindTLSRoute, Group: groupPtr(gatev1.GroupName)},
|
|
|
|
{Kind: kindTCPRoute, Group: groupPtr(gatev1.GroupName)},
|
|
|
|
{Kind: kindTLSRoute, Group: groupPtr(gatev1.GroupName)},
|
|
|
|
{Kind: kindTCPRoute, Group: groupPtr(gatev1.GroupName)},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
supportedRouteKinds: []gatev1.RouteGroupKind{
|
|
|
|
{Kind: kindTLSRoute, Group: groupPtr(gatev1.GroupName)},
|
|
|
|
{Kind: kindTCPRoute, Group: groupPtr(gatev1.GroupName)},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
2024-01-09 10:28:05 +01:00
|
|
|
wantKinds: []gatev1.RouteGroupKind{
|
|
|
|
{Kind: kindTLSRoute, Group: groupPtr(gatev1.GroupName)},
|
|
|
|
{Kind: kindTCPRoute, Group: groupPtr(gatev1.GroupName)},
|
2021-11-09 11:34:06 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2022-06-23 11:58:09 +02:00
|
|
|
for _, test := range testCases {
|
2021-11-09 11:34:06 +01:00
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
2024-01-09 10:28:05 +01:00
|
|
|
got, conditions := getAllowedRouteKinds(&gatev1.Gateway{}, test.listener, test.supportedRouteKinds)
|
2021-11-09 11:34:06 +01:00
|
|
|
if test.wantErr {
|
|
|
|
require.NotEmpty(t, conditions, "no conditions")
|
2021-05-20 11:50:12 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-11-17 01:50:06 +01:00
|
|
|
require.Empty(t, conditions)
|
2021-11-09 11:34:06 +01:00
|
|
|
assert.Equal(t, test.wantKinds, got)
|
2021-05-20 11:50:12 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2021-11-09 11:34:06 +01:00
|
|
|
|
2022-06-23 11:58:09 +02:00
|
|
|
func Test_makeListenerKey(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
desc string
|
2024-01-09 10:28:05 +01:00
|
|
|
listener gatev1.Listener
|
2022-06-23 11:58:09 +02:00
|
|
|
expectedKey string
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "empty",
|
|
|
|
expectedKey: "||0",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "listener with port, protocol and hostname",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2022-06-23 11:58:09 +02:00
|
|
|
Port: 443,
|
2024-01-09 10:28:05 +01:00
|
|
|
Protocol: gatev1.HTTPSProtocolType,
|
2022-06-23 11:58:09 +02:00
|
|
|
Hostname: hostnamePtr("www.example.com"),
|
|
|
|
},
|
|
|
|
expectedKey: "HTTPS|www.example.com|443",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "listener with port, protocol and nil hostname",
|
2024-01-09 10:28:05 +01:00
|
|
|
listener: gatev1.Listener{
|
2022-06-23 11:58:09 +02:00
|
|
|
Port: 443,
|
2024-01-09 10:28:05 +01:00
|
|
|
Protocol: gatev1.HTTPSProtocolType,
|
2022-06-23 11:58:09 +02:00
|
|
|
},
|
|
|
|
expectedKey: "HTTPS||443",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
assert.Equal(t, test.expectedKey, makeListenerKey(test.listener))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-30 16:44:05 +01:00
|
|
|
func Test_referenceGrantMatchesFrom(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
desc string
|
|
|
|
referenceGrant gatev1beta1.ReferenceGrant
|
|
|
|
group string
|
|
|
|
kind string
|
|
|
|
namespace string
|
|
|
|
expectedResult bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "matches",
|
|
|
|
referenceGrant: gatev1beta1.ReferenceGrant{
|
|
|
|
Spec: gatev1beta1.ReferenceGrantSpec{
|
|
|
|
From: []gatev1beta1.ReferenceGrantFrom{
|
|
|
|
{
|
|
|
|
Group: "correct-group",
|
|
|
|
Kind: "correct-kind",
|
|
|
|
Namespace: "correct-namespace",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
group: "correct-group",
|
|
|
|
kind: "correct-kind",
|
|
|
|
namespace: "correct-namespace",
|
|
|
|
expectedResult: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "empty group matches core",
|
|
|
|
referenceGrant: gatev1beta1.ReferenceGrant{
|
|
|
|
Spec: gatev1beta1.ReferenceGrantSpec{
|
|
|
|
From: []gatev1beta1.ReferenceGrantFrom{
|
|
|
|
{
|
|
|
|
Group: "",
|
|
|
|
Kind: "correct-kind",
|
|
|
|
Namespace: "correct-namespace",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
group: "core",
|
|
|
|
kind: "correct-kind",
|
|
|
|
namespace: "correct-namespace",
|
|
|
|
expectedResult: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "wrong group",
|
|
|
|
referenceGrant: gatev1beta1.ReferenceGrant{
|
|
|
|
Spec: gatev1beta1.ReferenceGrantSpec{
|
|
|
|
From: []gatev1beta1.ReferenceGrantFrom{
|
|
|
|
{
|
|
|
|
Group: "wrong-group",
|
|
|
|
Kind: "correct-kind",
|
|
|
|
Namespace: "correct-namespace",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
group: "correct-group",
|
|
|
|
kind: "correct-kind",
|
|
|
|
namespace: "correct-namespace",
|
|
|
|
expectedResult: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "wrong kind",
|
|
|
|
referenceGrant: gatev1beta1.ReferenceGrant{
|
|
|
|
Spec: gatev1beta1.ReferenceGrantSpec{
|
|
|
|
From: []gatev1beta1.ReferenceGrantFrom{
|
|
|
|
{
|
|
|
|
Group: "correct-group",
|
|
|
|
Kind: "wrong-kind",
|
|
|
|
Namespace: "correct-namespace",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
group: "correct-group",
|
|
|
|
kind: "correct-kind",
|
|
|
|
namespace: "correct-namespace",
|
|
|
|
expectedResult: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "wrong namespace",
|
|
|
|
referenceGrant: gatev1beta1.ReferenceGrant{
|
|
|
|
Spec: gatev1beta1.ReferenceGrantSpec{
|
|
|
|
From: []gatev1beta1.ReferenceGrantFrom{
|
|
|
|
{
|
|
|
|
Group: "correct-group",
|
|
|
|
Kind: "correct-kind",
|
|
|
|
Namespace: "wrong-namespace",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
group: "correct-group",
|
|
|
|
kind: "correct-kind",
|
|
|
|
namespace: "correct-namespace",
|
|
|
|
expectedResult: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
assert.Equal(t, test.expectedResult, referenceGrantMatchesFrom(&test.referenceGrant, test.group, test.kind, test.namespace))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_referenceGrantMatchesTo(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
desc string
|
|
|
|
referenceGrant gatev1beta1.ReferenceGrant
|
|
|
|
group string
|
|
|
|
kind string
|
|
|
|
name string
|
|
|
|
expectedResult bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "matches",
|
|
|
|
referenceGrant: gatev1beta1.ReferenceGrant{
|
|
|
|
Spec: gatev1beta1.ReferenceGrantSpec{
|
|
|
|
To: []gatev1beta1.ReferenceGrantTo{
|
|
|
|
{
|
|
|
|
Group: "correct-group",
|
|
|
|
Kind: "correct-kind",
|
|
|
|
Name: objectNamePtr("correct-name"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
group: "correct-group",
|
|
|
|
kind: "correct-kind",
|
|
|
|
name: "correct-name",
|
|
|
|
expectedResult: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "matches without name",
|
|
|
|
referenceGrant: gatev1beta1.ReferenceGrant{
|
|
|
|
Spec: gatev1beta1.ReferenceGrantSpec{
|
|
|
|
To: []gatev1beta1.ReferenceGrantTo{
|
|
|
|
{
|
|
|
|
Group: "correct-group",
|
|
|
|
Kind: "correct-kind",
|
|
|
|
Name: nil,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
group: "correct-group",
|
|
|
|
kind: "correct-kind",
|
|
|
|
name: "some-name",
|
|
|
|
expectedResult: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "empty group matches core",
|
|
|
|
referenceGrant: gatev1beta1.ReferenceGrant{
|
|
|
|
Spec: gatev1beta1.ReferenceGrantSpec{
|
|
|
|
To: []gatev1beta1.ReferenceGrantTo{
|
|
|
|
{
|
|
|
|
Group: "",
|
|
|
|
Kind: "correct-kind",
|
|
|
|
Name: objectNamePtr("correct-name"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
group: "core",
|
|
|
|
kind: "correct-kind",
|
|
|
|
name: "correct-name",
|
|
|
|
expectedResult: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "wrong group",
|
|
|
|
referenceGrant: gatev1beta1.ReferenceGrant{
|
|
|
|
Spec: gatev1beta1.ReferenceGrantSpec{
|
|
|
|
To: []gatev1beta1.ReferenceGrantTo{
|
|
|
|
{
|
|
|
|
Group: "wrong-group",
|
|
|
|
Kind: "correct-kind",
|
|
|
|
Name: objectNamePtr("correct-name"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
group: "correct-group",
|
|
|
|
kind: "correct-kind",
|
|
|
|
name: "correct-namespace",
|
|
|
|
expectedResult: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "wrong kind",
|
|
|
|
referenceGrant: gatev1beta1.ReferenceGrant{
|
|
|
|
Spec: gatev1beta1.ReferenceGrantSpec{
|
|
|
|
To: []gatev1beta1.ReferenceGrantTo{
|
|
|
|
{
|
|
|
|
Group: "correct-group",
|
|
|
|
Kind: "wrong-kind",
|
|
|
|
Name: objectNamePtr("correct-name"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
group: "correct-group",
|
|
|
|
kind: "correct-kind",
|
|
|
|
name: "correct-name",
|
|
|
|
expectedResult: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "wrong name",
|
|
|
|
referenceGrant: gatev1beta1.ReferenceGrant{
|
|
|
|
Spec: gatev1beta1.ReferenceGrantSpec{
|
|
|
|
To: []gatev1beta1.ReferenceGrantTo{
|
|
|
|
{
|
|
|
|
Group: "correct-group",
|
|
|
|
Kind: "correct-kind",
|
|
|
|
Name: objectNamePtr("wrong-name"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
group: "correct-group",
|
|
|
|
kind: "correct-kind",
|
|
|
|
name: "correct-name",
|
|
|
|
expectedResult: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
assert.Equal(t, test.expectedResult, referenceGrantMatchesTo(&test.referenceGrant, test.group, test.kind, test.name))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-04-10 09:34:07 +02:00
|
|
|
func Test_gatewayAddresses(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
desc string
|
|
|
|
statusAddress *StatusAddress
|
|
|
|
paths []string
|
|
|
|
wantErr require.ErrorAssertionFunc
|
|
|
|
want []gatev1.GatewayStatusAddress
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "nothing",
|
|
|
|
wantErr: require.NoError,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "empty configuration",
|
|
|
|
statusAddress: &StatusAddress{},
|
|
|
|
wantErr: require.Error,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "IP address",
|
|
|
|
statusAddress: &StatusAddress{
|
|
|
|
IP: "1.2.3.4",
|
|
|
|
},
|
|
|
|
wantErr: require.NoError,
|
|
|
|
want: []gatev1.GatewayStatusAddress{
|
|
|
|
{
|
|
|
|
Type: ptr.To(gatev1.IPAddressType),
|
|
|
|
Value: "1.2.3.4",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "hostname address",
|
|
|
|
statusAddress: &StatusAddress{
|
|
|
|
Hostname: "foo.bar",
|
|
|
|
},
|
|
|
|
wantErr: require.NoError,
|
|
|
|
want: []gatev1.GatewayStatusAddress{
|
|
|
|
{
|
|
|
|
Type: ptr.To(gatev1.HostnameAddressType),
|
|
|
|
Value: "foo.bar",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "service",
|
|
|
|
statusAddress: &StatusAddress{
|
|
|
|
Service: ServiceRef{
|
|
|
|
Name: "status-address",
|
|
|
|
Namespace: "default",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
paths: []string{"services.yml"},
|
|
|
|
wantErr: require.NoError,
|
|
|
|
want: []gatev1.GatewayStatusAddress{
|
|
|
|
{
|
|
|
|
Type: ptr.To(gatev1.HostnameAddressType),
|
|
|
|
Value: "foo.bar",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Type: ptr.To(gatev1.IPAddressType),
|
|
|
|
Value: "1.2.3.4",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "missing service",
|
|
|
|
statusAddress: &StatusAddress{
|
|
|
|
Service: ServiceRef{
|
|
|
|
Name: "status-address2",
|
|
|
|
Namespace: "default",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wantErr: require.Error,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "service without load-balancer status",
|
|
|
|
statusAddress: &StatusAddress{
|
|
|
|
Service: ServiceRef{
|
|
|
|
Name: "whoamitcp-bar",
|
|
|
|
Namespace: "bar",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
paths: []string{"services.yml"},
|
|
|
|
wantErr: require.NoError,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
|
|
|
t.Run(test.desc, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
p := Provider{StatusAddress: test.statusAddress}
|
|
|
|
|
|
|
|
got, err := p.gatewayAddresses(newClientMock(test.paths...))
|
|
|
|
test.wantErr(t, err)
|
|
|
|
|
|
|
|
assert.Equal(t, test.want, got)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func hostnamePtr(hostname gatev1.Hostname) *gatev1.Hostname {
|
|
|
|
return &hostname
|
|
|
|
}
|
|
|
|
|
|
|
|
func groupPtr(group gatev1.Group) *gatev1.Group {
|
|
|
|
return &group
|
|
|
|
}
|
|
|
|
|
|
|
|
func sectionNamePtr(sectionName gatev1.SectionName) *gatev1.SectionName {
|
|
|
|
return §ionName
|
|
|
|
}
|
|
|
|
|
|
|
|
func namespacePtr(namespace gatev1.Namespace) *gatev1.Namespace {
|
|
|
|
return &namespace
|
|
|
|
}
|
|
|
|
|
|
|
|
func kindPtr(kind gatev1.Kind) *gatev1.Kind {
|
|
|
|
return &kind
|
|
|
|
}
|
|
|
|
|
|
|
|
func pathMatchTypePtr(p gatev1.PathMatchType) *gatev1.PathMatchType { return &p }
|
|
|
|
|
|
|
|
func headerMatchTypePtr(h gatev1.HeaderMatchType) *gatev1.HeaderMatchType { return &h }
|
|
|
|
|
2024-01-30 16:44:05 +01:00
|
|
|
func objectNamePtr(objectName gatev1.ObjectName) *gatev1.ObjectName {
|
|
|
|
return &objectName
|
|
|
|
}
|