diff options
Diffstat (limited to 'tests/test_vba.py')
-rw-r--r-- | tests/test_vba.py | 71 |
1 files changed, 8 insertions, 63 deletions
diff --git a/tests/test_vba.py b/tests/test_vba.py index 9c12cc1..caa1867 100644 --- a/tests/test_vba.py +++ b/tests/test_vba.py @@ -4,20 +4,16 @@ Tests for VBA automation tools import unittest -import pokemontools.vba.vba as vba - -from pokemontools.vba.battle import ( - Battle, - BattleException, +from setup_vba import ( + vba, + autoplayer, + keyboard, ) -try: - import pokemontools.vba.vba_autoplayer as autoplayer -except ImportError: - import pokemontools.vba.autoplayer as autoplayer -autoplayer.vba = vba - -import pokemontools.vba.keyboard as keyboard +from bootstrapping import ( + bootstrap, + bootstrap_trainer_battle, +) def setup_wram(): """ @@ -39,49 +35,6 @@ def setup_wram(): return wram -def bootstrap(): - """ - Every test needs to be run against a certain minimum context. That context - is constructed by this function. - """ - - cry = vba.crystal(config=None) - runner = autoplayer.SpeedRunner(cry=cry) - - # skip=False means run the skip_intro function instead of just skipping to - # a saved state. - runner.skip_intro(skip=True) - - state = cry.vba.state - - # clean everything up again - cry.vba.shutdown() - - return state - -def bootstrap_trainer_battle(): - """ - Start a trainer battle. - """ - # setup - cry = vba.crystal(config=None) - runner = autoplayer.SpeedRunner(cry=cry) - - runner.skip_intro(skip=True) - runner.handle_mom(skip=True) - runner.walk_into_new_bark_town(skip=True) - runner.handle_elm("totodile", skip=True) - - # levelgrind a pokemon - # TODO: make new_bark_level_grind able to figure out how to construct its - # initial state if none is provided. - runner.new_bark_level_grind(17, skip=True) - - # TODO: figure out a better way to start a trainer battle :( - runner.cry.start_trainer_battle_lamely() - - return runner.cry.vba.state - class OtherVbaTests(unittest.TestCase): def test_keyboard_planner(self): button_sequence = keyboard.plan_typing("an") @@ -329,13 +282,5 @@ class VbaTests(unittest.TestCase): pname = self.cry.get_player_name().replace("@", "") self.assertEqual(name, pname) - def test_battle_is_player_turn(self): - state = bootstrap_trainer_battle() - self.cry.vba.state = state - - battle = Battle(emulator=self.cry) - - self.assertTrue(battle.is_player_turn()) - if __name__ == "__main__": unittest.main() |