У меня есть тестовый пример, управляемый таблицей, вроде этого:
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)
}
Это предполагает, что строковые представления эквивалентных карт одинаковы, что кажется правдой в этом случае (если ключи одинаковы, они хешируют одно и то же значение, поэтому их порядок будет одинаковым). Есть лучший способ сделать это? Каков идиоматический способ сравнения двух карт в табличных тестах?