diff options
| author | Eyal Posener <[email protected]> | 2017-05-05 16:57:22 +0300 |
|---|---|---|
| committer | Eyal Posener <[email protected]> | 2017-05-05 18:01:08 +0300 |
| commit | 04e78e42abea95d46d09f7de563ca50d78d3e108 (patch) | |
| tree | f67a4877c550eb9eafc8eb6314ebbaffe2beb87b /complete_test.go | |
Initial commit
Diffstat (limited to 'complete_test.go')
| -rw-r--r-- | complete_test.go | 149 |
1 files changed, 149 insertions, 0 deletions
diff --git a/complete_test.go b/complete_test.go new file mode 100644 index 0000000..55934bd --- /dev/null +++ b/complete_test.go @@ -0,0 +1,149 @@ +package complete + +import ( + "os" + "sort" + "testing" +) + +func TestCompleter_Complete(t *testing.T) { + t.Parallel() + + os.Setenv(envDebug, "1") + + c := Completer{ + Command: Command{ + Sub: map[string]Command{ + "sub1": { + Flags: map[string]FlagOptions{ + "-flag1": FlagUnknownFollow, + "-flag2": FlagNoFollow, + }, + }, + "sub2": { + Flags: map[string]FlagOptions{ + "-flag2": FlagNoFollow, + "-flag3": FlagNoFollow, + }, + }, + }, + Flags: map[string]FlagOptions{ + "-h": FlagNoFollow, + "-global1": FlagUnknownFollow, + }, + }, + log: t.Logf, + } + + allGlobals := []string{} + for sub := range c.Sub { + allGlobals = append(allGlobals, sub) + } + for flag := range c.Flags { + allGlobals = append(allGlobals, flag) + } + + tests := []struct { + args string + want []string + }{ + { + args: "", + want: allGlobals, + }, + { + args: "-", + want: []string{"-h", "-global1"}, + }, + { + args: "-h ", + want: allGlobals, + }, + { + args: "-global1 ", // global1 is known follow flag + want: []string{}, + }, + { + args: "sub", + want: []string{"sub1", "sub2"}, + }, + { + args: "sub1", + want: []string{"sub1"}, + }, + { + args: "sub2", + want: []string{"sub2"}, + }, + { + args: "sub1 ", + want: []string{"-flag1", "-flag2", "-h", "-global1"}, + }, + { + args: "sub2 ", + want: []string{"-flag2", "-flag3", "-h", "-global1"}, + }, + { + args: "sub1 -fl", + want: []string{"-flag1", "-flag2"}, + }, + { + args: "sub1 -flag1", + want: []string{"-flag1"}, + }, + { + args: "sub1 -flag1 ", + want: []string{}, // flag1 is unknown follow flag + }, + { + args: "sub1 -flag2 ", + want: []string{"-flag1", "-flag2", "-h", "-global1"}, + }, + { + args: "-no-such-flag", + want: []string{}, + }, + { + args: "-no-such-flag ", + want: allGlobals, + }, + { + args: "no-such-command", + want: []string{}, + }, + { + args: "no-such-command ", + want: allGlobals, + }, + } + + for _, tt := range tests { + t.Run(tt.args, func(t *testing.T) { + + tt.args = "cmd " + tt.args + os.Setenv(envComplete, tt.args) + args := getLine() + + got := c.complete(args) + + sort.Strings(tt.want) + sort.Strings(got) + + if !equalSlices(got, tt.want) { + t.Errorf("failed '%s'\ngot = %s\nwant: %s", t.Name(), got, tt.want) + } + }) + } +} + +func equalSlices(a, b []string) bool { + if len(a) != len(b) { + return false + } + for i := range a { + if a[i] != b[i] { + return false + } + } + return true +} |
