mirror of
https://github.com/status-im/consul.git
synced 2025-01-27 05:57:03 +00:00
b8b37c2357
Ensure nothing in the troubleshoot go module depends on consul's top level module. This is so we can import troubleshoot into consul-k8s and not import all of consul. * turns troubleshoot into a go module [authored by @curtbushko] * gets the envoy protos into the troubleshoot module [authored by @curtbushko] * adds a new go module `envoyextensions` which has xdscommon and extensioncommon folders that both the xds package and the troubleshoot package can import * adds testing and linting for the new go modules * moves the unit tests in `troubleshoot/validateupstream` that depend on proxycfg/xds into the xds package, with a comment describing why those tests cannot be in the troubleshoot package * fixes all the imports everywhere as a result of these changes Co-authored-by: Curt Bushko <cbushko@gmail.com>
282 lines
8.1 KiB
Go
282 lines
8.1 KiB
Go
//go:build !consulent
|
|
// +build !consulent
|
|
|
|
package extensionruntime
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/hashicorp/consul/agent/proxycfg"
|
|
"github.com/hashicorp/consul/agent/structs"
|
|
"github.com/hashicorp/consul/api"
|
|
"github.com/hashicorp/consul/envoyextensions/extensioncommon"
|
|
)
|
|
|
|
func TestGetRuntimeConfigurations_TerminatingGateway(t *testing.T) {
|
|
snap := proxycfg.TestConfigSnapshotTerminatingGatewayWithLambdaServiceAndServiceResolvers(t)
|
|
|
|
webService := api.CompoundServiceName{
|
|
Name: "web",
|
|
Namespace: "default",
|
|
Partition: "default",
|
|
}
|
|
dbService := api.CompoundServiceName{
|
|
Name: "db",
|
|
Namespace: "default",
|
|
Partition: "default",
|
|
}
|
|
cacheService := api.CompoundServiceName{
|
|
Name: "cache",
|
|
Namespace: "default",
|
|
Partition: "default",
|
|
}
|
|
apiService := api.CompoundServiceName{
|
|
Name: "api",
|
|
Namespace: "default",
|
|
Partition: "default",
|
|
}
|
|
|
|
expected := map[api.CompoundServiceName][]extensioncommon.RuntimeConfig{
|
|
apiService: {},
|
|
cacheService: {},
|
|
dbService: {},
|
|
webService: {
|
|
{
|
|
EnvoyExtension: api.EnvoyExtension{
|
|
Name: api.BuiltinAWSLambdaExtension,
|
|
Arguments: map[string]interface{}{
|
|
"ARN": "arn:aws:lambda:us-east-1:111111111111:function:lambda-1234",
|
|
"PayloadPassthrough": true,
|
|
},
|
|
},
|
|
ServiceName: webService,
|
|
Upstreams: map[api.CompoundServiceName]*extensioncommon.UpstreamData{
|
|
apiService: {
|
|
SNI: map[string]struct{}{
|
|
"api.default.dc1.internal.11111111-2222-3333-4444-555555555555.consul": {},
|
|
},
|
|
EnvoyID: "api",
|
|
OutgoingProxyKind: "terminating-gateway",
|
|
},
|
|
cacheService: {
|
|
SNI: map[string]struct{}{
|
|
"cache.default.dc1.internal.11111111-2222-3333-4444-555555555555.consul": {},
|
|
},
|
|
EnvoyID: "cache",
|
|
OutgoingProxyKind: "terminating-gateway",
|
|
},
|
|
dbService: {
|
|
SNI: map[string]struct{}{
|
|
"db.default.dc1.internal.11111111-2222-3333-4444-555555555555.consul": {},
|
|
},
|
|
EnvoyID: "db",
|
|
OutgoingProxyKind: "terminating-gateway",
|
|
},
|
|
webService: {
|
|
SNI: map[string]struct{}{
|
|
"canary1.web.default.dc1.internal.11111111-2222-3333-4444-555555555555.consul": {},
|
|
"canary2.web.default.dc1.internal.11111111-2222-3333-4444-555555555555.consul": {},
|
|
"web.default.dc1.internal.11111111-2222-3333-4444-555555555555.consul": {},
|
|
},
|
|
EnvoyID: "web",
|
|
OutgoingProxyKind: "terminating-gateway",
|
|
},
|
|
},
|
|
Kind: api.ServiceKindTerminatingGateway,
|
|
},
|
|
},
|
|
}
|
|
|
|
require.Equal(t, expected, GetRuntimeConfigurations(snap))
|
|
}
|
|
|
|
func TestGetRuntimeConfigurations_ConnectProxy(t *testing.T) {
|
|
dbService := api.CompoundServiceName{
|
|
Name: "db",
|
|
Partition: "default",
|
|
Namespace: "default",
|
|
}
|
|
webService := api.CompoundServiceName{
|
|
Name: "web",
|
|
Partition: "",
|
|
Namespace: "default",
|
|
}
|
|
|
|
// Setup multiple extensions to ensure all of them are in the ExtensionConfiguration map.
|
|
envoyExtensions := []structs.EnvoyExtension{
|
|
{
|
|
Name: api.BuiltinAWSLambdaExtension,
|
|
Arguments: map[string]interface{}{
|
|
"ARN": "arn:aws:lambda:us-east-1:111111111111:function:lambda-1234",
|
|
"PayloadPassthrough": true,
|
|
},
|
|
},
|
|
{
|
|
Name: "ext2",
|
|
Arguments: map[string]interface{}{
|
|
"arg1": 1,
|
|
"arg2": "val2",
|
|
},
|
|
},
|
|
}
|
|
|
|
serviceDefaults := &structs.ServiceConfigEntry{
|
|
Kind: structs.ServiceDefaults,
|
|
Name: "db",
|
|
Protocol: "http",
|
|
EnvoyExtensions: envoyExtensions,
|
|
}
|
|
|
|
// Setup a snapshot where the db upstream is on a connect proxy.
|
|
snapConnect := proxycfg.TestConfigSnapshotDiscoveryChain(t, "default", nil, nil, serviceDefaults)
|
|
// Setup a snapshot where the db upstream is on a terminating gateway.
|
|
snapTermGw := proxycfg.TestConfigSnapshotDiscoveryChain(t, "register-to-terminating-gateway", nil, nil, serviceDefaults)
|
|
// Setup a snapshot with the local service web has extensions.
|
|
snapWebConnect := proxycfg.TestConfigSnapshotDiscoveryChain(t, "default", func(ns *structs.NodeService) {
|
|
ns.Proxy.EnvoyExtensions = envoyExtensions
|
|
}, nil)
|
|
|
|
type testCase struct {
|
|
snapshot *proxycfg.ConfigSnapshot
|
|
expected map[api.CompoundServiceName][]extensioncommon.RuntimeConfig
|
|
}
|
|
cases := map[string]testCase{
|
|
"connect proxy upstream": {
|
|
snapshot: snapConnect,
|
|
expected: map[api.CompoundServiceName][]extensioncommon.RuntimeConfig{
|
|
dbService: {
|
|
{
|
|
EnvoyExtension: api.EnvoyExtension{
|
|
Name: api.BuiltinAWSLambdaExtension,
|
|
Arguments: map[string]interface{}{
|
|
"ARN": "arn:aws:lambda:us-east-1:111111111111:function:lambda-1234",
|
|
"PayloadPassthrough": true,
|
|
},
|
|
},
|
|
ServiceName: dbService,
|
|
Upstreams: map[api.CompoundServiceName]*extensioncommon.UpstreamData{
|
|
dbService: {
|
|
SNI: map[string]struct{}{
|
|
"db.default.dc1.internal.11111111-2222-3333-4444-555555555555.consul": {},
|
|
},
|
|
EnvoyID: "db",
|
|
OutgoingProxyKind: "connect-proxy",
|
|
},
|
|
},
|
|
Kind: api.ServiceKindConnectProxy,
|
|
},
|
|
{
|
|
EnvoyExtension: api.EnvoyExtension{
|
|
Name: "ext2",
|
|
Arguments: map[string]interface{}{
|
|
"arg1": 1,
|
|
"arg2": "val2",
|
|
},
|
|
},
|
|
ServiceName: dbService,
|
|
Upstreams: map[api.CompoundServiceName]*extensioncommon.UpstreamData{
|
|
dbService: {
|
|
SNI: map[string]struct{}{
|
|
"db.default.dc1.internal.11111111-2222-3333-4444-555555555555.consul": {},
|
|
},
|
|
EnvoyID: "db",
|
|
OutgoingProxyKind: "connect-proxy",
|
|
},
|
|
},
|
|
Kind: api.ServiceKindConnectProxy,
|
|
},
|
|
},
|
|
webService: {},
|
|
},
|
|
},
|
|
"terminating gateway upstream": {
|
|
snapshot: snapTermGw,
|
|
expected: map[api.CompoundServiceName][]extensioncommon.RuntimeConfig{
|
|
dbService: {
|
|
{
|
|
EnvoyExtension: api.EnvoyExtension{
|
|
Name: api.BuiltinAWSLambdaExtension,
|
|
Arguments: map[string]interface{}{
|
|
"ARN": "arn:aws:lambda:us-east-1:111111111111:function:lambda-1234",
|
|
"PayloadPassthrough": true,
|
|
},
|
|
},
|
|
ServiceName: dbService,
|
|
Upstreams: map[api.CompoundServiceName]*extensioncommon.UpstreamData{
|
|
dbService: {
|
|
SNI: map[string]struct{}{
|
|
"db.default.dc1.internal.11111111-2222-3333-4444-555555555555.consul": {},
|
|
},
|
|
EnvoyID: "db",
|
|
OutgoingProxyKind: "terminating-gateway",
|
|
},
|
|
},
|
|
Kind: api.ServiceKindConnectProxy,
|
|
},
|
|
{
|
|
EnvoyExtension: api.EnvoyExtension{
|
|
Name: "ext2",
|
|
Arguments: map[string]interface{}{
|
|
"arg1": 1,
|
|
"arg2": "val2",
|
|
},
|
|
},
|
|
ServiceName: dbService,
|
|
Upstreams: map[api.CompoundServiceName]*extensioncommon.UpstreamData{
|
|
dbService: {
|
|
SNI: map[string]struct{}{
|
|
"db.default.dc1.internal.11111111-2222-3333-4444-555555555555.consul": {},
|
|
},
|
|
EnvoyID: "db",
|
|
OutgoingProxyKind: "terminating-gateway",
|
|
},
|
|
},
|
|
Kind: api.ServiceKindConnectProxy,
|
|
},
|
|
},
|
|
webService: {},
|
|
},
|
|
},
|
|
"local service extensions": {
|
|
snapshot: snapWebConnect,
|
|
expected: map[api.CompoundServiceName][]extensioncommon.RuntimeConfig{
|
|
dbService: {},
|
|
webService: {
|
|
{
|
|
EnvoyExtension: api.EnvoyExtension{
|
|
Name: api.BuiltinAWSLambdaExtension,
|
|
Arguments: map[string]interface{}{
|
|
"ARN": "arn:aws:lambda:us-east-1:111111111111:function:lambda-1234",
|
|
"PayloadPassthrough": true,
|
|
},
|
|
},
|
|
ServiceName: webService,
|
|
Upstreams: nil,
|
|
Kind: api.ServiceKindConnectProxy,
|
|
},
|
|
{
|
|
EnvoyExtension: api.EnvoyExtension{
|
|
Name: "ext2",
|
|
Arguments: map[string]interface{}{
|
|
"arg1": 1,
|
|
"arg2": "val2",
|
|
},
|
|
},
|
|
ServiceName: webService,
|
|
Upstreams: nil,
|
|
Kind: api.ServiceKindConnectProxy,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
for name, tc := range cases {
|
|
t.Run(name, func(t *testing.T) {
|
|
require.Equal(t, tc.expected, GetRuntimeConfigurations(tc.snapshot))
|
|
})
|
|
}
|
|
}
|