mirror of
https://github.com/status-im/consul.git
synced 2025-01-21 19:20:41 +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>
93 lines
2.0 KiB
Go
93 lines
2.0 KiB
Go
package lua
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/hashicorp/consul/api"
|
|
"github.com/hashicorp/consul/envoyextensions/extensioncommon"
|
|
)
|
|
|
|
func TestConstructor(t *testing.T) {
|
|
makeArguments := func(overrides map[string]interface{}) map[string]interface{} {
|
|
m := map[string]interface{}{
|
|
"ProxyType": "connect-proxy",
|
|
"Listener": "inbound",
|
|
"Script": "lua-script",
|
|
}
|
|
|
|
for k, v := range overrides {
|
|
m[k] = v
|
|
}
|
|
|
|
return m
|
|
}
|
|
|
|
cases := map[string]struct {
|
|
extensionName string
|
|
arguments map[string]interface{}
|
|
expected lua
|
|
ok bool
|
|
}{
|
|
"with no arguments": {
|
|
arguments: nil,
|
|
ok: false,
|
|
},
|
|
"with an invalid name": {
|
|
arguments: makeArguments(map[string]interface{}{}),
|
|
extensionName: "bad",
|
|
ok: false,
|
|
},
|
|
"empty script": {
|
|
arguments: makeArguments(map[string]interface{}{"Script": ""}),
|
|
ok: false,
|
|
},
|
|
"invalid proxy type": {
|
|
arguments: makeArguments(map[string]interface{}{"ProxyType": "terminating-gateway"}),
|
|
ok: false,
|
|
},
|
|
"invalid listener": {
|
|
arguments: makeArguments(map[string]interface{}{"Listener": "invalid"}),
|
|
ok: false,
|
|
},
|
|
"valid everything": {
|
|
arguments: makeArguments(map[string]interface{}{}),
|
|
expected: lua{
|
|
ProxyType: "connect-proxy",
|
|
Listener: "inbound",
|
|
Script: "lua-script",
|
|
},
|
|
ok: true,
|
|
},
|
|
}
|
|
|
|
for n, tc := range cases {
|
|
t.Run(n, func(t *testing.T) {
|
|
|
|
extensionName := api.BuiltinLuaExtension
|
|
if tc.extensionName != "" {
|
|
extensionName = tc.extensionName
|
|
}
|
|
|
|
svc := api.CompoundServiceName{Name: "svc"}
|
|
ext := extensioncommon.RuntimeConfig{
|
|
ServiceName: svc,
|
|
EnvoyExtension: api.EnvoyExtension{
|
|
Name: extensionName,
|
|
Arguments: tc.arguments,
|
|
},
|
|
}
|
|
|
|
e, err := Constructor(ext.EnvoyExtension)
|
|
|
|
if tc.ok {
|
|
require.NoError(t, err)
|
|
require.Equal(t, &extensioncommon.BasicEnvoyExtender{Extension: &tc.expected}, e)
|
|
} else {
|
|
require.Error(t, err)
|
|
}
|
|
})
|
|
}
|
|
}
|