2015-07-20 19:18:25 +00:00
|
|
|
package cli
|
2014-04-14 21:44:32 +00:00
|
|
|
|
|
|
|
import (
|
2015-10-27 20:33:55 +00:00
|
|
|
"errors"
|
2014-06-18 05:33:30 +00:00
|
|
|
"flag"
|
2015-12-25 20:45:58 +00:00
|
|
|
"fmt"
|
2016-02-04 07:25:41 +00:00
|
|
|
"io/ioutil"
|
2015-12-25 20:45:58 +00:00
|
|
|
"strings"
|
2016-02-04 07:25:41 +00:00
|
|
|
"testing"
|
2014-04-14 21:44:32 +00:00
|
|
|
)
|
|
|
|
|
2015-10-27 20:33:55 +00:00
|
|
|
func TestCommandFlagParsing(t *testing.T) {
|
|
|
|
cases := []struct {
|
|
|
|
testArgs []string
|
|
|
|
skipFlagParsing bool
|
|
|
|
expectedErr error
|
|
|
|
}{
|
2016-05-07 23:36:54 +00:00
|
|
|
{[]string{"test-cmd", "-break", "blah", "blah"}, false, errors.New("flag provided but not defined: -break")}, // Test normal "not ignoring flags" flow
|
|
|
|
{[]string{"test-cmd", "blah", "blah"}, true, nil}, // Test SkipFlagParsing without any args that look like flags
|
|
|
|
{[]string{"test-cmd", "-break", "blah"}, true, nil}, // Test SkipFlagParsing with random flag arg
|
|
|
|
{[]string{"test-cmd", "-help", "blah"}, true, nil}, // Test SkipFlagParsing with "special" help flag arg
|
2014-04-14 21:44:32 +00:00
|
|
|
}
|
|
|
|
|
2015-10-27 20:33:55 +00:00
|
|
|
for _, c := range cases {
|
2016-06-22 16:47:57 +00:00
|
|
|
app := &App{Writer: ioutil.Discard}
|
2015-10-27 20:33:55 +00:00
|
|
|
set := flag.NewFlagSet("test", 0)
|
|
|
|
set.Parse(c.testArgs)
|
2014-04-14 21:44:32 +00:00
|
|
|
|
2015-10-27 20:33:55 +00:00
|
|
|
context := NewContext(app, set, nil)
|
2014-04-14 21:44:32 +00:00
|
|
|
|
2015-10-27 20:33:55 +00:00
|
|
|
command := Command{
|
|
|
|
Name: "test-cmd",
|
|
|
|
Aliases: []string{"tc"},
|
|
|
|
Usage: "this is for testing",
|
|
|
|
Description: "testing",
|
2016-04-27 13:12:34 +00:00
|
|
|
Action: func(_ *Context) error { return nil },
|
2015-10-27 20:33:55 +00:00
|
|
|
}
|
2015-09-25 21:13:36 +00:00
|
|
|
|
2015-10-27 20:33:55 +00:00
|
|
|
command.SkipFlagParsing = c.skipFlagParsing
|
2015-09-25 21:13:36 +00:00
|
|
|
|
2016-04-27 13:12:34 +00:00
|
|
|
err := command.Run(context)
|
2015-09-25 21:13:36 +00:00
|
|
|
|
2015-10-27 20:33:55 +00:00
|
|
|
expect(t, err, c.expectedErr)
|
2016-05-22 19:20:52 +00:00
|
|
|
expect(t, context.Args().Slice(), c.testArgs)
|
2015-09-25 21:13:36 +00:00
|
|
|
}
|
|
|
|
}
|
2015-12-25 20:45:58 +00:00
|
|
|
|
|
|
|
func TestCommand_Run_DoesNotOverwriteErrorFromBefore(t *testing.T) {
|
2016-06-22 16:47:57 +00:00
|
|
|
app := &App{
|
|
|
|
Commands: []*Command{
|
|
|
|
{
|
|
|
|
Name: "bar",
|
|
|
|
Before: func(c *Context) error {
|
|
|
|
return fmt.Errorf("before error")
|
|
|
|
},
|
|
|
|
After: func(c *Context) error {
|
|
|
|
return fmt.Errorf("after error")
|
|
|
|
},
|
2016-04-25 22:10:10 +00:00
|
|
|
},
|
2015-12-25 20:45:58 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2016-04-27 13:12:34 +00:00
|
|
|
err := app.Run([]string{"foo", "bar"})
|
2015-12-25 20:45:58 +00:00
|
|
|
if err == nil {
|
2016-01-20 09:56:46 +00:00
|
|
|
t.Fatalf("expected to receive error from Run, got none")
|
2015-12-25 20:45:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if !strings.Contains(err.Error(), "before error") {
|
|
|
|
t.Errorf("expected text of error from Before method, but got none in \"%v\"", err)
|
|
|
|
}
|
|
|
|
if !strings.Contains(err.Error(), "after error") {
|
|
|
|
t.Errorf("expected text of error from After method, but got none in \"%v\"", err)
|
|
|
|
}
|
|
|
|
}
|
2016-01-23 11:47:24 +00:00
|
|
|
|
|
|
|
func TestCommand_OnUsageError_WithWrongFlagValue(t *testing.T) {
|
2016-06-22 16:47:57 +00:00
|
|
|
app := &App{
|
|
|
|
Commands: []*Command{
|
|
|
|
{
|
|
|
|
Name: "bar",
|
|
|
|
Flags: []Flag{
|
|
|
|
&IntFlag{Name: "flag"},
|
|
|
|
},
|
|
|
|
OnUsageError: func(c *Context, err error, _ bool) error {
|
|
|
|
if !strings.HasPrefix(err.Error(), "invalid value \"wrong\"") {
|
|
|
|
t.Errorf("Expect an invalid value error, but got \"%v\"", err)
|
|
|
|
}
|
|
|
|
return errors.New("intercepted: " + err.Error())
|
|
|
|
},
|
2016-01-23 11:47:24 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2016-04-27 13:12:34 +00:00
|
|
|
err := app.Run([]string{"foo", "bar", "--flag=wrong"})
|
2016-01-23 11:47:24 +00:00
|
|
|
if err == nil {
|
|
|
|
t.Fatalf("expected to receive error from Run, got none")
|
|
|
|
}
|
|
|
|
|
|
|
|
if !strings.HasPrefix(err.Error(), "intercepted: invalid value") {
|
|
|
|
t.Errorf("Expect an intercepted error, but got \"%v\"", err)
|
|
|
|
}
|
|
|
|
}
|