-
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtestmoveslist.hs
123 lines (90 loc) · 7.22 KB
/
testmoveslist.hs
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
module TestMovesList where
import Board
import Data.List
import Data.Word
import Masks
import Moves
import Test.HUnit
assertBoolLists :: [[Word64]] -> [[Word64]] -> Bool
assertBoolLists x y = sort x == sort y
testMoveList1 :: Test
testMoveList1 = TestCase $ assertBool "test move list 1" $ assertBoolLists (getWhiteMovesList initialBoard)
(map getBoardFields [[12, 16],[12, 15],[11, 14], [11, 15],[10, 13],[10, 14],[9, 13]])
testMoveList2 :: Test
testMoveList2 = TestCase $ assertBool "test move list 2" $ assertBoolLists (getWhiteMovesList Board {wp = mergeBoardFields [1], bp = mergeBoardFields [0], k = mergeBoardFields [1]})
(map getBoardFields [[1, 5],[1, 10],[1, 14],[1, 19],[1, 23],[1, 28],[1, 32]])
testMoveList3 :: Test
testMoveList3 = TestCase $ assertBool "test move list 3" $ assertBoolLists (getWhiteMovesList Board {wp = mergeBoardFields [14], bp = mergeBoardFields [0], k = mergeBoardFields [14]})
(map getBoardFields [[14, 5],[14, 10],[14, 1],[14, 19],[14, 23],[14, 28],[14, 32],[14, 18],[14, 21],[14, 25],[14, 11], [14, 7],[14, 4]])
testMoveList4 :: Test
testMoveList4 = TestCase $ assertBool "test move list 4" $ assertBoolLists (getWhiteMovesList Board {wp = mergeBoardFields [9, 21, 7], bp = mergeBoardFields [0], k = mergeBoardFields [21]})
(map getBoardFields [[9, 13],[21, 25],[21, 18],[21, 14],[21, 11],[7, 11],[7, 12],[21, 17],[21, 26],[21, 30]])
testMoveList5 :: Test
testMoveList5 = TestCase $ assertBool "test move list 5" $ assertBoolLists (getWhiteMovesList Board {wp = mergeBoardFields [27, 20, 15], bp = mergeBoardFields [30], k = mergeBoardFields [20]})
(map getBoardFields[[27, 31],[15, 19],[20, 23], [20, 24],[20, 16]])
testMoveList6 :: Test
testMoveList6 = TestCase $ assertBool "test move list 6" $ assertBoolLists (getWhiteMovesList Board {wp = mergeBoardFields [18, 11, 14], bp = mergeBoardFields [25, 21, 22, 27], k = mergeBoardFields [14]})
(map getBoardFields [[11, 15],[14, 1],[14, 5],[14, 10],[14, 19],[14, 23],[14, 28],[14, 32]])
-------- PIECES JUMPS ---------------
testJumpList1 :: Test
testJumpList1 = TestCase $ assertBool "test jump list 1" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [14], bp = mergeBoardFields [18, 19, 10, 11], k = mergeBoardFields [0]})
(map getBoardFields [[14, 21],[14, 23],
[14, 5], [14, 7]])
testJumpList2 :: Test
testJumpList2 = TestCase $ assertBool "test jump list 2" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [5], bp = mergeBoardFields [10], k = mergeBoardFields [0]})
(map getBoardFields [[5, 14]])
testJumpList3 :: Test
testJumpList3 = TestCase $ assertBool "test jump list 3" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [14], bp = mergeBoardFields [18, 19, 10, 11, 28], k = mergeBoardFields [0]})
(map getBoardFields [[14, 21],[14, 23, 32],
[14, 5], [14, 7]])
testJumpList4 :: Test
testJumpList4 = TestCase $ assertBool "test jump list 4" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [12], bp = mergeBoardFields [15 , 23, 22, 21 , 13, 6, 14], k = mergeBoardFields [0]})
(map getBoardFields [[12, 19, 28], [12, 19, 26, 17, 10, 3],[12, 19, 26, 17, 10, 19, 28], [12, 19, 10, 3],[12, 19, 10, 17, 26, 19, 28]])
testJumpList5 :: Test
testJumpList5 = TestCase $ assertBool "test jump list 5" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [14], bp = mergeBoardFields [19 , 28], k = mergeBoardFields [0]})
(map getBoardFields [[14,23,32]])
testJumpList6 :: Test
testJumpList6 = TestCase $ assertBool "test jump list 6" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [19, 28], bp = mergeBoardFields [14 , 23], k = mergeBoardFields [0]})
(map getBoardFields [[19,10]])
-------------- KINGS JUMPS -------------
testJumpKingsList1 :: Test
testJumpKingsList1 = TestCase $ assertBool "test jump king list 1" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [10], bp = mergeBoardFields [14], k = mergeBoardFields [10]})
(map getBoardFields [[10,19], [10,23],[10,28], [10,32]])
testJumpKingsList2 :: Test
testJumpKingsList2 = TestCase $ assertBool "test jump king list 2" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [10], bp = mergeBoardFields [28], k = mergeBoardFields [10]})
(map getBoardFields [[10,32]])
testJumpKingsList3 :: Test
testJumpKingsList3 = TestCase $ assertBool "test jump king list 3" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [14], bp = mergeBoardFields [18, 19, 10, 11], k = mergeBoardFields [14]})
(map getBoardFields [[14, 21],[14, 25],[14, 23],[14, 28], [14, 32],[14, 5], [14, 1],[14, 7], [14, 4]])
testJumpKingsList4 :: Test
testJumpKingsList4 = TestCase $ assertBool "test jump king list 4" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [14], bp = mergeBoardFields [18, 19, 10, 11, 28], k = mergeBoardFields [14]})
(map getBoardFields [[14, 21],[14, 25],[14, 23,32],[14, 5], [14, 1],[14, 7], [14, 4]])
testJumpKingsList5 :: Test
testJumpKingsList5 = TestCase $ assertBool "test jump king list 5" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [12], bp = mergeBoardFields [15 , 23, 22, 21 , 13, 6, 14], k = mergeBoardFields [12]})
(map getBoardFields [[12, 19, 28], [12, 19, 32],
[12, 19, 26, 17, 10, 3],
[12, 19, 26, 17, 10, 19, 28], [12, 19, 26, 17, 10, 19, 32],
[12, 19, 10, 3],
[12, 19, 10, 17, 26, 19, 28],
[12, 19, 10, 17, 30, 20],
[12, 19, 10, 17, 30, 16],
[12, 19, 10, 17, 26, 19, 32]])
testJumpKingsList6 :: Test
testJumpKingsList6 = TestCase $ assertBool "test jump king list 6" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [14], bp = mergeBoardFields [19 , 28], k = mergeBoardFields [14]})
(map getBoardFields [[14,23,32]])
------- KINGS AND PIECES JUMPS -------------
testJumpKingsPiecesList1 :: Test
testJumpKingsPiecesList1 = TestCase $ assertBool "test jump king pieces list 1" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [1, 6 ], bp = mergeBoardFields [10 ], k = mergeBoardFields [1]})
(map getBoardFields [[6,13], [1,19],[1,14], [1,23], [1,28], [1,32]])
testJumpKingsPiecesList2 :: Test
testJumpKingsPiecesList2 = TestCase $ assertBool "test jump king pieces list 2" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [1, 6 ], bp = mergeBoardFields [10, 14 ], k = mergeBoardFields [1]})
(map getBoardFields [[6,13]])
----- BROKEN TEST --------------
testJumpKingsPiecesList3 :: Test
testJumpKingsPiecesList3 = TestCase $ assertBool "test jump king pieces list 3" $ assertBoolLists (getWhiteJumpsList Board {wp = mergeBoardFields [1, 6 ], bp = mergeBoardFields [10, 23 ], k = mergeBoardFields [1]})
(map getBoardFields [[6,13],[1,28], [1,32]])
getTestList :: [Test]
getTestList = [testMoveList1, testMoveList2, testMoveList3, testMoveList4, testMoveList5, testMoveList6,
testJumpList1, testJumpList2, testJumpList3, testJumpList4, testJumpList5, testJumpList6,
testJumpKingsList1, testJumpKingsList2, testJumpKingsList3, testJumpKingsList4, testJumpKingsList5, testJumpKingsList6,
testJumpKingsPiecesList1, testJumpKingsPiecesList2]