Use iterative logic to determine missing flag

This commit is contained in:
Ajitem Sahasrabuddhe 2019-09-11 14:34:41 +05:30
parent 1547ac2f6a
commit c6ee3b4904
No known key found for this signature in database
GPG Key ID: 5B0EE10DAA76876C
2 changed files with 19 additions and 9 deletions

View File

@ -313,18 +313,21 @@ func checkRequiredFlags(flags []Flag, context *Context) requiredFlagsErr {
var missingFlags []string
for _, f := range flags {
if rf, ok := f.(RequiredFlag); ok && rf.IsRequired() {
key := strings.Split(f.GetName(), ",")
var flagPresent bool
var flagName string
for _, key := range strings.Split(f.GetName(), ",") {
if len(key) > 1 {
// has short name
if !context.IsSet(strings.TrimSpace(key[0])) && !context.IsSet(strings.TrimSpace(key[1])) {
missingFlags = append(missingFlags, key[0])
flagName = key
}
} else {
// does not have short name
if !context.IsSet(strings.TrimSpace(key[0])) {
missingFlags = append(missingFlags, key[0])
if context.IsSet(strings.TrimSpace(key)) {
flagPresent = true
}
}
if !flagPresent {
missingFlags = append(missingFlags, flagName)
}
}
}

View File

@ -524,6 +524,13 @@ func TestCheckRequiredFlags(t *testing.T) {
},
parseInput: []string{"-N", "asd", "-N", "qwe"},
},
{
testCase: "required_flag_with_short_name",
flags: []Flag{
StringSliceFlag{Name: "names, N, n", Required: true},
},
parseInput: []string{"-n", "asd", "-n", "qwe"},
},
}
for _, test := range tdata {
t.Run(test.testCase, func(t *testing.T) {