diff options
| author | Eric Paris <[email protected]> | 2015-08-12 10:19:24 -0500 |
|---|---|---|
| committer | Eric Paris <[email protected]> | 2015-08-12 10:19:24 -0500 |
| commit | 4869ec2ae0628354eaac5bf88fccf9a7265ae475 (patch) | |
| tree | a512d39ec0822c7a5ff3b0960b0b16894f2df007 /string_slice_test.go | |
| parent | 978c009ee41c0f14bd0c0e2927ae81713cc65864 (diff) | |
| parent | 95a6a40798df11df014298af8a8250af515fa753 (diff) | |
Merge pull request #41 from eparis/fix-slice-defaults
Do not append to default values in {String,Int}Slice
Diffstat (limited to 'string_slice_test.go')
| -rw-r--r-- | string_slice_test.go | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/string_slice_test.go b/string_slice_test.go index 63eb9de..e8847d5 100644 --- a/string_slice_test.go +++ b/string_slice_test.go @@ -16,6 +16,12 @@ func setUpSSFlagSet(ssp *[]string) *FlagSet { return f } +func setUpSSFlagSetWithDefault(ssp *[]string) *FlagSet { + f := NewFlagSet("test", ContinueOnError) + f.StringSliceVar(ssp, "ss", []string{"default", "values"}, "Command seperated list!") + return f +} + func TestEmptySS(t *testing.T) { var ss []string f := setUpSSFlagSet(&ss) @@ -60,6 +66,60 @@ func TestSS(t *testing.T) { } } +func TestSSDefault(t *testing.T) { + var ss []string + f := setUpSSFlagSetWithDefault(&ss) + + vals := []string{"default", "values"} + + err := f.Parse([]string{}) + if err != nil { + t.Fatal("expected no error; got", err) + } + for i, v := range ss { + if vals[i] != v { + t.Fatalf("expected ss[%d] to be %s but got: %s", i, vals[i], v) + } + } + + getSS, err := f.GetStringSlice("ss") + if err != nil { + t.Fatal("got an error from GetStringSlice():", err) + } + for i, v := range getSS { + if vals[i] != v { + t.Fatalf("expected ss[%d] to be %s from GetStringSlice but got: %s", i, vals[i], v) + } + } +} + +func TestSSWithDefault(t *testing.T) { + var ss []string + f := setUpSSFlagSetWithDefault(&ss) + + vals := []string{"one", "two", "4", "3"} + arg := fmt.Sprintf("--ss=%s", strings.Join(vals, ",")) + err := f.Parse([]string{arg}) + if err != nil { + t.Fatal("expected no error; got", err) + } + for i, v := range ss { + if vals[i] != v { + t.Fatalf("expected ss[%d] to be %s but got: %s", i, vals[i], v) + } + } + + getSS, err := f.GetStringSlice("ss") + if err != nil { + t.Fatal("got an error from GetStringSlice():", err) + } + for i, v := range getSS { + if vals[i] != v { + t.Fatalf("expected ss[%d] to be %s from GetStringSlice but got: %s", i, vals[i], v) + } + } +} + func TestSSCalledTwice(t *testing.T) { var ss []string f := setUpSSFlagSet(&ss) |
