-
Notifications
You must be signed in to change notification settings - Fork 0
/
service_test.go
119 lines (93 loc) · 2.85 KB
/
service_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
package logsvc_test
import (
"testing"
"github.com/golang/mock/gomock"
"github.com/nguyenhoaibao/logsvc"
"github.com/nguyenhoaibao/logsvc/mocks"
"github.com/nguyenhoaibao/logsvc/pb"
"github.com/pkg/errors"
"github.com/stretchr/testify/assert"
context "golang.org/x/net/context"
)
func TestService_Write(t *testing.T) {
mockCtrl := gomock.NewController(t)
defer mockCtrl.Finish()
mockRepo := mocks.NewMockRepository(mockCtrl)
svc := logsvc.NewService(mockRepo)
var (
clientIP = "127.0.0.1"
serverIP = "127.0.1.1"
tags = map[string]string{"key": "val"}
msg = "log message"
ctx = context.Background()
logReq = &pb.Log{
ClientIp: clientIP,
ServerIp: serverIP,
Tags: &pb.Tags{
Tags: tags,
},
Msg: msg,
}
)
mockRepo.EXPECT().Save(gomock.Any(), gomock.Any()).
Do(func(_ context.Context, log *logsvc.Log) {
assert.Equal(t, clientIP, log.ClientIP)
assert.Equal(t, serverIP, log.ServerIP)
assert.Equal(t, tags, log.Tags)
assert.Equal(t, msg, log.Msg)
})
_, err := svc.Write(ctx, logReq)
assert.NoError(t, err)
}
func TestService_WriteReturnsError(t *testing.T) {
mockCtrl := gomock.NewController(t)
defer mockCtrl.Finish()
mockRepo := mocks.NewMockRepository(mockCtrl)
svc := logsvc.NewService(mockRepo)
dummyErr := errors.New("dummy error")
mockRepo.EXPECT().Save(gomock.Any(), gomock.Any()).Return(dummyErr)
_, err := svc.Write(context.Background(), &pb.Log{})
assert.Equal(t, dummyErr, err)
}
func TestService_Get(t *testing.T) {
mockCtrl := gomock.NewController(t)
defer mockCtrl.Finish()
mockRepo := mocks.NewMockRepository(mockCtrl)
svc := logsvc.NewService(mockRepo)
var (
clientIP = "127.0.0.1"
serverIP = "127.0.1.1"
tags = map[string]string{"key": "val"}
ctx = context.Background()
req = &pb.GetRequest{
ClientIp: clientIP,
ServerIp: serverIP,
Tags: &pb.Tags{
Tags: tags,
},
}
)
mockRepo.EXPECT().Get(ctx, clientIP, serverIP, tags)
_, err := svc.Get(ctx, req)
assert.NoError(t, err)
}
func TestService_GetReturnsEmptyResults(t *testing.T) {
mockCtrl := gomock.NewController(t)
defer mockCtrl.Finish()
mockRepo := mocks.NewMockRepository(mockCtrl)
svc := logsvc.NewService(mockRepo)
mockRepo.EXPECT().Get(gomock.Any(), gomock.Any(), gomock.Any(), gomock.Any()).Return([]logsvc.Log{}, nil)
results, err := svc.Get(context.Background(), &pb.GetRequest{})
assert.NoError(t, err)
assert.Equal(t, &pb.GetResponse{[]*pb.Log{}}, results)
}
func TestService_GetReturnsError(t *testing.T) {
mockCtrl := gomock.NewController(t)
defer mockCtrl.Finish()
mockRepo := mocks.NewMockRepository(mockCtrl)
svc := logsvc.NewService(mockRepo)
dummyErr := errors.New("dummy error")
mockRepo.EXPECT().Get(gomock.Any(), gomock.Any(), gomock.Any(), gomock.Any()).Return(nil, dummyErr)
_, err := svc.Get(context.Background(), &pb.GetRequest{})
assert.Equal(t, dummyErr, err)
}