-
Notifications
You must be signed in to change notification settings - Fork 38
/
Copy pathtypes_test.go
87 lines (78 loc) · 1.35 KB
/
types_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
package nvim
import (
"reflect"
"testing"
)
func TestLogLevel_String(t *testing.T) {
t.Parallel()
tests := []struct {
name string
level LogLevel
want string
}{
{
name: "Trace",
level: LogTraceLevel,
want: "TraceLevel",
},
{
name: "Debug",
level: LogDebugLevel,
want: "DebugLevel",
},
{
name: "Info",
level: LogInfoLevel,
want: "InfoLevel",
},
{
name: "Warn",
level: LogWarnLevel,
want: "WarnLevel",
},
{
name: "Error",
level: LogErrorLevel,
want: "ErrorLevel",
},
{
name: "unknown",
level: LogLevel(-1),
want: "unknown Level",
},
}
for _, tt := range tests {
tt := tt
t.Run(tt.name, func(t *testing.T) {
t.Parallel()
if got := tt.level.String(); got != tt.want {
t.Fatalf("LogLevel.String() = %v, want %v", tt.want, got)
}
})
}
}
func TestUserCommand(t *testing.T) {
t.Parallel()
uc := reflect.TypeOf((*UserCommand)(nil)).Elem()
tests := map[string]struct {
u UserCommand
}{
"UserVimCommand": {
u: UserVimCommand(""),
},
"UserLuaCommand": {
u: UserLuaCommand{},
},
}
for name, tt := range tests {
tt := tt
t.Run(name, func(t *testing.T) {
t.Parallel()
v := reflect.TypeOf(tt.u)
if !v.Implements(uc) {
t.Fatalf("%s type not implements %q interface", v.Name(), "UserCommand")
}
tt.u.command()
})
}
}