forked from TrueCloudLab/restic
233 lines
5.6 KiB
Go
233 lines
5.6 KiB
Go
// Copyright 2009 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package pflag
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
)
|
|
|
|
func setUpSAFlagSet(sap *[]string) *FlagSet {
|
|
f := NewFlagSet("test", ContinueOnError)
|
|
f.StringArrayVar(sap, "sa", []string{}, "Command separated list!")
|
|
return f
|
|
}
|
|
|
|
func setUpSAFlagSetWithDefault(sap *[]string) *FlagSet {
|
|
f := NewFlagSet("test", ContinueOnError)
|
|
f.StringArrayVar(sap, "sa", []string{"default", "values"}, "Command separated list!")
|
|
return f
|
|
}
|
|
|
|
func TestEmptySA(t *testing.T) {
|
|
var sa []string
|
|
f := setUpSAFlagSet(&sa)
|
|
err := f.Parse([]string{})
|
|
if err != nil {
|
|
t.Fatal("expected no error; got", err)
|
|
}
|
|
|
|
getSA, err := f.GetStringArray("sa")
|
|
if err != nil {
|
|
t.Fatal("got an error from GetStringArray():", err)
|
|
}
|
|
if len(getSA) != 0 {
|
|
t.Fatalf("got sa %v with len=%d but expected length=0", getSA, len(getSA))
|
|
}
|
|
}
|
|
|
|
func TestEmptySAValue(t *testing.T) {
|
|
var sa []string
|
|
f := setUpSAFlagSet(&sa)
|
|
err := f.Parse([]string{"--sa="})
|
|
if err != nil {
|
|
t.Fatal("expected no error; got", err)
|
|
}
|
|
|
|
getSA, err := f.GetStringArray("sa")
|
|
if err != nil {
|
|
t.Fatal("got an error from GetStringArray():", err)
|
|
}
|
|
if len(getSA) != 0 {
|
|
t.Fatalf("got sa %v with len=%d but expected length=0", getSA, len(getSA))
|
|
}
|
|
}
|
|
|
|
func TestSADefault(t *testing.T) {
|
|
var sa []string
|
|
f := setUpSAFlagSetWithDefault(&sa)
|
|
|
|
vals := []string{"default", "values"}
|
|
|
|
err := f.Parse([]string{})
|
|
if err != nil {
|
|
t.Fatal("expected no error; got", err)
|
|
}
|
|
for i, v := range sa {
|
|
if vals[i] != v {
|
|
t.Fatalf("expected sa[%d] to be %s but got: %s", i, vals[i], v)
|
|
}
|
|
}
|
|
|
|
getSA, err := f.GetStringArray("sa")
|
|
if err != nil {
|
|
t.Fatal("got an error from GetStringArray():", err)
|
|
}
|
|
for i, v := range getSA {
|
|
if vals[i] != v {
|
|
t.Fatalf("expected sa[%d] to be %s from GetStringArray but got: %s", i, vals[i], v)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestSAWithDefault(t *testing.T) {
|
|
var sa []string
|
|
f := setUpSAFlagSetWithDefault(&sa)
|
|
|
|
val := "one"
|
|
arg := fmt.Sprintf("--sa=%s", val)
|
|
err := f.Parse([]string{arg})
|
|
if err != nil {
|
|
t.Fatal("expected no error; got", err)
|
|
}
|
|
|
|
if len(sa) != 1 {
|
|
t.Fatalf("expected number of values to be %d but %d", 1, len(sa))
|
|
}
|
|
|
|
if sa[0] != val {
|
|
t.Fatalf("expected value to be %s but got: %s", sa[0], val)
|
|
}
|
|
|
|
getSA, err := f.GetStringArray("sa")
|
|
if err != nil {
|
|
t.Fatal("got an error from GetStringArray():", err)
|
|
}
|
|
|
|
if len(getSA) != 1 {
|
|
t.Fatalf("expected number of values to be %d but %d", 1, len(getSA))
|
|
}
|
|
|
|
if getSA[0] != val {
|
|
t.Fatalf("expected value to be %s but got: %s", getSA[0], val)
|
|
}
|
|
}
|
|
|
|
func TestSACalledTwice(t *testing.T) {
|
|
var sa []string
|
|
f := setUpSAFlagSet(&sa)
|
|
|
|
in := []string{"one", "two"}
|
|
expected := []string{"one", "two"}
|
|
argfmt := "--sa=%s"
|
|
arg1 := fmt.Sprintf(argfmt, in[0])
|
|
arg2 := fmt.Sprintf(argfmt, in[1])
|
|
err := f.Parse([]string{arg1, arg2})
|
|
if err != nil {
|
|
t.Fatal("expected no error; got", err)
|
|
}
|
|
|
|
if len(expected) != len(sa) {
|
|
t.Fatalf("expected number of sa to be %d but got: %d", len(expected), len(sa))
|
|
}
|
|
for i, v := range sa {
|
|
if expected[i] != v {
|
|
t.Fatalf("expected sa[%d] to be %s but got: %s", i, expected[i], v)
|
|
}
|
|
}
|
|
|
|
values, err := f.GetStringArray("sa")
|
|
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(sa))
|
|
}
|
|
for i, v := range values {
|
|
if expected[i] != v {
|
|
t.Fatalf("expected got sa[%d] to be %s but got: %s", i, expected[i], v)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestSAWithSpecialChar(t *testing.T) {
|
|
var sa []string
|
|
f := setUpSAFlagSet(&sa)
|
|
|
|
in := []string{"one,two", `"three"`, `"four,five",six`, "seven eight"}
|
|
expected := []string{"one,two", `"three"`, `"four,five",six`, "seven eight"}
|
|
argfmt := "--sa=%s"
|
|
arg1 := fmt.Sprintf(argfmt, in[0])
|
|
arg2 := fmt.Sprintf(argfmt, in[1])
|
|
arg3 := fmt.Sprintf(argfmt, in[2])
|
|
arg4 := fmt.Sprintf(argfmt, in[3])
|
|
err := f.Parse([]string{arg1, arg2, arg3, arg4})
|
|
if err != nil {
|
|
t.Fatal("expected no error; got", err)
|
|
}
|
|
|
|
if len(expected) != len(sa) {
|
|
t.Fatalf("expected number of sa to be %d but got: %d", len(expected), len(sa))
|
|
}
|
|
for i, v := range sa {
|
|
if expected[i] != v {
|
|
t.Fatalf("expected sa[%d] to be %s but got: %s", i, expected[i], v)
|
|
}
|
|
}
|
|
|
|
values, err := f.GetStringArray("sa")
|
|
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 sa[%d] to be %s but got: %s", i, expected[i], v)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestSAWithSquareBrackets(t *testing.T) {
|
|
var sa []string
|
|
f := setUpSAFlagSet(&sa)
|
|
|
|
in := []string{"][]-[", "[a-z]", "[a-z]+"}
|
|
expected := []string{"][]-[", "[a-z]", "[a-z]+"}
|
|
argfmt := "--sa=%s"
|
|
arg1 := fmt.Sprintf(argfmt, in[0])
|
|
arg2 := fmt.Sprintf(argfmt, in[1])
|
|
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(sa) {
|
|
t.Fatalf("expected number of sa to be %d but got: %d", len(expected), len(sa))
|
|
}
|
|
for i, v := range sa {
|
|
if expected[i] != v {
|
|
t.Fatalf("expected sa[%d] to be %s but got: %s", i, expected[i], v)
|
|
}
|
|
}
|
|
|
|
values, err := f.GetStringArray("sa")
|
|
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 sa[%d] to be %s but got: %s", i, expected[i], v)
|
|
}
|
|
}
|
|
}
|