2017-09-25 20:40:42 +02:00
|
|
|
package config
|
|
|
|
|
|
|
|
import (
|
2017-10-20 12:02:05 +02:00
|
|
|
"flag"
|
2017-09-25 20:40:42 +02:00
|
|
|
"reflect"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
|
2020-06-02 12:41:25 -04:00
|
|
|
"github.com/stretchr/testify/require"
|
2017-09-25 20:40:42 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// TestParseFlags tests whether command line flags are properly parsed
|
|
|
|
// into the Flags/File structure. It contains an example for every type
|
|
|
|
// that is parsed. It does not test the conversion into the final
|
|
|
|
// runtime configuration. See TestConfig for that.
|
|
|
|
func TestParseFlags(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
args []string
|
|
|
|
flags Flags
|
|
|
|
err error
|
|
|
|
}{
|
|
|
|
{},
|
|
|
|
{
|
|
|
|
args: []string{`-bind`, `a`},
|
|
|
|
flags: Flags{Config: Config{BindAddr: pString("a")}},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
args: []string{`-bootstrap`},
|
|
|
|
flags: Flags{Config: Config{Bootstrap: pBool(true)}},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
args: []string{`-bootstrap=true`},
|
|
|
|
flags: Flags{Config: Config{Bootstrap: pBool(true)}},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
args: []string{`-bootstrap=false`},
|
|
|
|
flags: Flags{Config: Config{Bootstrap: pBool(false)}},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
args: []string{`-config-file`, `a`, `-config-dir`, `b`, `-config-file`, `c`, `-config-dir`, `d`},
|
|
|
|
flags: Flags{ConfigFiles: []string{"a", "b", "c", "d"}},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
args: []string{`-datacenter`, `a`},
|
|
|
|
flags: Flags{Config: Config{Datacenter: pString("a")}},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
args: []string{`-dns-port`, `1`},
|
|
|
|
flags: Flags{Config: Config{Ports: Ports{DNS: pInt(1)}}},
|
|
|
|
},
|
2018-10-03 14:05:28 +01:00
|
|
|
{
|
|
|
|
args: []string{`-grpc-port`, `1`},
|
|
|
|
flags: Flags{Config: Config{Ports: Ports{GRPC: pInt(1)}}},
|
|
|
|
},
|
2020-01-22 11:32:17 +01:00
|
|
|
{
|
|
|
|
args: []string{`-http-port`, `1`},
|
|
|
|
flags: Flags{Config: Config{Ports: Ports{HTTP: pInt(1)}}},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
args: []string{`-https-port`, `1`},
|
|
|
|
flags: Flags{Config: Config{Ports: Ports{HTTPS: pInt(1)}}},
|
|
|
|
},
|
2018-07-07 03:05:06 +09:00
|
|
|
{
|
|
|
|
args: []string{`-serf-lan-port`, `1`},
|
|
|
|
flags: Flags{Config: Config{Ports: Ports{SerfLAN: pInt(1)}}},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
args: []string{`-serf-wan-port`, `1`},
|
|
|
|
flags: Flags{Config: Config{Ports: Ports{SerfWAN: pInt(1)}}},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
args: []string{`-server-port`, `1`},
|
|
|
|
flags: Flags{Config: Config{Ports: Ports{Server: pInt(1)}}},
|
|
|
|
},
|
2017-09-25 20:40:42 +02:00
|
|
|
{
|
|
|
|
args: []string{`-join`, `a`, `-join`, `b`},
|
|
|
|
flags: Flags{Config: Config{StartJoinAddrsLAN: []string{"a", "b"}}},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
args: []string{`-node-meta`, `a:b`, `-node-meta`, `c:d`},
|
|
|
|
flags: Flags{Config: Config{NodeMeta: map[string]string{"a": "b", "c": "d"}}},
|
|
|
|
},
|
2017-10-20 12:02:05 +02:00
|
|
|
{
|
|
|
|
args: []string{`-bootstrap`, `true`},
|
|
|
|
flags: Flags{Config: Config{Bootstrap: pBool(true)}, Args: []string{"true"}},
|
|
|
|
},
|
2020-03-09 15:59:02 -05:00
|
|
|
{
|
|
|
|
args: []string{`-primary-gateway`, `foo.local`, `-primary-gateway`, `bar.local`},
|
|
|
|
flags: Flags{Config: Config{PrimaryGateways: []string{
|
|
|
|
"foo.local", "bar.local",
|
|
|
|
}}},
|
|
|
|
},
|
2017-09-25 20:40:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(strings.Join(tt.args, " "), func(t *testing.T) {
|
2017-10-20 12:02:05 +02:00
|
|
|
flags := Flags{}
|
|
|
|
fs := flag.NewFlagSet("", flag.ContinueOnError)
|
|
|
|
AddFlags(fs, &flags)
|
|
|
|
err := fs.Parse(tt.args)
|
2017-09-25 20:40:42 +02:00
|
|
|
if got, want := err, tt.err; !reflect.DeepEqual(got, want) {
|
|
|
|
t.Fatalf("got error %v want %v", got, want)
|
|
|
|
}
|
2017-10-20 12:02:05 +02:00
|
|
|
flags.Args = fs.Args()
|
2020-06-02 12:41:25 -04:00
|
|
|
|
|
|
|
// Normalize the expected value because require.Equal considers
|
|
|
|
// empty slices/maps and nil slices/maps to be different.
|
|
|
|
if len(tt.flags.Args) == 0 && flags.Args != nil {
|
|
|
|
tt.flags.Args = []string{}
|
|
|
|
}
|
|
|
|
if len(tt.flags.Config.NodeMeta) == 0 {
|
|
|
|
tt.flags.Config.NodeMeta = map[string]string{}
|
2017-09-25 20:40:42 +02:00
|
|
|
}
|
2020-06-02 12:41:25 -04:00
|
|
|
|
|
|
|
require.Equal(t, tt.flags, flags)
|
2017-09-25 20:40:42 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|