2019-11-29 13:09:46 +00:00
|
|
|
package cli
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestSuggestFlag(t *testing.T) {
|
|
|
|
// Given
|
|
|
|
app := testApp()
|
|
|
|
|
|
|
|
for _, testCase := range []struct {
|
|
|
|
provided, expected string
|
|
|
|
}{
|
|
|
|
{"", ""},
|
|
|
|
{"a", "--another-flag"},
|
|
|
|
{"hlp", "--help"},
|
|
|
|
{"k", ""},
|
|
|
|
{"s", "-s"},
|
|
|
|
} {
|
|
|
|
// When
|
2022-05-14 12:24:44 +00:00
|
|
|
res := suggestFlag(app.Flags, testCase.provided, false)
|
2019-11-29 13:09:46 +00:00
|
|
|
|
|
|
|
// Then
|
|
|
|
expect(t, res, testCase.expected)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSuggestFlagHideHelp(t *testing.T) {
|
|
|
|
// Given
|
|
|
|
app := testApp()
|
|
|
|
|
|
|
|
// When
|
2022-05-14 12:24:44 +00:00
|
|
|
res := suggestFlag(app.Flags, "hlp", true)
|
2019-11-29 13:09:46 +00:00
|
|
|
|
|
|
|
// Then
|
|
|
|
expect(t, res, "--fl")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSuggestFlagFromError(t *testing.T) {
|
|
|
|
// Given
|
|
|
|
app := testApp()
|
|
|
|
|
|
|
|
for _, testCase := range []struct {
|
|
|
|
command, provided, expected string
|
|
|
|
}{
|
|
|
|
{"", "hel", "--help"},
|
|
|
|
{"", "soccer", "--socket"},
|
|
|
|
{"config", "anot", "--another-flag"},
|
|
|
|
} {
|
|
|
|
// When
|
|
|
|
res, _ := app.suggestFlagFromError(
|
|
|
|
errors.New(providedButNotDefinedErrMsg+testCase.provided),
|
|
|
|
testCase.command,
|
|
|
|
)
|
|
|
|
|
|
|
|
// Then
|
2022-05-17 13:24:17 +00:00
|
|
|
expect(t, res, fmt.Sprintf(SuggestDidYouMeanTemplate+"\n\n", testCase.expected))
|
2019-11-29 13:09:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSuggestFlagFromErrorWrongError(t *testing.T) {
|
|
|
|
// Given
|
|
|
|
app := testApp()
|
|
|
|
|
|
|
|
// When
|
|
|
|
_, err := app.suggestFlagFromError(errors.New("invalid"), "")
|
|
|
|
|
|
|
|
// Then
|
|
|
|
expect(t, true, err != nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSuggestFlagFromErrorWrongCommand(t *testing.T) {
|
|
|
|
// Given
|
|
|
|
app := testApp()
|
|
|
|
|
|
|
|
// When
|
|
|
|
_, err := app.suggestFlagFromError(
|
|
|
|
errors.New(providedButNotDefinedErrMsg+"flag"),
|
|
|
|
"invalid",
|
|
|
|
)
|
|
|
|
|
|
|
|
// Then
|
|
|
|
expect(t, true, err != nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSuggestFlagFromErrorNoSuggestion(t *testing.T) {
|
|
|
|
// Given
|
|
|
|
app := testApp()
|
|
|
|
|
|
|
|
// When
|
|
|
|
_, err := app.suggestFlagFromError(
|
|
|
|
errors.New(providedButNotDefinedErrMsg+""),
|
|
|
|
"",
|
|
|
|
)
|
|
|
|
|
|
|
|
// Then
|
|
|
|
expect(t, true, err != nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSuggestCommand(t *testing.T) {
|
|
|
|
// Given
|
|
|
|
app := testApp()
|
|
|
|
|
|
|
|
for _, testCase := range []struct {
|
|
|
|
provided, expected string
|
|
|
|
}{
|
|
|
|
{"", ""},
|
|
|
|
{"conf", "config"},
|
|
|
|
{"i", "i"},
|
|
|
|
{"information", "info"},
|
|
|
|
{"not-existing", "info"},
|
|
|
|
} {
|
|
|
|
// When
|
|
|
|
res := suggestCommand(app.Commands, testCase.provided)
|
|
|
|
|
|
|
|
// Then
|
2022-05-17 13:24:17 +00:00
|
|
|
expect(t, res, fmt.Sprintf(SuggestDidYouMeanTemplate, testCase.expected))
|
2019-11-29 13:09:46 +00:00
|
|
|
}
|
|
|
|
}
|
2022-05-08 00:57:44 +00:00
|
|
|
|
|
|
|
func ExampleApp_Suggest() {
|
|
|
|
app := &App{
|
2022-05-08 03:06:43 +00:00
|
|
|
Name: "greet",
|
|
|
|
Suggest: true,
|
|
|
|
HideHelp: true,
|
|
|
|
HideHelpCommand: true,
|
|
|
|
CustomAppHelpTemplate: "(this space intentionally left blank)\n",
|
2022-05-08 00:57:44 +00:00
|
|
|
Flags: []Flag{
|
|
|
|
&StringFlag{Name: "name", Value: "squirrel", Usage: "a name to say"},
|
|
|
|
},
|
2022-05-08 03:06:43 +00:00
|
|
|
Action: func(cCtx *Context) error {
|
|
|
|
fmt.Printf("Hello %v\n", cCtx.String("name"))
|
2022-05-08 00:57:44 +00:00
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
app.Run([]string{"greet", "--nema", "chipmunk"})
|
|
|
|
// Output:
|
|
|
|
// Incorrect Usage. flag provided but not defined: -nema
|
|
|
|
//
|
2022-05-17 13:24:17 +00:00
|
|
|
// Did you mean "--name"?
|
2022-05-08 00:57:44 +00:00
|
|
|
//
|
2022-05-08 03:06:43 +00:00
|
|
|
// (this space intentionally left blank)
|
|
|
|
}
|
|
|
|
|
|
|
|
func ExampleApp_Suggest_command() {
|
|
|
|
app := &App{
|
|
|
|
Name: "greet",
|
|
|
|
Suggest: true,
|
|
|
|
HideHelp: true,
|
|
|
|
HideHelpCommand: true,
|
|
|
|
CustomAppHelpTemplate: "(this space intentionally left blank)\n",
|
|
|
|
Flags: []Flag{
|
|
|
|
&StringFlag{Name: "name", Value: "squirrel", Usage: "a name to say"},
|
|
|
|
},
|
|
|
|
Action: func(cCtx *Context) error {
|
|
|
|
fmt.Printf("Hello %v\n", cCtx.String("name"))
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
Commands: []*Command{
|
|
|
|
{
|
|
|
|
Name: "neighbors",
|
|
|
|
CustomHelpTemplate: "(this space intentionally left blank)\n",
|
|
|
|
Flags: []Flag{
|
|
|
|
&BoolFlag{Name: "smiling"},
|
|
|
|
},
|
|
|
|
Action: func(cCtx *Context) error {
|
|
|
|
if cCtx.Bool("smiling") {
|
|
|
|
fmt.Println("😀")
|
|
|
|
}
|
|
|
|
fmt.Println("Hello, neighbors")
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
app.Run([]string{"greet", "neighbors", "--sliming"})
|
|
|
|
// Output:
|
|
|
|
// Incorrect Usage: flag provided but not defined: -sliming
|
2022-05-08 00:57:44 +00:00
|
|
|
//
|
2022-05-17 13:24:17 +00:00
|
|
|
// Did you mean "--smiling"?
|
2022-05-08 00:57:44 +00:00
|
|
|
//
|
2022-05-08 03:06:43 +00:00
|
|
|
// (this space intentionally left blank)
|
2022-05-08 00:57:44 +00:00
|
|
|
}
|