-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdataloss_test.go
More file actions
129 lines (116 loc) · 3.79 KB
/
dataloss_test.go
File metadata and controls
129 lines (116 loc) · 3.79 KB
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
129
package errors
import (
"encoding/json"
"errors"
"testing"
assert "github.com/stretchr/testify/assert"
codes "google.golang.org/grpc/codes"
)
type DataLossErrorTest struct {
err *DataLossError
timeout bool
temporary bool
errorInfo string
errorVerbose string
errorDebug string
errorTrace string
getCode int
getMessage string
getCause error
json []byte
rpcCode codes.Code
rpcMessage string
}
var DataLossErrorTests = []DataLossErrorTest{
{
err: NewDataLossError("foo"),
timeout: false,
temporary: false,
errorInfo: "error 500: DATA LOSS. Unrecoverable data loss or data corruption. foo",
getCode: 500,
getMessage: "DATA LOSS. Unrecoverable data loss or data corruption. foo",
getCause: nil,
json: []byte(`{"errorCode":500,"errorMessage":"DATA LOSS. Unrecoverable data loss or data corruption."}`),
rpcCode: codes.DataLoss,
rpcMessage: "DATA LOSS. Unrecoverable data loss or data corruption.",
},
{
err: NewDataLossError("foo", errors.New("causal error")),
timeout: false,
temporary: false,
errorInfo: "error 500: DATA LOSS. Unrecoverable data loss or data corruption. foo",
getCode: 500,
getMessage: "DATA LOSS. Unrecoverable data loss or data corruption. foo",
getCause: errors.New("causal error"),
json: []byte(`{"errorCode":500,"errorMessage":"DATA LOSS. Unrecoverable data loss or data corruption."}`),
rpcCode: codes.DataLoss,
rpcMessage: "DATA LOSS. Unrecoverable data loss or data corruption.",
},
{
err: NewDataLossError("foo", errors.New("causal error"), errors.New("causal error 2")),
timeout: false,
temporary: false,
errorInfo: "error 500: DATA LOSS. Unrecoverable data loss or data corruption. foo",
getCode: 500,
getMessage: "DATA LOSS. Unrecoverable data loss or data corruption. foo",
getCause: NewErrors(errors.New("causal error"), errors.New("causal error 2")),
json: []byte(`{"errorCode":500,"errorMessage":"DATA LOSS. Unrecoverable data loss or data corruption."}`),
rpcCode: codes.DataLoss,
rpcMessage: "DATA LOSS. Unrecoverable data loss or data corruption.",
},
}
func TestDataLossErrorTimeout(t *testing.T) {
for _, test := range DataLossErrorTests {
assert.Equal(t, test.timeout, test.err.Timeout())
}
}
func TestDataLossErrorTemporary(t *testing.T) {
for _, test := range DataLossErrorTests {
assert.Equal(t, test.temporary, test.err.Temporary())
}
}
func TestDataLossErrorError(t *testing.T) {
// note, all other verbosity states tested in error_test.go
SetVerbosity(Info)
for _, test := range DataLossErrorTests {
assert.Equal(t, test.errorInfo, test.err.Error())
}
}
func TestDataLossErrorGetCode(t *testing.T) {
for _, test := range DataLossErrorTests {
assert.Equal(t, test.getCode, test.err.GetCode())
}
}
func TestDataLossErrorGetMessage(t *testing.T) {
for _, test := range DataLossErrorTests {
assert.Equal(t, test.getMessage, test.err.GetMessage())
}
}
func TestDataLossErrorGetCause(t *testing.T) {
for _, test := range DataLossErrorTests {
if test.getCause == nil {
assert.Nil(t, test.err.GetCause())
} else {
assert.Equal(t, test.getCause.Error(), test.err.GetCause().Error())
}
}
}
func TestDataLossErrorGetStack(t *testing.T) {
// trace output prevents testing for string match in different contexts
for _, test := range DataLossErrorTests {
assert.NotNil(t, test.err.GetStack())
}
}
func TestDataLossErrorJson(t *testing.T) {
for _, test := range DataLossErrorTests {
json, _ := json.Marshal(test.err)
assert.Equal(t, string(json[:]), string((test.json)[:]))
}
}
func TestDataLossErrorGrpc(t *testing.T) {
for _, test := range DataLossErrorTests {
s := test.err.GRPCStatus()
assert.Equal(t, test.rpcCode, s.Code())
assert.Equal(t, test.rpcMessage, s.Message())
}
}