У меня есть настольный тестовый пример, подобный этому:
func CountWords(s string) map[string]int
func TestCountWords(t *testing.T) {
var tests = []struct {
input string
want map[string]int
}{
{"foo", map[string]int{"foo":1}},
{"foo bar foo", map[string]int{"foo":2,"bar":1}},
}
for i, c := range tests {
got := CountWords(c.input)
// TODO test whether c.want == got
}
}
Я могу проверить, одинаковы ли длины и написать цикл, который проверяет, одинакова ли каждая пара ключей значений. Но тогда я должен снова написать эту проверку, когда захочу использовать ее для другого типа карты (скажем map[string]string
).
То, что я закончил, это преобразование карт в строки и сравнение строк:
func checkAsStrings(a,b interface{}) bool {
return fmt.Sprintf("%v", a) != fmt.Sprintf("%v", b)
}
//...
if checkAsStrings(got, c.want) {
t.Errorf("Case #%v: Wanted: %v, got: %v", i, c.want, got)
}
Это предполагает, что строковые представления эквивалентных карт одинаковы, что в данном случае кажется истинным (если ключи одинаковы, то они имеют значение hh для одного и того же значения, поэтому их заказы будут одинаковыми). Есть лучший способ сделать это? Каков идиоматический способ сравнения двух карт в табличных тестах?