7038fe6b71
* Added new Config for SidecarService in ServiceDefinitions.
* WIP: all the code needed for SidecarService is written... none of it is tested other than config :). Need API updates too.
* Test coverage for the new sidecarServiceFromNodeService method.
* Test API registratrion with SidecarService
* Recursive Key Translation 🤦
* Add tests for nested sidecar defintion arrays to ensure they are translated correctly
* Use dedicated internal state rather than Service Meta for tracking sidecars for deregistration.
Add tests for deregistration.
* API struct for agent register. No other endpoint should be affected yet.
* Additional test cases to cover updates to API registrations
53 lines
1.6 KiB
Go
53 lines
1.6 KiB
Go
package structs
|
|
|
|
import "github.com/mitchellh/go-testing-interface"
|
|
|
|
// TestConnectProxyConfig returns a ConnectProxyConfig representing a valid
|
|
// Connect proxy.
|
|
func TestConnectProxyConfig(t testing.T) ConnectProxyConfig {
|
|
return ConnectProxyConfig{
|
|
DestinationServiceName: "web",
|
|
Upstreams: TestUpstreams(t),
|
|
}
|
|
}
|
|
|
|
// TestUpstreams returns a set of upstreams to be used in tests exercising most
|
|
// important configuration patterns.
|
|
func TestUpstreams(t testing.T) Upstreams {
|
|
return Upstreams{
|
|
{
|
|
// We rely on this one having default type in a few tests...
|
|
DestinationName: "db",
|
|
LocalBindPort: 9191,
|
|
Config: map[string]interface{}{
|
|
// Float because this is how it is decoded by JSON decoder so this
|
|
// enables the value returned to be compared directly to a decoded JSON
|
|
// response without spurios type loss.
|
|
"connect_timeout_ms": float64(1000),
|
|
},
|
|
},
|
|
{
|
|
DestinationType: UpstreamDestTypePreparedQuery,
|
|
DestinationName: "geo-cache",
|
|
LocalBindPort: 8181,
|
|
LocalBindAddress: "127.10.10.10",
|
|
},
|
|
}
|
|
}
|
|
|
|
// TestAddDefaultsToUpstreams takes an array of upstreams (such as that from
|
|
// TestUpstreams) and adds default values that are populated during
|
|
// refigistration. Use this for generating the expected Upstreams value after
|
|
// registration.
|
|
func TestAddDefaultsToUpstreams(t testing.T, upstreams []Upstream) []Upstream {
|
|
ups := make([]Upstream, len(upstreams))
|
|
for i := range upstreams {
|
|
ups[i] = upstreams[i]
|
|
// Fill in default fields we expect to have back explicitly in a response
|
|
if ups[i].DestinationType == "" {
|
|
ups[i].DestinationType = UpstreamDestTypeService
|
|
}
|
|
}
|
|
return ups
|
|
}
|