summaryrefslogtreecommitdiff
path: root/parse_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'parse_test.go')
-rw-r--r--parse_test.go32
1 files changed, 18 insertions, 14 deletions
diff --git a/parse_test.go b/parse_test.go
index 9ad5944..4037ef5 100644
--- a/parse_test.go
+++ b/parse_test.go
@@ -8,15 +8,19 @@ import (
"github.com/stretchr/testify/require"
)
-func split(s string) []string {
- return strings.Split(s, " ")
+func parse(cmdline string, dest interface{}) error {
+ p, err := NewParser(dest)
+ if err != nil {
+ return err
+ }
+ return p.Parse(strings.Split(cmdline, " "))
}
func TestStringSingle(t *testing.T) {
var args struct {
Foo string
}
- err := ParseFrom(split("--foo bar"), &args)
+ err := parse("--foo bar", &args)
require.NoError(t, err)
assert.Equal(t, "bar", args.Foo)
}
@@ -30,7 +34,7 @@ func TestMixed(t *testing.T) {
Spam float32
}
args.Bar = 3
- err := ParseFrom(split("123 -spam=1.2 -ham -f xyz"), &args)
+ err := parse("123 -spam=1.2 -ham -f xyz", &args)
require.NoError(t, err)
assert.Equal(t, "xyz", args.Foo)
assert.Equal(t, 3, args.Bar)
@@ -43,7 +47,7 @@ func TestRequired(t *testing.T) {
var args struct {
Foo string `arg:"required"`
}
- err := ParseFrom(nil, &args)
+ err := parse("", &args)
require.Error(t, err, "--foo is required")
}
@@ -52,15 +56,15 @@ func TestShortFlag(t *testing.T) {
Foo string `arg:"-f"`
}
- err := ParseFrom(split("-f xyz"), &args)
+ err := parse("-f xyz", &args)
require.NoError(t, err)
assert.Equal(t, "xyz", args.Foo)
- err = ParseFrom(split("-foo xyz"), &args)
+ err = parse("-foo xyz", &args)
require.NoError(t, err)
assert.Equal(t, "xyz", args.Foo)
- err = ParseFrom(split("--foo xyz"), &args)
+ err = parse("--foo xyz", &args)
require.NoError(t, err)
assert.Equal(t, "xyz", args.Foo)
}
@@ -71,7 +75,7 @@ func TestCaseSensitive(t *testing.T) {
Upper bool `arg:"-V"`
}
- err := ParseFrom(split("-v"), &args)
+ err := parse("-v", &args)
require.NoError(t, err)
assert.True(t, args.Lower)
assert.False(t, args.Upper)
@@ -83,7 +87,7 @@ func TestCaseSensitive2(t *testing.T) {
Upper bool `arg:"-V"`
}
- err := ParseFrom(split("-V"), &args)
+ err := parse("-V", &args)
require.NoError(t, err)
assert.False(t, args.Lower)
assert.True(t, args.Upper)
@@ -94,7 +98,7 @@ func TestPositional(t *testing.T) {
Input string `arg:"positional"`
Output string `arg:"positional"`
}
- err := ParseFrom(split("foo"), &args)
+ err := parse("foo", &args)
require.NoError(t, err)
assert.Equal(t, "foo", args.Input)
assert.Equal(t, "", args.Output)
@@ -105,7 +109,7 @@ func TestRequiredPositional(t *testing.T) {
Input string `arg:"positional"`
Output string `arg:"positional,required"`
}
- err := ParseFrom(split("foo"), &args)
+ err := parse("foo", &args)
assert.Error(t, err)
}
@@ -114,7 +118,7 @@ func TestTooManyPositional(t *testing.T) {
Input string `arg:"positional"`
Output string `arg:"positional"`
}
- err := ParseFrom(split("foo bar baz"), &args)
+ err := parse("foo bar baz", &args)
assert.Error(t, err)
}
@@ -123,7 +127,7 @@ func TestMultiple(t *testing.T) {
Foo []int
Bar []string
}
- err := ParseFrom(split("--foo 1 2 3 --bar x y z"), &args)
+ err := parse("--foo 1 2 3 --bar x y z", &args)
require.NoError(t, err)
assert.Equal(t, []int{1, 2, 3}, args.Foo)
assert.Equal(t, []string{"x", "y", "z"}, args.Bar)