-
Notifications
You must be signed in to change notification settings - Fork 0
/
client_test.go
66 lines (53 loc) · 964 Bytes
/
client_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
package xcache
import (
"context"
"testing"
"time"
)
var srv1, srv2, srv3 Server
var cli Cache
func init() {
srv1 = startServer(7000)
srv2 = startServer(7001)
srv3 = startServer(7002)
time.Sleep(time.Second)
err := srv2.Join(srv1.Myself())
if err != nil {
panic(err)
}
err = srv3.Join(srv1.Myself())
if err != nil {
panic(err)
}
cli, err = NewClient(context.Background(), []string{":7000", ":7001"})
if err != nil {
panic(err)
}
}
func TestClient(t *testing.T) {
cli, err := NewClient(context.Background(), []string{":7000", ":7001"})
if err != nil {
t.Fatal(err)
}
err = cli.Set("k1", "v1")
if err != nil {
t.Fatal(err)
}
v, err := cli.Get("k1")
if err != nil {
t.Fatal(err)
}
t.Log("get value: ", v)
}
func BenchmarkNewClient(b *testing.B) {
b.ResetTimer()
b.ReportAllocs()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
err := cli.Set("k1", "v1")
if err != nil {
panic(err)
}
}
})
}