-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathtest_poker.py
91 lines (79 loc) · 4.45 KB
/
test_poker.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
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
import poker
import unittest
import solver
class TestPoker(unittest.TestCase):
def setUp(self):
self.straight_flush = poker.make_hand('4h 7h 6h 5h Ah 8h 9h')
self.steel_wheel = poker.make_hand('2s As 3s 4s 5s 2h 2d')
self.quads = poker.make_hand('5h 8h 8d 8c 8s 4d 4s')
self.full_house = poker.make_hand('9d 8c 9c 2d Kc 2s 2c')
self.extra_full_house = poker.make_hand('4c 5c 5d 5s Qc Qh Qs')
self.flush = poker.make_hand('4s 5s 6s 8s Qc Qh Qs')
self.straight = poker.make_hand('Ac Kc Qd 2h 6d Jc Tc')
self.wheel = poker.make_hand('3h 7h Ad 2h Ac 4d 5d')
self.trips = poker.make_hand('8h 7h 8d 2h 8c 4d 5d')
self.two_pair = poker.make_hand('Jh Jd 8c 8s 2d 2c Kc')
self.one_pair = poker.make_hand('Tc Td Qh Js 5d 4d 3d')
self.high_card = poker.make_hand('3h Kd 5d 6s 9c Th 2c')
self.five_cards_trips = poker.make_hand('Ac Ad As 4d 8c')
self.four_cards = poker.make_hand('5h Th Tc As')
self.eight_cards = poker.make_hand('5h Th Tc As 8d 8s 7c Kc')
self.pocket_aces = poker.make_hand('As Ac')
self.pocket_kings = poker.make_hand('Kc Kd')
self.pocket_queens = poker.make_hand('Qc Qd')
self.pocket_fives = poker.make_hand('5s 5d')
self.range1 = poker.Range({tuple(self.pocket_aces): 1,
tuple(poker.make_hand('5s 6s')): 2,
tuple(poker.make_hand('2s 2d')): 3})
self.board1 = poker.make_hand('3c 4c 7c Ks Td')
self.range2 = poker.Range({tuple(self.pocket_kings): 1,
tuple(self.pocket_fives): 1})
self.range3 = poker.Range({tuple(self.pocket_kings): .25,
tuple(self.pocket_fives): .25})
self.board2 = poker.make_hand('2h 3h 4d 6d 7s')
self.rangeAKQ = poker.Range({tuple(self.pocket_queens): 1,
tuple(self.pocket_kings): 1,
tuple(self.pocket_aces): 1})
def test_evaluate_hand(self):
self.assertEqual(poker.evaluate_hand(self.straight_flush), (8, 7))
self.assertEqual(poker.evaluate_hand(self.steel_wheel), (8, 3))
self.assertEqual(poker.evaluate_hand(self.quads), (7, (6, 3)))
self.assertEqual(poker.evaluate_hand(self.full_house), (6, (0, 7)))
self.assertEqual(poker.evaluate_hand(self.extra_full_house), (6, (10, 3)))
self.assertEqual(poker.evaluate_hand(self.flush), (5, (10, 6, 4, 3, 2)))
self.assertEqual(poker.evaluate_hand(self.straight), (4, 12))
self.assertEqual(poker.evaluate_hand(self.wheel), (4, 3))
self.assertEqual(poker.evaluate_hand(self.trips), (3, (6, 5, 3)))
self.assertEqual(poker.evaluate_hand(self.two_pair), (2, (9, 6, 11)))
self.assertEqual(poker.evaluate_hand(self.one_pair), (1, (8, 10, 9, 3)))
self.assertEqual(poker.evaluate_hand(self.high_card), (0, (11, 8, 7, 4, 3)))
self.assertEqual(poker.evaluate_hand(self.five_cards_trips), (3, (12, 6, 2)))
with self.assertRaises(ValueError):
poker.evaluate_hand(self.four_cards)
with self.assertRaises(ValueError):
poker.evaluate_hand(self.eight_cards)
def test_equity_hand_vs_range(self):
equity = poker.equity_hand_vs_range(self.pocket_kings,
self.range1,
self.board1)
self.assertEqual(equity, 2/3)
equity = poker.equity_hand_vs_range(self.pocket_fives,
self.range1,
self.board1)
self.assertEqual(equity, 3/4)
def test_equity_range_vs_range(self):
equity = poker.equity_range_vs_range(self.range1,
self.range2,
self.board1)
self.assertEqual(equity, 0.3)
def test_solver(self):
s = solver.Solver(self.board2, self.rangeAKQ, self.rangeAKQ, 'ip', .5, .5)
strat = s.create_optimal_strategy()
opp_value = s.evaluate_strategy(strat.x)
self.assertAlmostEqual(2.833, opp_value, places=3)
s = solver.Solver(self.board2, self.rangeAKQ, self.rangeAKQ, 'oop', .5, .5)
strat = s.create_optimal_strategy()
opp_value = s.evaluate_strategy(strat.x)
self.assertAlmostEqual(3.167, opp_value, places=3)
if __name__ == '__main__':
unittest.main()