-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfields_test.go
185 lines (181 loc) · 6.91 KB
/
fields_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
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
package golog
import (
"reflect"
"testing"
)
func TestField(t *testing.T) {
t.Run("Should return nil if the given key doesn't exists", func(t *testing.T) {
l := &logger{fields: LogFields{"a": "aaa", "b": "bbb", "c": "ccc"}}
v := l.Field("d")
if v != nil {
t.Fatalf("Expected to be nil")
}
v = l.Field("zzz")
if v != nil {
t.Fatalf("Expected to be nil")
}
})
t.Run("Should return the value of the given key", func(t *testing.T) {
l := &logger{fields: LogFields{"a": "aaa", "b": "bbb", "c": "ccc"}}
v := l.Field("a")
if v == nil || v.(string) != "aaa" {
t.Fatalf("Expected to be the correct value")
}
v = l.Field("c")
if v == nil || v.(string) != "ccc" {
t.Fatalf("Expected to be the correct value")
}
})
}
func TestFields(t *testing.T) {
t.Run("Should return a new equal instance of src", func(t *testing.T) {
l := &logger{}
newLog := l.Fields(nil)
if reflect.ValueOf(l).Pointer() == reflect.ValueOf(newLog).Pointer() {
t.Fatalf("Expected a different instance")
}
})
t.Run("The new instance should point to the same configuration", func(t *testing.T) {
c := &Configuration{}
l := &logger{configuration: c}
newLog := l.Fields(nil).(*logger)
if reflect.ValueOf(l.configuration).Pointer() != reflect.ValueOf(newLog.configuration).Pointer() {
t.Fatalf("Expected the same configuration")
}
})
t.Run("The new instance should be equivalent, but with new slices/maps", func(t *testing.T) {
fnD := func(log Log) interface{} { return nil }
fnE := func(log Log) interface{} { return nil }
fnF := func(log Log) interface{} { return nil }
fnG := func(log Log) interface{} { return nil }
outH := func(lvl uint64, msg string, fields LogFields) {}
outI := func(lvl uint64, msg string, fields LogFields) {}
l := &logger{
fields: LogFields{"a": "aaa", "b": "bbb", "c": "ccc"},
preHooks: Hooks{"d": fnD, "e": fnE},
postHooks: Hooks{"f": fnF, "g": fnG},
outputs: []Output{outH, outI},
}
newLog := l.Fields(nil).(*logger)
if reflect.ValueOf(l.fields).Pointer() == reflect.ValueOf(newLog.fields).Pointer() {
t.Fatalf("Expected to be a different fields map")
}
if !reflect.DeepEqual(l.fields, newLog.fields) {
t.Fatalf("Expected an equivalent fields map")
}
if reflect.ValueOf(l.preHooks).Pointer() == reflect.ValueOf(newLog.preHooks).Pointer() {
t.Fatalf("Expected to be a different preHooks map")
}
if len(l.preHooks) != len(newLog.preHooks) {
t.Fatalf("Expected an equivalent preHooks map")
}
for k, v := range l.preHooks {
if reflect.ValueOf(v).Pointer() != reflect.ValueOf(newLog.preHooks[k]).Pointer() {
t.Fatalf("Expected an equivalent preHooks map")
}
}
if reflect.ValueOf(l.postHooks).Pointer() == reflect.ValueOf(newLog.postHooks).Pointer() {
t.Fatalf("Expected to be a different postHooks map")
}
if len(l.postHooks) != len(newLog.postHooks) {
t.Fatalf("Expected an equivalent postHooks map")
}
for k, v := range l.postHooks {
if reflect.ValueOf(v).Pointer() != reflect.ValueOf(newLog.postHooks[k]).Pointer() {
t.Fatalf("Expected an equivalent postHooks map")
}
}
if reflect.ValueOf(l.outputs).Pointer() == reflect.ValueOf(newLog.outputs).Pointer() {
t.Fatalf("Expected to be a different outputs slice")
}
if len(l.outputs) != len(newLog.outputs) {
t.Fatalf("Expected an equivalent outputs slice")
}
for k, v := range l.outputs {
if reflect.ValueOf(v).Pointer() != reflect.ValueOf(newLog.outputs[k]).Pointer() {
t.Fatalf("Expected an equivalent outputs slice")
}
}
})
t.Run("Merge the given LogFields with the src fields, overriding duplicates", func(t *testing.T) {
fields := LogFields{"a": "AAA", "d": "ddd", "e": "eee"}
l := &logger{fields: LogFields{"a": "aaa", "b": "bbb", "c": "ccc"}}
newLog := l.Fields(fields).(*logger)
if newLog.fields["a"] != "AAA" || newLog.fields["b"] != "bbb" || newLog.fields["c"] != "ccc" ||
newLog.fields["d"] != "ddd" || newLog.fields["e"] != "eee" {
t.Fatalf("Expected the merge of the src fields + argument")
}
})
}
func TestRawFields(t *testing.T) {
t.Run("Should return a new equal instance of src", func(t *testing.T) {
l := &logger{}
newLog := l.RawFields(nil)
if reflect.ValueOf(l).Pointer() == reflect.ValueOf(newLog).Pointer() {
t.Fatalf("Expected a different instance")
}
})
t.Run("The new instance should point to the same configuration", func(t *testing.T) {
c := &Configuration{}
l := &logger{configuration: c}
newLog := l.RawFields(nil).(*logger)
if reflect.ValueOf(l.configuration).Pointer() != reflect.ValueOf(newLog.configuration).Pointer() {
t.Fatalf("Expected the same configuration")
}
})
t.Run("The new instance should be equivalent, but with new slices/maps (except the fields)", func(t *testing.T) {
fnD := func(log Log) interface{} { return nil }
fnE := func(log Log) interface{} { return nil }
fnF := func(log Log) interface{} { return nil }
fnG := func(log Log) interface{} { return nil }
outH := func(lvl uint64, msg string, fields LogFields) {}
outI := func(lvl uint64, msg string, fields LogFields) {}
l := &logger{
preHooks: Hooks{"d": fnD, "e": fnE},
postHooks: Hooks{"f": fnF, "g": fnG},
outputs: []Output{outH, outI},
}
newLog := l.RawFields(nil).(*logger)
if reflect.ValueOf(l.preHooks).Pointer() == reflect.ValueOf(newLog.preHooks).Pointer() {
t.Fatalf("Expected to be a different preHooks map")
}
if len(l.preHooks) != len(newLog.preHooks) {
t.Fatalf("Expected an equivalent preHooks map")
}
for k, v := range l.preHooks {
if reflect.ValueOf(v).Pointer() != reflect.ValueOf(newLog.preHooks[k]).Pointer() {
t.Fatalf("Expected an equivalent preHooks map")
}
}
if reflect.ValueOf(l.postHooks).Pointer() == reflect.ValueOf(newLog.postHooks).Pointer() {
t.Fatalf("Expected to be a different postHooks map")
}
if len(l.postHooks) != len(newLog.postHooks) {
t.Fatalf("Expected an equivalent postHooks map")
}
for k, v := range l.postHooks {
if reflect.ValueOf(v).Pointer() != reflect.ValueOf(newLog.postHooks[k]).Pointer() {
t.Fatalf("Expected an equivalent postHooks map")
}
}
if reflect.ValueOf(l.outputs).Pointer() == reflect.ValueOf(newLog.outputs).Pointer() {
t.Fatalf("Expected to be a different outputs slice")
}
if len(l.outputs) != len(newLog.outputs) {
t.Fatalf("Expected an equivalent outputs slice")
}
for k, v := range l.outputs {
if reflect.ValueOf(v).Pointer() != reflect.ValueOf(newLog.outputs[k]).Pointer() {
t.Fatalf("Expected an equivalent outputs slice")
}
}
})
t.Run("Should set the Logger fields, ignoring the previous one", func(t *testing.T) {
fields := LogFields{"a": "AAA", "d": "ddd", "e": "eee"}
l := &logger{fields: LogFields{"a": "aaa", "b": "bbb", "c": "ccc"}}
newLog := l.RawFields(fields).(*logger)
if len(newLog.fields) != 3 || newLog.fields["a"] != "AAA" || newLog.fields["d"] != "ddd" || newLog.fields["e"] != "eee" {
t.Fatalf("Expected to override the value of the src fields completelly")
}
})
}