def main(): print("-- Tic Tac Toe --\n") parser = argparse.ArgumentParser() parser.add_argument( "--size", help="size of the one side of the board", type=int) parser.add_argument( "--ai", help="which player for ai, -1 for no ai", type=int, default=1) args = parser.parse_args() ai = args.ai size = args.size model = None if size: model = TicTacToeModel(size) else: model = TicTacToeModel() while True: print(model) current_player = model.current_player next_move = get_next_move(current_player, model, ai) try: model.make_move(next_move, current_player) except ValueError as err: print(err) print("Try again!") continue if model.check_winner(next_move): print(model) print("Player {player} won!".format(player=current_player)) break if model.filled(): print(model) print("Game over: Tie!") break
def setUp(self): self.empty_board = TicTacToeModel() self.mid_game_board = TicTacToeModel() self.mid_game_board.make_move((0, 0), 0) self.mid_game_board.make_move((0, 1), 1) self.mid_game_board.make_move((0, 2), 0) self.mid_game_board.make_move((2, 1), 1) self.mid_game_board.make_move((1, 1), 0)
def test_check_winner_right_left_diag(self): winning_board = TicTacToeModel() winning_board.current_player = 0 winning_board.num_moves = 6 winning_board.board = [[0, None, 0], [1, 0, 1], [0, None, 1]] self.assertTrue(winning_board.check_winner((0, 2))) self.assertTrue(winning_board.check_winner((1, 1))) self.assertTrue(winning_board.check_winner((2, 0)))
def test_check_winner_row_2(self): winning_board = TicTacToeModel() winning_board.current_player = 1 winning_board.num_moves = 7 winning_board.board = [[None, None, None], [1, 1, None], [0, 0, 0]] self.assertTrue(winning_board.check_winner((2, 0))) self.assertTrue(winning_board.check_winner((2, 1))) self.assertTrue(winning_board.check_winner((2, 2)))
def test_check_winner_column_2(self): winning_board = TicTacToeModel() winning_board.current_player = 0 winning_board.num_moves = 6 winning_board.board = [[0, 0, 1], [None, 0, 1], [None, None, 1]] self.assertTrue(winning_board.check_winner((0, 2))) self.assertTrue(winning_board.check_winner((1, 2))) self.assertTrue(winning_board.check_winner((2, 2)))
def test_check_winner_column_1(self): winning_board = TicTacToeModel() winning_board.current_player = 1 winning_board.num_moves = 5 winning_board.board = [[1, 0, 1], [None, 0, None], [None, 0, None]] self.assertTrue(winning_board.check_winner((0, 1))) self.assertTrue(winning_board.check_winner((1, 1))) self.assertTrue(winning_board.check_winner((2, 1)))
def test_check_winner_column_0(self): winning_board = TicTacToeModel() winning_board.current_player = 0 winning_board.num_moves = 8 winning_board.board = [[1, None, 0], [1, 0, 0], [1, 0, 1]] self.assertTrue(winning_board.check_winner((0, 0))) self.assertTrue(winning_board.check_winner((1, 0))) self.assertTrue(winning_board.check_winner((2, 0)))
def test_check_winner_right_left_diag_size_5(self): winning_board = TicTacToeModel(5) winning_board.current_player = 1 winning_board.num_moves = 18 winning_board.board = [[0, 0, 0, None, 1], [0, 0, 0, 1, 1], [0, 0, 1, None, 1], [0, 1, None, None, 1], [1, None, None, None, 1]] self.assertTrue(winning_board.check_winner((4, 0))) self.assertTrue(winning_board.check_winner((3, 1))) self.assertTrue(winning_board.check_winner((2, 2))) self.assertTrue(winning_board.check_winner((1, 3))) self.assertTrue(winning_board.check_winner((0, 4)))
def test_check_winner_column_3_size_5(self): winning_board = TicTacToeModel(5) winning_board.current_player = 1 winning_board.num_moves = 19 winning_board.board = [[1, 0, 1, 0, None], [1, 0, 1, 0, None], [1, 0, 1, 0, None], [1, 0, 1, 0, None], [0, 1, None, 0, None]] self.assertTrue(winning_board.check_winner((0, 3))) self.assertTrue(winning_board.check_winner((1, 3))) self.assertTrue(winning_board.check_winner((2, 3))) self.assertTrue(winning_board.check_winner((3, 3))) self.assertTrue(winning_board.check_winner((4, 3)))
def test_check_winner_column_2_size_5(self): winning_board = TicTacToeModel(5) winning_board.current_player = 0 winning_board.num_moves = 9 winning_board.board = [[0, 0, 1, None, None], [0, 0, 1, None, 1], [0, 0, 1, 1, None], [0, None, 1, None, None], [None, None, 1, None, None]] self.assertTrue(winning_board.check_winner((0, 2))) self.assertTrue(winning_board.check_winner((1, 2))) self.assertTrue(winning_board.check_winner((2, 2))) self.assertTrue(winning_board.check_winner((3, 2))) self.assertTrue(winning_board.check_winner((4, 2)))
def test_check_winner_row_4_size_5(self): winning_board = TicTacToeModel(5) winning_board.current_player = 0 winning_board.num_moves = 10 winning_board.board = [[None, 0, 0, None, None], [None, 0, 0, None, None], [None, 0, None, None, None], [None, None, None, None, None], [1, 1, 1, 1, 1]] self.assertTrue(winning_board.check_winner((4, 0))) self.assertTrue(winning_board.check_winner((4, 1))) self.assertTrue(winning_board.check_winner((4, 2))) self.assertTrue(winning_board.check_winner((4, 3))) self.assertTrue(winning_board.check_winner((4, 4)))
def test_check_winner_column_4_size_5(self): winning_board = TicTacToeModel(5) winning_board.current_player = 0 winning_board.num_moves = 10 winning_board.board = [[None, 0, 0, None, 1], [None, 0, None, None, 1], [None, 0, None, None, 1], [None, 0, None, None, 1], [None, None, None, None, 1]] self.assertTrue(winning_board.check_winner((0, 4))) self.assertTrue(winning_board.check_winner((1, 4))) self.assertTrue(winning_board.check_winner((2, 4))) self.assertTrue(winning_board.check_winner((3, 4))) self.assertTrue(winning_board.check_winner((4, 4)))
def test_check_no_winner_size_5(self): not_winning_board = TicTacToeModel(5) not_winning_board.current_player = 0 not_winning_board.num_moves = 16 not_winning_board.board = [[1, None, 1, 0, 1], [1, 0, 0, None, None], [1, 0, 0, None, None], [1, 0, 0, None, None], [0, 1, 1, None, None]] self.assertFalse(not_winning_board.check_winner((0, 0))) self.assertFalse(not_winning_board.check_winner((1, 0))) self.assertFalse(not_winning_board.check_winner((4, 0))) self.assertFalse(not_winning_board.check_winner((2, 2))) self.assertFalse(not_winning_board.check_winner((4, 2)))
def move(): board_size = int(request.form.get('board_size')) player = int(request.form.get('player')) num_moves = int(request.form.get('num_moves')) board = [[None for x in range(board_size)] for y in range(board_size)] remaining_moves = {(x, y) for x in range(board_size) for y in range(board_size)} for x in range(board_size): for y in range(board_size): spot = request.form.get(str((x, y)), None) if spot is not None: board[x][y] = int(spot) remaining_moves.remove((x, y)) model = TicTacToeModel(board_size) model.current_player = player model.num_moves = num_moves model.board = board model.remaining_moves = remaining_moves response = str(get_next_move(player, model)) print(model) print(response) return response
def test_check_winner_empty_board_size_5(self): not_winning_board = TicTacToeModel() self.assertFalse(not_winning_board.check_winner((0, 0)))