Fix regression of SkipFlagParsing behavior

Introduced by df562bf1a8

Was mistakenly prepending the command name.
This commit is contained in:
Jesse Szwedko 2017-12-29 13:38:18 -05:00
parent 39908eb08f
commit e38e4ae2d0
2 changed files with 37 additions and 1 deletions

View File

@ -178,7 +178,7 @@ func (c *Command) parseFlags(args Args) (*flag.FlagSet, error) {
set.SetOutput(ioutil.Discard) set.SetOutput(ioutil.Discard)
if c.SkipFlagParsing { if c.SkipFlagParsing {
return set, set.Parse(append([]string{c.Name, "--"}, args...)) return set, set.Parse(append([]string{"--"}, args...))
} }
if c.UseShortOptionHandling { if c.UseShortOptionHandling {

View File

@ -281,3 +281,39 @@ func TestCommandFlagReordering(t *testing.T) {
expect(t, args, c.expectedArgs) expect(t, args, c.expectedArgs)
} }
} }
func TestCommandSkipFlagParsing(t *testing.T) {
cases := []struct {
testArgs []string
expectedArgs []string
expectedErr error
}{
{[]string{"some-exec", "some-command", "some-arg", "--flag", "foo"}, []string{"some-arg", "--flag", "foo"}, nil},
{[]string{"some-exec", "some-command", "some-arg", "--flag=foo"}, []string{"some-arg", "--flag=foo"}, nil},
}
for _, c := range cases {
value := ""
args := []string{}
app := &App{
Commands: []Command{
{
SkipFlagParsing: true,
Name: "some-command",
Flags: []Flag{
StringFlag{Name: "flag"},
},
Action: func(c *Context) {
fmt.Printf("%+v\n", c.String("flag"))
value = c.String("flag")
args = c.Args()
},
},
},
}
err := app.Run(c.testArgs)
expect(t, err, c.expectedErr)
expect(t, args, c.expectedArgs)
}
}