From 282c0fc9f8bb9f9ef45db0d2227b2d31f36620d3 Mon Sep 17 00:00:00 2001 From: Aineopintojen-harjoitustyo-Algoritmit-j Date: Mon, 5 Feb 2024 09:14:28 +0200 Subject: Updating tests and removing unused returns and function. --- bots/bot.py | 8 ------- tests/test_app.py | 68 ++++++++++++++++++++++++++++++++++++++++++++----------- tui/ansi_draw.py | 3 --- 3 files changed, 55 insertions(+), 24 deletions(-) diff --git a/bots/bot.py b/bots/bot.py index 51151e0..2f3baae 100644 --- a/bots/bot.py +++ b/bots/bot.py @@ -107,14 +107,6 @@ class Bot(): count+=1 return count - def remove_unknowns(self, tiles): - """ poistaa tunnistamattomat laatat """ - count=0 - for tile in list(tiles): - if not self.known_tile(tile): - tiles.remove(tile) - count+=1 - return count def get_interesting_tiles(self): """ palauttaa laatat joiden naapureissa on vaihtelua """ diff --git a/tests/test_app.py b/tests/test_app.py index ba97a90..d82d3a2 100644 --- a/tests/test_app.py +++ b/tests/test_app.py @@ -2,6 +2,7 @@ # pylint: disable = missing-class-docstring, too-few-public-methods from io import StringIO +from time import time import unittest from unittest.mock import patch @@ -14,9 +15,13 @@ class KbdTest: def __init__(self, actions): self.actions = actions def read_action(self): - return self.actions.pop(0) if self.actions else (Action.NOOP) + if self.actions: + action, _, _ = self.actions.pop(0) + else: + action = Action.NOOP + return action def read_matrix_action(self, w, h, x, y): - return (self.actions.pop(0), 0, 0) if self.actions else (Action.NOOP,0,0) + return self.actions.pop(0) if self.actions else (Action.NOOP,x,y) class TestAppClass(unittest.TestCase): @@ -68,6 +73,11 @@ class TestAppClass(unittest.TestCase): [0,1,1,0,1,1,0,1,0] ] + mini_board = [ + [0,0], + [0,1] + ] + def test_run(self): """ Testataan että edes pyörähtää """ @@ -79,8 +89,8 @@ class TestAppClass(unittest.TestCase): """ Testataan Quittaamista """ app = App() app.ui.kbd=KbdTest([ - Action.QUIT, - Action.OPEN + (Action.QUIT,0,0), + (Action.OPEN,0,0) ]) app.run() del app @@ -159,8 +169,8 @@ class TestAppClass(unittest.TestCase): bot = 0 app = App(args) app.ui.kbd=KbdTest([ - Action.SAFE, - Action.OPEN + (Action.SAFE,0,0), + (Action.OPEN,0,0) ]) self.assertTrue(app.run()) del app @@ -172,9 +182,9 @@ class TestAppClass(unittest.TestCase): autoplay = 0 app = App(args) app.ui.kbd=KbdTest([ - Action.FLAG, - Action.MINE, - Action.OPEN + (Action.FLAG,0,0), + (Action.MINE,0,0), + (Action.OPEN,0,0) ]) self.assertFalse(app.run()) del app @@ -186,10 +196,42 @@ class TestAppClass(unittest.TestCase): autoplay = 1 app = App(args) app.ui.kbd=KbdTest([ - Action.NOOP, - Action.NOOP, - Action.OPEN, - Action.HINT + (Action.OPEN,0,0), + (Action.HINT,0,0), + ]) + self.assertTrue(app.run()) + del app + + def test_delay(self): + """ Hidastus toimii """ + class args(self.default_args): + board = self.dssp_win_board + autoplay = 2 + delay = 5 + app = App(args) + app.ui.kbd=KbdTest([ + (Action.OPEN,0,0), + (Action.HINT,0,0), + ]) + duration = time() + self.assertTrue(app.run()) + duration = time() - duration + del app + self.assertTrue( duration > 0.5 ) + + def test_botless_play(self): + """ Hidastus toimii """ + class args(self.default_args): + board = self.mini_board + autoplay = 0 + delay = 50000 + app = App(args) + app.ui.kbd=KbdTest([ + (Action.OPEN,0,0), + (Action.HINT,0,0), + (Action.OPEN,1,0), + (Action.HINT,0,0), + (Action.OPEN,0,1) ]) self.assertTrue(app.run()) del app diff --git a/tui/ansi_draw.py b/tui/ansi_draw.py index 143874d..ba71fdb 100644 --- a/tui/ansi_draw.py +++ b/tui/ansi_draw.py @@ -42,7 +42,6 @@ class SuppressDraw(): def matrix(self, matrix, hx, hy): """ "piirtää" ruudukon """ - return True def status_line(self, text): """ draw_status_line - tulostaa pelitietorivin""" @@ -54,8 +53,6 @@ class NoDraw(): def matrix(self, matrix, hx, hy): """ "piirtää" ruudukon """ - return True def status_line(self, text): """ draw_status_line - tulostaa pelitietorivin""" - return True -- cgit v1.2.3