-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathswiss_test.py
58 lines (51 loc) · 2.43 KB
/
swiss_test.py
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
# Run tests with `python3 swiss_test.py`.
import swiss
import unittest
class TestSwiss(unittest.TestCase):
def players(self):
return [
{'id': 'Abimbola', 'points': 3, 'opponents': ['Boipelo'] },
{'id': 'Boipelo', 'points': 0, 'opponents': ['Abimbola'] },
{'id': 'Chiamaka', 'points': 1, 'opponents': ['Delo'] },
{'id': 'Delo', 'points': 1, 'opponents': ['Chiamaka']},
{'id': 'Ebele', 'points': 0, 'opponents': ['Furaha']},
{'id': 'Furaha', 'points': 3, 'opponents': ['Ebele']},
{'id': 'Zula', 'points': 3, 'opponents': ['BYE']},
{'id': 'BYE', 'points': 0, 'opponents': ['Zula']},
]
def test_pairings(self):
ps = swiss.pairings(self.players())
self.assertEqual('Delo', self.players()[ps[0]]['id'])
self.assertEqual('Ebele', self.players()[ps[1]]['id'])
self.assertEqual('BYE', self.players()[ps[2]]['id'])
self.assertEqual('Abimbola', self.players()[ps[3]]['id'])
self.assertEqual('Boipelo', self.players()[ps[4]]['id'])
self.assertEqual('Zula', self.players()[ps[5]]['id'])
self.assertEqual('Furaha', self.players()[ps[6]]['id'])
self.assertEqual('Chiamaka', self.players()[ps[7]]['id'])
def test_weights(self):
ws = swiss.weights(self.players())
self.assertEqual((1, 0, 4), ws[0])
self.assertEqual((2, 0, 8), ws[1])
self.assertEqual((2, 1, 6), ws[2])
self.assertEqual((3, 0, 8), ws[3])
self.assertEqual((3, 1, 6), ws[4])
self.assertEqual((3, 2, 8), ws[5])
self.assertEqual((4, 0, 4), ws[6])
def test_weight(self):
highest_points = max(p['points'] for p in self.players())
w = swiss.weight(highest_points, self.players()[0], self.players()[1])
self.assertEqual(4, w)
w = swiss.weight(highest_points, self.players()[1], self.players()[2])
self.assertEqual(6, w)
w = swiss.weight(highest_points, self.players()[0], self.players()[7])
self.assertEqual(4, w)
# importance and closeness are values in the range 0..highest_points
def test_quality(self):
self.assertEqual(6, swiss.quality(1, 2))
self.assertEqual(6, swiss.quality(2, 1))
self.assertEqual(12, swiss.quality(3, 2))
self.assertEqual(4, swiss.quality(3, 0))
self.assertEqual(26, swiss.quality(12, 1))
if __name__ == '__main__':
unittest.main()