Ensure MultiError returned when both Before and After funcs given

This commit is contained in:
Dan Buch 2016-04-28 17:15:16 -04:00
parent 61d4175525
commit 4cae17cfe1
No known key found for this signature in database
GPG Key ID: FAEF12936DD3E3EC
3 changed files with 38 additions and 10 deletions

18
app.go
View File

@ -196,11 +196,12 @@ func (a *App) Run(arguments []string) (err error) {
} }
if a.Before != nil { if a.Before != nil {
err = a.Before(context) beforeErr := a.Before(context)
if err != nil { if beforeErr != nil {
fmt.Fprintf(a.Writer, "%v\n\n", err) fmt.Fprintf(a.Writer, "%v\n\n", beforeErr)
ShowAppHelp(context) ShowAppHelp(context)
HandleExitCoder(err) HandleExitCoder(beforeErr)
err = beforeErr
return err return err
} }
} }
@ -286,7 +287,7 @@ func (a *App) RunAsSubcommand(ctx *Context) (err error) {
if a.OnUsageError != nil { if a.OnUsageError != nil {
err = a.OnUsageError(context, err, true) err = a.OnUsageError(context, err, true)
HandleExitCoder(err) HandleExitCoder(err)
return nil return err
} else { } else {
fmt.Fprintf(a.Writer, "%s\n\n", "Incorrect Usage.") fmt.Fprintf(a.Writer, "%s\n\n", "Incorrect Usage.")
ShowSubcommandHelp(context) ShowSubcommandHelp(context)
@ -319,9 +320,10 @@ func (a *App) RunAsSubcommand(ctx *Context) (err error) {
} }
if a.Before != nil { if a.Before != nil {
err = a.Before(context) beforeErr := a.Before(context)
if err != nil { if beforeErr != nil {
HandleExitCoder(err) HandleExitCoder(beforeErr)
err = beforeErr
return err return err
} }
} }

View File

@ -522,6 +522,30 @@ func TestApp_BeforeFunc(t *testing.T) {
if counts.SubCommand != 0 { if counts.SubCommand != 0 {
t.Errorf("Subcommand executed when NOT expected") t.Errorf("Subcommand executed when NOT expected")
} }
// reset
counts = &opCounts{}
afterError := errors.New("fail again")
app.After = func(_ *Context) error {
return afterError
}
// run with the Before() func failing, wrapped by After()
err = app.Run([]string{"command", "--opt", "fail", "sub"})
// should be the same error produced by the Before func
if _, ok := err.(MultiError); !ok {
t.Errorf("MultiError expected, but not received")
}
if counts.Before != 1 {
t.Errorf("Before() not executed when expected")
}
if counts.SubCommand != 0 {
t.Errorf("Subcommand executed when NOT expected")
}
} }
func TestApp_AfterFunc(t *testing.T) { func TestApp_AfterFunc(t *testing.T) {
@ -735,9 +759,10 @@ func TestApp_OrderOfOperations(t *testing.T) {
}, },
} }
app.Action = func(c *Context) { app.Action = func(c *Context) error {
counts.Total++ counts.Total++
counts.Action = counts.Total counts.Action = counts.Total
return nil
} }
_ = app.Run([]string{"command", "--nope"}) _ = app.Run([]string{"command", "--nope"})

View File

@ -154,9 +154,10 @@ func TestContext_GlobalFlag(t *testing.T) {
app.Flags = []Flag{ app.Flags = []Flag{
StringFlag{Name: "global, g", Usage: "global"}, StringFlag{Name: "global, g", Usage: "global"},
} }
app.Action = func(c *Context) { app.Action = func(c *Context) error {
globalFlag = c.GlobalString("global") globalFlag = c.GlobalString("global")
globalFlagSet = c.GlobalIsSet("global") globalFlagSet = c.GlobalIsSet("global")
return nil
} }
app.Run([]string{"command", "-g", "foo"}) app.Run([]string{"command", "-g", "foo"})
expect(t, globalFlag, "foo") expect(t, globalFlag, "foo")