diff options
| author | wu8685 <[email protected]> | 2016-08-19 10:41:12 +0800 |
|---|---|---|
| committer | wu8685 <[email protected]> | 2016-08-19 10:41:12 +0800 |
| commit | d68ef7c38c75152f9dac79bc635bd070b70d0913 (patch) | |
| tree | c65cf07d70dfbd07a44366523d988cd567e2659f /string_slice_test.go | |
| parent | 4f9190456aed1c2113ca51ea9b89219747458dc1 (diff) | |
Fix bug in FlagSet.GetStringSlice when a comma in a string slice value
Diffstat (limited to 'string_slice_test.go')
| -rw-r--r-- | string_slice_test.go | 43 |
1 files changed, 40 insertions, 3 deletions
diff --git a/string_slice_test.go b/string_slice_test.go index ed7cbfc..26118c7 100644 --- a/string_slice_test.go +++ b/string_slice_test.go @@ -150,29 +150,66 @@ func TestSSCalledTwice(t *testing.T) { if err != nil { t.Fatal("expected no error; got", err) } + + if len(expected) != len(ss) { + t.Fatalf("expected number of ss to be %d but got: %d", len(expected), len(ss)) + } for i, v := range ss { if expected[i] != v { t.Fatalf("expected ss[%d] to be %s but got: %s", i, expected[i], v) } } + + values, err := f.GetStringSlice("ss") + if err != nil { + t.Fatal("expected no error; got", err) + } + + if len(expected) != len(values) { + t.Fatalf("expected number of values to be %d but got: %d", len(expected), len(ss)) + } + for i, v := range values { + if expected[i] != v { + t.Fatalf("expected got ss[%d] to be %s but got: %s", i, expected[i], v) + } + } } func TestSSWithComma(t *testing.T) { var ss []string f := setUpSSFlagSet(&ss) - in := []string{`"one,two"`, `"three"`} - expected := []string{"one,two", "three"} + in := []string{`"one,two"`, `"three"`, `"four,five",six`} + expected := []string{"one,two", "three", "four,five", "six"} argfmt := "--ss=%s" arg1 := fmt.Sprintf(argfmt, in[0]) arg2 := fmt.Sprintf(argfmt, in[1]) - err := f.Parse([]string{arg1, arg2}) + arg3 := fmt.Sprintf(argfmt, in[2]) + err := f.Parse([]string{arg1, arg2, arg3}) if err != nil { t.Fatal("expected no error; got", err) } + + if len(expected) != len(ss) { + t.Fatalf("expected number of ss to be %d but got: %d", len(expected), len(ss)) + } for i, v := range ss { if expected[i] != v { t.Fatalf("expected ss[%d] to be %s but got: %s", i, expected[i], v) } } + + values, err := f.GetStringSlice("ss") + if err != nil { + t.Fatal("expected no error; got", err) + } + + if len(expected) != len(values) { + t.Fatalf("expected number of values to be %d but got: %d", len(expected), len(values)) + } + for i, v := range values { + if expected[i] != v { + t.Fatalf("expected got ss[%d] to be %s but got: %s", i, expected[i], v) + } + } } |
