-
Notifications
You must be signed in to change notification settings - Fork 16
/
redis_test.go
128 lines (112 loc) · 2.06 KB
/
redis_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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
package polluter
import (
"bytes"
"log"
"testing"
"github.com/go-redis/redis"
"github.com/pkg/errors"
"github.com/stretchr/testify/assert"
)
func Test_redisEngine_build(t *testing.T) {
tests := []struct {
name string
input []byte
expect commands
}{
{
name: "example input",
input: []byte(`{"count":1,"values":[1,2],"obj":{"key":"value"}}`),
expect: commands{
command{
q: "count",
args: []interface{}{
[]byte(`1`),
},
},
command{
q: "values",
args: []interface{}{
[]byte(`[1,2]`),
},
},
command{
q: "obj",
args: []interface{}{
[]byte(`{"key":"value"}`),
},
},
},
},
}
for _, tt := range tests {
tt := tt
t.Run(tt.name, func(t *testing.T) {
t.Parallel()
obj, err := jsonParser{}.parse(bytes.NewReader(tt.input))
if err != nil {
assert.Nil(t, err)
}
e := redisEngine{}
got, err := e.build(obj)
assert.Nil(t, err)
assert.Equal(t, tt.expect, got)
})
}
}
func Test_redisEngine_exec(t *testing.T) {
if testing.Short() {
t.Skip("skipping test in short mode")
}
tests := []struct {
name string
args []command
wantErr bool
}{
{
name: "valid query",
args: []command{
{
q: "count",
args: []interface{}{
"1",
},
},
},
},
}
for i, tt := range tests {
i := i
tt := tt
t.Run(tt.name, func(t *testing.T) {
t.Parallel()
cli, teardown := prepareRedisDB(t, i)
defer teardown()
e := redisEngine{cli}
err := e.exec(tt.args)
if tt.wantErr && err == nil {
assert.NotNil(t, err)
return
}
if !tt.wantErr && err != nil {
assert.Nil(t, err)
}
})
}
}
func prepareRedisDB(t *testing.T, db int) (cli *redis.Client, teardown func() error) {
cli = redis.NewClient(&redis.Options{
Addr: redisAddr,
Password: "",
DB: db,
})
_, err := cli.Ping().Result()
if err != nil {
log.Fatalf("ping redis: %s", err)
}
return cli, func() error {
if err := cli.FlushDB().Err(); err != nil {
return errors.Wrap(err, "flush db")
}
return nil
}
}