JMS #4: Flag testing
This commit is contained in:
parent
3f76896c4f
commit
3119b075d6
4
cli.go
4
cli.go
@ -21,8 +21,8 @@ var Action = ShowHelp
|
|||||||
|
|
||||||
func Run(args []string) {
|
func Run(args []string) {
|
||||||
|
|
||||||
set := flagSet(Flags)
|
set := flagSet(Flags)
|
||||||
set.Parse(args[1:])
|
set.Parse(args[1:])
|
||||||
|
|
||||||
context := NewContext(set)
|
context := NewContext(set)
|
||||||
if len(args) > 1 {
|
if len(args) > 1 {
|
||||||
|
39
cli_test.go
39
cli_test.go
@ -1,22 +1,39 @@
|
|||||||
package cli
|
package cli
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"reflect"
|
"reflect"
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
func Test_SimpleCLIFlags(t *testing.T) {
|
func Test_SettingFlags(t *testing.T) {
|
||||||
Flags = []Flag{
|
Flags = []Flag{
|
||||||
StringFlag{"foo", "default", "a foo flag"},
|
StringFlag{"foo", "default", "a string flag"},
|
||||||
}
|
IntFlag{"bar", 42, "an int flag"},
|
||||||
Action = func(c *Context) {
|
BoolFlag{"bat", "a bool flag"},
|
||||||
expect(t, c.String("foo"), "hello world")
|
}
|
||||||
}
|
Action = func(c *Context) {
|
||||||
Run([]string{ "command", "--foo", "hello world" })
|
expect(t, c.String("foo"), "hello world")
|
||||||
|
expect(t, c.Int("bar"), 245)
|
||||||
|
expect(t, c.Bool("bat"), true)
|
||||||
|
}
|
||||||
|
Run([]string{"command", "--foo", "hello world", "--bar", "245", "--bat"})
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Helpers */
|
func Test_FlagDefaults(t *testing.T) {
|
||||||
|
Flags = []Flag{
|
||||||
|
StringFlag{"foo", "default", "a string flag"},
|
||||||
|
IntFlag{"bar", 42, "an int flag"},
|
||||||
|
BoolFlag{"bat", "a bool flag"},
|
||||||
|
}
|
||||||
|
Action = func(c *Context) {
|
||||||
|
expect(t, c.String("foo"), "default")
|
||||||
|
expect(t, c.Int("bar"), 42)
|
||||||
|
expect(t, c.Bool("bat"), false)
|
||||||
|
}
|
||||||
|
Run([]string{"command"})
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Test Helpers */
|
||||||
func expect(t *testing.T, a interface{}, b interface{}) {
|
func expect(t *testing.T, a interface{}, b interface{}) {
|
||||||
if a != b {
|
if a != b {
|
||||||
t.Errorf("Expected %v (type %v) - Got %v (type %v)", b, reflect.TypeOf(b), a, reflect.TypeOf(a))
|
t.Errorf("Expected %v (type %v) - Got %v (type %v)", b, reflect.TypeOf(b), a, reflect.TypeOf(a))
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
package cli
|
package cli
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
func Test_True(t *testing.T) {
|
func Test_True(t *testing.T) {
|
||||||
expect(t, true, true)
|
expect(t, true, true)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Test_Run(t *testing.T) {
|
func Test_Run(t *testing.T) {
|
||||||
|
@ -1,36 +1,36 @@
|
|||||||
package cli
|
package cli
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"flag"
|
"flag"
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
func Test_Int(t *testing.T) {
|
func Test_Int(t *testing.T) {
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
set.Int("myflag", 12, "doc")
|
set.Int("myflag", 12, "doc")
|
||||||
c := NewContext(set)
|
c := NewContext(set)
|
||||||
expect(t, c.Int("myflag"), 12)
|
expect(t, c.Int("myflag"), 12)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Test_String(t *testing.T) {
|
func Test_String(t *testing.T) {
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
set.String("myflag", "hello world", "doc")
|
set.String("myflag", "hello world", "doc")
|
||||||
c := NewContext(set)
|
c := NewContext(set)
|
||||||
expect(t, c.String("myflag"), "hello world")
|
expect(t, c.String("myflag"), "hello world")
|
||||||
}
|
}
|
||||||
|
|
||||||
func Test_Bool(t *testing.T) {
|
func Test_Bool(t *testing.T) {
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
set.Bool("myflag", false, "doc")
|
set.Bool("myflag", false, "doc")
|
||||||
c := NewContext(set)
|
c := NewContext(set)
|
||||||
expect(t, c.Bool("myflag"), false)
|
expect(t, c.Bool("myflag"), false)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Test_Args(t *testing.T) {
|
func Test_Args(t *testing.T) {
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
set.Bool("myflag", false, "doc")
|
set.Bool("myflag", false, "doc")
|
||||||
c := NewContext(set)
|
c := NewContext(set)
|
||||||
set.Parse([]string{"--myflag", "bat", "baz"})
|
set.Parse([]string{"--myflag", "bat", "baz"})
|
||||||
expect(t, len(c.Args()), 2)
|
expect(t, len(c.Args()), 2)
|
||||||
expect(t, c.Bool("myflag"), true)
|
expect(t, c.Bool("myflag"), true)
|
||||||
}
|
}
|
||||||
|
82
flag.go
82
flag.go
@ -4,41 +4,55 @@ import "fmt"
|
|||||||
import "flag"
|
import "flag"
|
||||||
|
|
||||||
type Flag interface {
|
type Flag interface {
|
||||||
fmt.Stringer
|
fmt.Stringer
|
||||||
Apply(*flag.FlagSet)
|
Apply(*flag.FlagSet)
|
||||||
}
|
|
||||||
|
|
||||||
type BoolFlag struct {
|
|
||||||
Name string
|
|
||||||
Usage string
|
|
||||||
}
|
|
||||||
|
|
||||||
type StringFlag struct {
|
|
||||||
Name string
|
|
||||||
Value string
|
|
||||||
Usage string
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f StringFlag) String() string {
|
|
||||||
return fmt.Sprintf("--%v 'string'\t%v", f.Name, f.Usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f StringFlag) Apply(set *flag.FlagSet) {
|
|
||||||
set.String(f.Name, f.Value, f.Usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f BoolFlag) String() string {
|
|
||||||
return fmt.Sprintf("--%v\t%v", f.Name, f.Usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f BoolFlag) Apply(set *flag.FlagSet) {
|
|
||||||
set.Bool(f.Name, false, f.Usage)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func flagSet(flags []Flag) *flag.FlagSet {
|
func flagSet(flags []Flag) *flag.FlagSet {
|
||||||
set := flag.NewFlagSet(Name, flag.ExitOnError)
|
set := flag.NewFlagSet(Name, flag.ExitOnError)
|
||||||
for _, f := range flags {
|
for _, f := range flags {
|
||||||
f.Apply(set)
|
f.Apply(set)
|
||||||
}
|
}
|
||||||
return set
|
return set
|
||||||
|
}
|
||||||
|
|
||||||
|
type BoolFlag struct {
|
||||||
|
Name string
|
||||||
|
Usage string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f BoolFlag) String() string {
|
||||||
|
return fmt.Sprintf("--%v\t%v", f.Name, f.Usage)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f BoolFlag) Apply(set *flag.FlagSet) {
|
||||||
|
set.Bool(f.Name, false, f.Usage)
|
||||||
|
}
|
||||||
|
|
||||||
|
type StringFlag struct {
|
||||||
|
Name string
|
||||||
|
Value string
|
||||||
|
Usage string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f StringFlag) String() string {
|
||||||
|
return fmt.Sprintf("--%v '%v'\t%v", f.Name, f.Value, f.Usage)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f StringFlag) Apply(set *flag.FlagSet) {
|
||||||
|
set.String(f.Name, f.Value, f.Usage)
|
||||||
|
}
|
||||||
|
|
||||||
|
type IntFlag struct {
|
||||||
|
Name string
|
||||||
|
Value int
|
||||||
|
Usage string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f IntFlag) String() string {
|
||||||
|
return fmt.Sprintf("--%v '%v'\t%v", f.Name, f.Value, f.Usage)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f IntFlag) Apply(set *flag.FlagSet) {
|
||||||
|
set.Int(f.Name, f.Value, f.Usage)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user