mirror of
https://github.com/status-im/consul.git
synced 2025-01-10 05:45:46 +00:00
0bcbed16ca
* Standardize support for Tagged and BindAddresses in Ingress Gateways This updates the TaggedAddresses and BindAddresses behavior for Ingress to match Mesh/Terminating gateways. The `consul connect envoy` command now also allows passing an address without a port for tagged/bind addresses. * Update command/connect/envoy/envoy.go Co-authored-by: Freddy <freddygv@users.noreply.github.com> * PR comments * Check to see if address is an actual IP address * Update agent/xds/listeners.go Co-authored-by: Freddy <freddygv@users.noreply.github.com> * fix whitespace Co-authored-by: Chris Piraino <cpiraino@hashicorp.com> Co-authored-by: Freddy <freddygv@users.noreply.github.com>
107 lines
2.5 KiB
Go
107 lines
2.5 KiB
Go
package envoy
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/hashicorp/consul/api"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestServiceAddressValue_Value(t *testing.T) {
|
|
t.Run("nil receiver", func(t *testing.T) {
|
|
var addr *ServiceAddressValue
|
|
require.Equal(t, addr.Value(), api.ServiceAddress{Port: defaultGatewayPort})
|
|
})
|
|
|
|
t.Run("default value", func(t *testing.T) {
|
|
addr := &ServiceAddressValue{}
|
|
require.Equal(t, addr.Value(), api.ServiceAddress{Port: defaultGatewayPort})
|
|
})
|
|
|
|
t.Run("set value", func(t *testing.T) {
|
|
addr := &ServiceAddressValue{}
|
|
require.NoError(t, addr.Set("localhost:3333"))
|
|
require.Equal(t, addr.Value(), api.ServiceAddress{
|
|
Address: "localhost",
|
|
Port: 3333,
|
|
})
|
|
})
|
|
}
|
|
|
|
func TestServiceAddressValue_String(t *testing.T) {
|
|
t.Run("nil receiver", func(t *testing.T) {
|
|
var addr *ServiceAddressValue
|
|
require.Equal(t, addr.String(), ":443")
|
|
})
|
|
|
|
t.Run("default value", func(t *testing.T) {
|
|
addr := &ServiceAddressValue{}
|
|
require.Equal(t, addr.String(), ":443")
|
|
})
|
|
|
|
t.Run("set value", func(t *testing.T) {
|
|
addr := &ServiceAddressValue{}
|
|
require.NoError(t, addr.Set("localhost:3333"))
|
|
require.Equal(t, addr.String(), "localhost:3333")
|
|
})
|
|
}
|
|
|
|
func TestServiceAddressValue_Set(t *testing.T) {
|
|
var testcases = []struct {
|
|
name string
|
|
input string
|
|
expectedErr string
|
|
expectedValue api.ServiceAddress
|
|
}{
|
|
{
|
|
name: "default port",
|
|
input: "8.8.8.8:",
|
|
expectedValue: api.ServiceAddress{
|
|
Address: "8.8.8.8",
|
|
Port: defaultGatewayPort,
|
|
},
|
|
},
|
|
{
|
|
name: "valid address",
|
|
input: "8.8.8.8:1234",
|
|
expectedValue: api.ServiceAddress{Address: "8.8.8.8", Port: 1234},
|
|
},
|
|
{
|
|
name: "address with no port",
|
|
input: "8.8.8.8",
|
|
expectedValue: api.ServiceAddress{
|
|
Address: "8.8.8.8",
|
|
Port: defaultGatewayPort,
|
|
},
|
|
},
|
|
{
|
|
name: "invalid addres",
|
|
input: "not-an-ip-address",
|
|
expectedErr: "not an IP address",
|
|
},
|
|
{
|
|
name: "invalid port",
|
|
input: "localhost:notaport",
|
|
expectedErr: `Error parsing port "notaport"`,
|
|
},
|
|
{
|
|
name: "invalid address format",
|
|
input: "too:many:colons",
|
|
expectedErr: "address too:many:colons: too many colons",
|
|
},
|
|
}
|
|
for _, tc := range testcases {
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
addr := &ServiceAddressValue{}
|
|
err := addr.Set(tc.input)
|
|
if tc.expectedErr != "" {
|
|
require.Error(t, err)
|
|
require.Contains(t, err.Error(), tc.expectedErr)
|
|
return
|
|
}
|
|
|
|
require.Equal(t, addr.Value(), tc.expectedValue)
|
|
})
|
|
}
|
|
}
|