Some options
fixes
Add tests for bool type. Fix subtle bug in TestOptionsApplyInvalid. Fix options list formatting.
This commit is contained in:
parent
cb6b0f6255
commit
332b1896d1
2 changed files with 30 additions and 8 deletions
|
@ -23,8 +23,14 @@ Exit status is 0 if the command was successful, and non-zero if there was any er
|
||||||
DisableAutoGenTag: true,
|
DisableAutoGenTag: true,
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
fmt.Printf("All Extended Options:\n")
|
fmt.Printf("All Extended Options:\n")
|
||||||
|
var maxLen int
|
||||||
for _, opt := range options.List() {
|
for _, opt := range options.List() {
|
||||||
fmt.Printf(" %-15s %s\n", opt.Namespace+"."+opt.Name, opt.Text)
|
if l := len(opt.Namespace + "." + opt.Name); l > maxLen {
|
||||||
|
maxLen = l
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for _, opt := range options.List() {
|
||||||
|
fmt.Printf(" %*s %s\n", -maxLen, opt.Namespace+"."+opt.Name, opt.Text)
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
@ -125,6 +125,7 @@ type Target struct {
|
||||||
Name string `option:"name"`
|
Name string `option:"name"`
|
||||||
ID int `option:"id"`
|
ID int `option:"id"`
|
||||||
Timeout time.Duration `option:"timeout"`
|
Timeout time.Duration `option:"timeout"`
|
||||||
|
Switch bool `option:"switch"`
|
||||||
Other string
|
Other string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -155,7 +156,15 @@ var setTests = []struct {
|
||||||
"timeout": "10m3s",
|
"timeout": "10m3s",
|
||||||
},
|
},
|
||||||
Target{
|
Target{
|
||||||
Timeout: time.Duration(10*time.Minute + 3*time.Second),
|
Timeout: 10*time.Minute + 3*time.Second,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Options{
|
||||||
|
"switch": "true",
|
||||||
|
},
|
||||||
|
Target{
|
||||||
|
Switch: true,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -202,6 +211,13 @@ var invalidSetTests = []struct {
|
||||||
"ns",
|
"ns",
|
||||||
`time: missing unit in duration "?2134"?`,
|
`time: missing unit in duration "?2134"?`,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
Options{
|
||||||
|
"switch": "yes",
|
||||||
|
},
|
||||||
|
"ns",
|
||||||
|
`strconv.ParseBool: parsing "yes": invalid syntax`,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestOptionsApplyInvalid(t *testing.T) {
|
func TestOptionsApplyInvalid(t *testing.T) {
|
||||||
|
@ -213,9 +229,9 @@ func TestOptionsApplyInvalid(t *testing.T) {
|
||||||
t.Fatalf("expected error %v not found", test.err)
|
t.Fatalf("expected error %v not found", test.err)
|
||||||
}
|
}
|
||||||
|
|
||||||
matched, err := regexp.MatchString(test.err, err.Error())
|
matched, e := regexp.MatchString(test.err, err.Error())
|
||||||
if err != nil {
|
if e != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(e)
|
||||||
}
|
}
|
||||||
|
|
||||||
if !matched {
|
if !matched {
|
||||||
|
@ -226,11 +242,11 @@ func TestOptionsApplyInvalid(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestListOptions(t *testing.T) {
|
func TestListOptions(t *testing.T) {
|
||||||
var teststruct = struct {
|
teststruct := struct {
|
||||||
Foo string `option:"foo" help:"bar text help"`
|
Foo string `option:"foo" help:"bar text help"`
|
||||||
}{}
|
}{}
|
||||||
|
|
||||||
var tests = []struct {
|
tests := []struct {
|
||||||
cfg interface{}
|
cfg interface{}
|
||||||
opts []Help
|
opts []Help
|
||||||
}{
|
}{
|
||||||
|
@ -281,7 +297,7 @@ func TestListOptions(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestAppendAllOptions(t *testing.T) {
|
func TestAppendAllOptions(t *testing.T) {
|
||||||
var tests = []struct {
|
tests := []struct {
|
||||||
cfgs map[string]interface{}
|
cfgs map[string]interface{}
|
||||||
opts []Help
|
opts []Help
|
||||||
}{
|
}{
|
||||||
|
|
Loading…
Reference in a new issue