def test_add_child(self):
     '''
     Test if update list is able to add new child
     '''
     new_update_list = UpdateList()
     self.__update_list.add_child(new_update_list)
     self.assertEqual(len(self.__update_list.get_children()), 1)
Exemplo n.º 2
0
    def __init__(self):
        '''
        Constructor of DungeonGame.
        :param game_start_mode: the way how game should start.
        :type game_start_mode: GameStartMode
        '''
        self.__dungeon_map = DungeonMap()
        self.__character = None
        self.__game_start_mode = None
        self.__current_game_state = GAME_MENU

        self.__text_to_menu = {
            'new game' : NEW_GAME,
            'load' : LOAD_GAME
        }

        self.__update_list = UpdateList()
Exemplo n.º 3
0
class DungeonGame:

    def __init__(self):
        '''
        Constructor of DungeonGame.
        :param game_start_mode: the way how game should start.
        :type game_start_mode: GameStartMode
        '''
        self.__dungeon_map = DungeonMap()
        self.__character = None
        self.__game_start_mode = None
        self.__current_game_state = GAME_MENU

        self.__text_to_menu = {
            'new game' : NEW_GAME,
            'load' : LOAD_GAME
        }

        self.__update_list = UpdateList()


    @logger_decorator
    def should_run(self):
        '''
        Function is used to undestand if game should continue.
        :return: True if should, False otherwise;
        :rtype: bool.
        '''
        if self.__character:
            player_is_alive = self.__character.is_alive()
            player_collected_all_treasures = self.__character.get_treasures_number() is\
            DungeonGameConfig.NUMBER_OF_TREASURES_TO_WIN
            should_run = player_is_alive and not player_collected_all_treasures
        else:
            should_run = True

        return should_run

    
    @logger_decorator
    def process_game_start(self):
        '''
        Function is used to process game start. It is an equivalent of menu in normal games.
        :return: a function that player have chosen in menu;
        :rtype: StartMenu.
        '''
        while True:
            logging.info('Type \'new game\' to start a new game or \'load\' to old game from save: ')
            input_command = input()
            if input_command in self.__text_to_menu.keys():
                break
        self.__game_start_mode = self.__text_to_menu[input_command]


    @logger_decorator
    def run_game(self):
        '''
        This method implements a single game frame.
        It will work depends on 
        '''
        if self.__current_game_state is GAME_MENU:
            try:
                if self.__game_start_mode is LOAD_GAME:
                    player_position, dungeon_map = DungeonGameSaveLoad.load_game()
                    self.__dungeon_map.init_from_load(player_position, dungeon_map)
                else:
                    map_size = int(input('Map size (>= 5): '))
                    self.__dungeon_map.generate_new_map(map_size)
            except NoSavedDataFileError as error:
                logging.error(f'User have chosen to load the game but we can\'t find game save data on address:\
                {error}.')
                logging.info('Sorry, but there is no game save data. Please, save the game firstly or find the\
                save data file.')
                self.process_game_start()
            else:
                self.__character = Character('User', DungeonGameConfig.PLAYER_HP, self.__dungeon_map)
                self.__current_game_state = GAMEPLAY
                self.__update_list.add_children(self.__dungeon_map, self.__character)

        elif self.__current_game_state is GAMEPLAY:
            logging.info(f'Current character stats: hp - {self.__character.get_hp()}, num of treasures - \
            {self.__character.get_treasures_number()}')
            self.__update_list.update()
 def setUpClass(cls):
     '''
     Used to create a new UpdateList instance for test.
     '''
     cls.__update_list = UpdateList()