Bunun gibi masaya dayalı bir test durumum var:
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
}
}
Uzunlukların aynı olup olmadığını kontrol edebilir ve her anahtar / değer çiftinin aynı olup olmadığını kontrol eden bir döngü yazabilirim. Ama sonra başka bir harita türü için kullanmak istediğimde bu çeki tekrar yazmam gerekiyor (örneğin map[string]string
).
Sonunda yaptığım şey, haritaları dizelere dönüştürdüm ve dizeleri karşılaştırdım:
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)
}
Bu, eşdeğer haritaların dizgi temsillerinin aynı olduğunu varsayar, bu durumda bu doğru görünür (eğer anahtarlar aynıysa, o zaman aynı değere karma yaparlar, bu nedenle sıraları aynı olacaktır). Bunu yapmanın daha iyi bir yolu var mı? Tablo tabanlı testlerde iki haritayı karşılaştırmanın deyimsel yolu nedir?