1
18
19 package resolver
20
21 import (
22 "fmt"
23 "sort"
24 "testing"
25
26 "github.com/google/go-cmp/cmp"
27 "google.golang.org/grpc/attributes"
28 )
29
30
31
32
33 var (
34 addr1 = Address{Addr: "a1", Attributes: attributes.New("a1", 3), ServerName: "s1"}
35 addr2 = Address{Addr: "a2", Attributes: attributes.New("a1", 3), ServerName: "s1"}
36 addr3 = Address{Addr: "a1", Attributes: attributes.New("a2", 3), ServerName: "s1"}
37 addr4 = Address{Addr: "a1", Attributes: attributes.New("a1", 2), ServerName: "s1"}
38 addr5 = Address{Addr: "a1", Attributes: attributes.New("a1", "3"), ServerName: "s1"}
39 addr6 = Address{Addr: "a1", Attributes: attributes.New("a1", 3), ServerName: "s2"}
40 addr7 = Address{Addr: "a1", Attributes: attributes.New("a1", 3), ServerName: "s1", BalancerAttributes: attributes.New("xx", 3)}
41
42 endpoint1 = Endpoint{Addresses: []Address{{Addr: "addr1"}}}
43 endpoint2 = Endpoint{Addresses: []Address{{Addr: "addr2"}}}
44 endpoint3 = Endpoint{Addresses: []Address{{Addr: "addr3"}}}
45 endpoint4 = Endpoint{Addresses: []Address{{Addr: "addr4"}}}
46 endpoint5 = Endpoint{Addresses: []Address{{Addr: "addr5"}}}
47 endpoint6 = Endpoint{Addresses: []Address{{Addr: "addr6"}}}
48 endpoint7 = Endpoint{Addresses: []Address{{Addr: "addr7"}}}
49 endpoint12 = Endpoint{Addresses: []Address{{Addr: "addr1"}, {Addr: "addr2"}}}
50 endpoint21 = Endpoint{Addresses: []Address{{Addr: "addr2"}, {Addr: "addr1"}}}
51 endpoint123 = Endpoint{Addresses: []Address{{Addr: "addr1"}, {Addr: "addr2"}, {Addr: "addr3"}}}
52 )
53
54 func (s) TestAddressMap_Length(t *testing.T) {
55 addrMap := NewAddressMap()
56 if got := addrMap.Len(); got != 0 {
57 t.Fatalf("addrMap.Len() = %v; want 0", got)
58 }
59 for i := 0; i < 10; i++ {
60 addrMap.Set(addr1, nil)
61 if got, want := addrMap.Len(), 1; got != want {
62 t.Fatalf("addrMap.Len() = %v; want %v", got, want)
63 }
64 addrMap.Set(addr7, nil)
65 }
66 for i := 0; i < 10; i++ {
67 addrMap.Set(addr2, nil)
68 if got, want := addrMap.Len(), 2; got != want {
69 t.Fatalf("addrMap.Len() = %v; want %v", got, want)
70 }
71 }
72 }
73
74 func (s) TestAddressMap_Get(t *testing.T) {
75 addrMap := NewAddressMap()
76 addrMap.Set(addr1, 1)
77
78 if got, ok := addrMap.Get(addr2); ok || got != nil {
79 t.Fatalf("addrMap.Get(addr1) = %v, %v; want nil, false", got, ok)
80 }
81
82 addrMap.Set(addr2, 2)
83 addrMap.Set(addr3, 3)
84 addrMap.Set(addr4, 4)
85 addrMap.Set(addr5, 5)
86 addrMap.Set(addr6, 6)
87 addrMap.Set(addr7, 7)
88 if got, ok := addrMap.Get(addr1); !ok || got.(int) != 7 {
89 t.Fatalf("addrMap.Get(addr1) = %v, %v; want %v, true", got, ok, 7)
90 }
91 if got, ok := addrMap.Get(addr2); !ok || got.(int) != 2 {
92 t.Fatalf("addrMap.Get(addr2) = %v, %v; want %v, true", got, ok, 2)
93 }
94 if got, ok := addrMap.Get(addr3); !ok || got.(int) != 3 {
95 t.Fatalf("addrMap.Get(addr3) = %v, %v; want %v, true", got, ok, 3)
96 }
97 if got, ok := addrMap.Get(addr4); !ok || got.(int) != 4 {
98 t.Fatalf("addrMap.Get(addr4) = %v, %v; want %v, true", got, ok, 4)
99 }
100 if got, ok := addrMap.Get(addr5); !ok || got.(int) != 5 {
101 t.Fatalf("addrMap.Get(addr5) = %v, %v; want %v, true", got, ok, 5)
102 }
103 if got, ok := addrMap.Get(addr6); !ok || got.(int) != 6 {
104 t.Fatalf("addrMap.Get(addr6) = %v, %v; want %v, true", got, ok, 6)
105 }
106 if got, ok := addrMap.Get(addr7); !ok || got.(int) != 7 {
107 t.Fatalf("addrMap.Get(addr7) = %v, %v; want %v, true", got, ok, 7)
108 }
109 }
110
111 func (s) TestAddressMap_Delete(t *testing.T) {
112 addrMap := NewAddressMap()
113 addrMap.Set(addr1, 1)
114 addrMap.Set(addr2, 2)
115 if got, want := addrMap.Len(), 2; got != want {
116 t.Fatalf("addrMap.Len() = %v; want %v", got, want)
117 }
118 addrMap.Delete(addr3)
119 addrMap.Delete(addr4)
120 addrMap.Delete(addr5)
121 addrMap.Delete(addr6)
122 addrMap.Delete(addr7)
123 if got, ok := addrMap.Get(addr1); ok || got != nil {
124 t.Fatalf("addrMap.Get(addr1) = %v, %v; want nil, false", got, ok)
125 }
126 if got, ok := addrMap.Get(addr7); ok || got != nil {
127 t.Fatalf("addrMap.Get(addr7) = %v, %v; want nil, false", got, ok)
128 }
129 if got, ok := addrMap.Get(addr2); !ok || got.(int) != 2 {
130 t.Fatalf("addrMap.Get(addr2) = %v, %v; want %v, true", got, ok, 2)
131 }
132 }
133
134 func (s) TestAddressMap_Keys(t *testing.T) {
135 addrMap := NewAddressMap()
136 addrMap.Set(addr1, 1)
137 addrMap.Set(addr2, 2)
138 addrMap.Set(addr3, 3)
139 addrMap.Set(addr4, 4)
140 addrMap.Set(addr5, 5)
141 addrMap.Set(addr6, 6)
142 addrMap.Set(addr7, 7)
143
144 want := []Address{addr1, addr2, addr3, addr4, addr5, addr6}
145 got := addrMap.Keys()
146 if d := cmp.Diff(want, got, cmp.Transformer("sort", func(in []Address) []Address {
147 out := append([]Address(nil), in...)
148 sort.Slice(out, func(i, j int) bool { return fmt.Sprint(out[i]) < fmt.Sprint(out[j]) })
149 return out
150 })); d != "" {
151 t.Fatalf("addrMap.Keys returned unexpected elements (-want, +got):\n%v", d)
152 }
153 }
154
155 func (s) TestAddressMap_Values(t *testing.T) {
156 addrMap := NewAddressMap()
157 addrMap.Set(addr1, 1)
158 addrMap.Set(addr2, 2)
159 addrMap.Set(addr3, 3)
160 addrMap.Set(addr4, 4)
161 addrMap.Set(addr5, 5)
162 addrMap.Set(addr6, 6)
163 addrMap.Set(addr7, 7)
164
165 want := []int{2, 3, 4, 5, 6, 7}
166 var got []int
167 for _, v := range addrMap.Values() {
168 got = append(got, v.(int))
169 }
170 sort.Ints(got)
171 if diff := cmp.Diff(want, got); diff != "" {
172 t.Fatalf("addrMap.Values returned unexpected elements (-want, +got):\n%v", diff)
173 }
174 }
175
176 func (s) TestEndpointMap_Length(t *testing.T) {
177 em := NewEndpointMap()
178
179 if got := em.Len(); got != 0 {
180 t.Fatalf("em.Len() = %v; want 0", got)
181 }
182
183
184 em.Set(endpoint12, struct{}{})
185 em.Set(endpoint21, struct{}{})
186
187 if got := em.Len(); got != 1 {
188 t.Fatalf("em.Len() = %v; want 1", got)
189 }
190
191
192 em.Set(endpoint123, struct{}{})
193 if got := em.Len(); got != 2 {
194 t.Fatalf("em.Len() = %v; want 2", got)
195 }
196 }
197
198 func (s) TestEndpointMap_Get(t *testing.T) {
199 em := NewEndpointMap()
200 em.Set(endpoint1, 1)
201
202 em.Set(endpoint12, 1)
203 em.Set(endpoint21, 2)
204 em.Set(endpoint3, 3)
205 em.Set(endpoint4, 4)
206 em.Set(endpoint5, 5)
207 em.Set(endpoint6, 6)
208 em.Set(endpoint7, 7)
209
210 if got, ok := em.Get(endpoint1); !ok || got.(int) != 1 {
211 t.Fatalf("em.Get(endpoint1) = %v, %v; want %v, true", got, ok, 1)
212 }
213 if got, ok := em.Get(endpoint12); !ok || got.(int) != 2 {
214 t.Fatalf("em.Get(endpoint12) = %v, %v; want %v, true", got, ok, 2)
215 }
216 if got, ok := em.Get(endpoint21); !ok || got.(int) != 2 {
217 t.Fatalf("em.Get(endpoint21) = %v, %v; want %v, true", got, ok, 2)
218 }
219 if got, ok := em.Get(endpoint3); !ok || got.(int) != 3 {
220 t.Fatalf("em.Get(endpoint1) = %v, %v; want %v, true", got, ok, 3)
221 }
222 if got, ok := em.Get(endpoint4); !ok || got.(int) != 4 {
223 t.Fatalf("em.Get(endpoint1) = %v, %v; want %v, true", got, ok, 4)
224 }
225 if got, ok := em.Get(endpoint5); !ok || got.(int) != 5 {
226 t.Fatalf("em.Get(endpoint1) = %v, %v; want %v, true", got, ok, 5)
227 }
228 if got, ok := em.Get(endpoint6); !ok || got.(int) != 6 {
229 t.Fatalf("em.Get(endpoint1) = %v, %v; want %v, true", got, ok, 6)
230 }
231 if got, ok := em.Get(endpoint7); !ok || got.(int) != 7 {
232 t.Fatalf("em.Get(endpoint1) = %v, %v; want %v, true", got, ok, 7)
233 }
234 if _, ok := em.Get(endpoint123); ok {
235 t.Fatalf("em.Get(endpoint123) = _, %v; want _, false", ok)
236 }
237 }
238
239 func (s) TestEndpointMap_Delete(t *testing.T) {
240 em := NewEndpointMap()
241
242 em.Set(endpoint1, struct{}{})
243 em.Set(endpoint2, struct{}{})
244 em.Set(endpoint3, struct{}{})
245 em.Set(endpoint12, struct{}{})
246
247 em.Delete(endpoint2)
248 em.Delete(endpoint21)
249
250
251 if _, ok := em.Get(endpoint1); !ok {
252 t.Fatalf("em.Get(endpoint1) = %v, want true", ok)
253 }
254 if _, ok := em.Get(endpoint3); !ok {
255 t.Fatalf("em.Get(endpoint3) = %v, want true", ok)
256 }
257
258 if _, ok := em.Get(endpoint2); ok {
259 t.Fatalf("em.Get(endpoint2) = %v, want false", ok)
260 }
261 if _, ok := em.Get(endpoint12); ok {
262 t.Fatalf("em.Get(endpoint12) = %v, want false", ok)
263 }
264 if _, ok := em.Get(endpoint21); ok {
265 t.Fatalf("em.Get(endpoint21) = %v, want false", ok)
266 }
267 }
268
269 func (s) TestEndpointMap_Values(t *testing.T) {
270 em := NewEndpointMap()
271 em.Set(endpoint1, 1)
272
273 em.Set(endpoint12, 1)
274 em.Set(endpoint21, 2)
275 em.Set(endpoint3, 3)
276 em.Set(endpoint4, 4)
277 em.Set(endpoint5, 5)
278 em.Set(endpoint6, 6)
279 em.Set(endpoint7, 7)
280 want := []int{1, 2, 3, 4, 5, 6, 7}
281 var got []int
282 for _, v := range em.Values() {
283 got = append(got, v.(int))
284 }
285 sort.Ints(got)
286 if diff := cmp.Diff(want, got); diff != "" {
287 t.Fatalf("em.Values() returned unexpected elements (-want, +got):\n%v", diff)
288 }
289 }
290
View as plain text