/
mockdb.go
72 lines (64 loc) · 1.34 KB
/
mockdb.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
package mockdb
import (
"fmt"
"github.com/alicebob/miniredis"
"github.com/garyburd/redigo/redis"
)
// MockDB is a wrapper over the miniredis server.
type MockDB struct {
*miniredis.Miniredis
}
// NewMiniRedis returns a miniredis server.
func NewMiniRedis() *MockDB {
s, err := miniredis.Run()
if err != nil {
panic(err)
}
return &MockDB{s}
}
// ReadCounter returns the current contents of the counter in the database.
func (s *MockDB) ReadCounter() int64 {
c, err := redis.Dial("tcp", s.Addr())
if err != nil {
panic(err)
}
i64, err := redis.Int64(c.Do("GET", "counter"))
if err != nil {
fmt.Println(err)
}
return i64
}
// IncrementCounter increments the counter by one.
func (s *MockDB) IncrementCounter() {
c, err := redis.Dial("tcp", s.Addr())
if err != nil {
panic(err)
}
c.Send("MULTI")
c.Send("INCR", "counter")
_, err = c.Do("EXEC")
if err != nil {
fmt.Println(err)
}
}
// DecrementCounter decrements the counter by one.
func (s *MockDB) DecrementCounter() {
c, err := redis.Dial("tcp", s.Addr())
if err != nil {
panic(err)
}
c.Send("MULTI")
c.Send("DECR", "counter")
_, err = c.Do("EXEC")
if err != nil {
fmt.Println(err)
}
}
// InitCounter sets the `counter` key to zero.
func (s *MockDB) InitCounter() {
c, err := redis.Dial("tcp", s.Addr())
if err != nil {
panic(err)
}
c.Do("SET", "counter", int64(0))
}