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
|
package bingo_test
import (
"iter"
"testing"
"github.com/jpappel/bingo-factory/bingo"
)
func TestRows(t *testing.T) {
g := bingo.Game{}
testGame := func(size int, length int) {
g.Board = make([]bingo.Tile, size)
testGroup := func(name string, iter iter.Seq[[]bingo.Tile]) {
for i := range size {
g.Board[i].Checked = false
}
for group := range iter {
if len(group) != length {
t.Logf("Mismatching %s length: %d != %d", name, length, len(group))
t.FailNow()
}
for i := range length {
if group[i].Checked != false {
t.Errorf("Incorrect value in %s!\n", name)
}
}
}
for i := range size {
g.Board[i].Checked = true
}
for group := range iter {
if len(group) != length {
t.Logf("Mismatching %s length: %d != %d\n", name, length, len(group))
}
for i := range length {
if group[i].Checked != true {
t.Errorf("Incorrect value in %s!\n", name)
}
}
}
}
testGroup("row", g.Rows())
testGroup("col", g.Cols())
testGroup("diag", g.Diags())
}
t.Log("Testing Square Games")
testGame(9, 3)
testGame(25, 5)
t.Log("Testing Non-Square Games")
testGame(22, 2)
}
|