Clarifying errors returned from HandleAction + tests
This commit is contained in:
parent
271b56c71b
commit
b453bf5940
27
app.go
27
app.go
@ -12,12 +12,14 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
appActionDeprecationURL = "https://github.com/codegangsta/cli/blob/master/CHANGELOG.md#deprecated-cli-app-action-signature"
|
||||||
|
|
||||||
errNonFuncAction = NewExitError("ERROR invalid Action type. "+
|
errNonFuncAction = NewExitError("ERROR invalid Action type. "+
|
||||||
"Must be a func of type `cli.ActionFunc`. "+
|
"Must be a func of type `cli.ActionFunc`. "+
|
||||||
"See https://github.com/codegangsta/cli/blob/master/CHANGELOG.md#deprecated-cli-app-action-signature", 2)
|
fmt.Sprintf("See %s", appActionDeprecationURL), 2)
|
||||||
errInvalidActionSignature = NewExitError("ERROR invalid Action signature. "+
|
errInvalidActionSignature = NewExitError("ERROR invalid Action signature. "+
|
||||||
"Must be `cli.ActionFunc`. "+
|
"Must be `cli.ActionFunc`. "+
|
||||||
"See https://github.com/codegangsta/cli/blob/master/CHANGELOG.md#deprecated-cli-app-action-signature", 2)
|
fmt.Sprintf("See %s", appActionDeprecationURL), 2)
|
||||||
)
|
)
|
||||||
|
|
||||||
// App is the main structure of a cli application. It is recommended that
|
// App is the main structure of a cli application. It is recommended that
|
||||||
@ -394,7 +396,18 @@ func (a Author) String() string {
|
|||||||
// ActionFunc, a func with the legacy signature for Action, or some other
|
// ActionFunc, a func with the legacy signature for Action, or some other
|
||||||
// invalid thing. If it's an ActionFunc or a func with the legacy signature for
|
// invalid thing. If it's an ActionFunc or a func with the legacy signature for
|
||||||
// Action, the func is run!
|
// Action, the func is run!
|
||||||
func HandleAction(action interface{}, context *Context) error {
|
func HandleAction(action interface{}, context *Context) (err error) {
|
||||||
|
defer func() {
|
||||||
|
if r := recover(); r != nil {
|
||||||
|
switch r.(type) {
|
||||||
|
case error:
|
||||||
|
err = r.(error)
|
||||||
|
default:
|
||||||
|
err = NewExitError(fmt.Sprintf("ERROR unknown Action error: %v. See %s", r, appActionDeprecationURL), 2)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
|
||||||
if reflect.TypeOf(action).Kind() != reflect.Func {
|
if reflect.TypeOf(action).Kind() != reflect.Func {
|
||||||
return errNonFuncAction
|
return errNonFuncAction
|
||||||
}
|
}
|
||||||
@ -404,16 +417,16 @@ func HandleAction(action interface{}, context *Context) error {
|
|||||||
if len(vals) == 0 {
|
if len(vals) == 0 {
|
||||||
fmt.Fprintln(os.Stderr,
|
fmt.Fprintln(os.Stderr,
|
||||||
"DEPRECATED Action signature. Must be `cli.ActionFunc`")
|
"DEPRECATED Action signature. Must be `cli.ActionFunc`")
|
||||||
return nil
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(vals) > 1 {
|
if len(vals) > 1 {
|
||||||
return errInvalidActionSignature
|
return errInvalidActionSignature
|
||||||
}
|
}
|
||||||
|
|
||||||
if err, ok := reflect.ValueOf(vals[0]).Interface().(error); ok {
|
if retErr, ok := reflect.ValueOf(vals[0]).Interface().(error); ok {
|
||||||
return err
|
return retErr
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return err
|
||||||
}
|
}
|
||||||
|
72
app_test.go
72
app_test.go
@ -1115,3 +1115,75 @@ func TestApp_OnUsageError_WithWrongFlagValue_ForSubcommand(t *testing.T) {
|
|||||||
t.Errorf("Expect an intercepted error, but got \"%v\"", err)
|
t.Errorf("Expect an intercepted error, but got \"%v\"", err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestHandleAction_WithNonFuncAction(t *testing.T) {
|
||||||
|
app := NewApp()
|
||||||
|
app.Action = 42
|
||||||
|
err := HandleAction(app.Action, NewContext(app, flagSet(app.Name, app.Flags), nil))
|
||||||
|
|
||||||
|
if err == nil {
|
||||||
|
t.Fatalf("expected to receive error from Run, got none")
|
||||||
|
}
|
||||||
|
|
||||||
|
exitErr, ok := err.(*ExitError)
|
||||||
|
|
||||||
|
if !ok {
|
||||||
|
t.Fatalf("expected to receive a *ExitError")
|
||||||
|
}
|
||||||
|
|
||||||
|
if !strings.HasPrefix(exitErr.Error(), "ERROR invalid Action type") {
|
||||||
|
t.Fatalf("expected an unknown Action error, but got: %v", exitErr.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
if exitErr.ExitCode() != 2 {
|
||||||
|
t.Fatalf("expected error exit code to be 2, but got: %v", exitErr.ExitCode())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestHandleAction_WithInvalidFuncSignature(t *testing.T) {
|
||||||
|
app := NewApp()
|
||||||
|
app.Action = func() string { return "" }
|
||||||
|
err := HandleAction(app.Action, NewContext(app, flagSet(app.Name, app.Flags), nil))
|
||||||
|
|
||||||
|
if err == nil {
|
||||||
|
t.Fatalf("expected to receive error from Run, got none")
|
||||||
|
}
|
||||||
|
|
||||||
|
exitErr, ok := err.(*ExitError)
|
||||||
|
|
||||||
|
if !ok {
|
||||||
|
t.Fatalf("expected to receive a *ExitError")
|
||||||
|
}
|
||||||
|
|
||||||
|
if !strings.HasPrefix(exitErr.Error(), "ERROR unknown Action error") {
|
||||||
|
t.Fatalf("expected an unknown Action error, but got: %v", exitErr.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
if exitErr.ExitCode() != 2 {
|
||||||
|
t.Fatalf("expected error exit code to be 2, but got: %v", exitErr.ExitCode())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestHandleAction_WithInvalidFuncReturnSignature(t *testing.T) {
|
||||||
|
app := NewApp()
|
||||||
|
app.Action = func(_ *Context) (int, error) { return 0, nil }
|
||||||
|
err := HandleAction(app.Action, NewContext(app, flagSet(app.Name, app.Flags), nil))
|
||||||
|
|
||||||
|
if err == nil {
|
||||||
|
t.Fatalf("expected to receive error from Run, got none")
|
||||||
|
}
|
||||||
|
|
||||||
|
exitErr, ok := err.(*ExitError)
|
||||||
|
|
||||||
|
if !ok {
|
||||||
|
t.Fatalf("expected to receive a *ExitError")
|
||||||
|
}
|
||||||
|
|
||||||
|
if !strings.HasPrefix(exitErr.Error(), "ERROR invalid Action signature") {
|
||||||
|
t.Fatalf("expected an invalid Action signature error, but got: %v", exitErr.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
if exitErr.ExitCode() != 2 {
|
||||||
|
t.Fatalf("expected error exit code to be 2, but got: %v", exitErr.ExitCode())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user