def setUp(self): """ Create the UI """ self.setup_application() self.build_settings() Registry.create() self.theme_manager = ThemeManager()
def test_update_preview_images(self): """ Test that the update_preview_images() method works correctly """ # GIVEN: A ThemeManager def get_theme_data(value): return '{}_theme_data'.format(value) theme_manager = ThemeManager(None) theme_manager.save_preview = MagicMock() theme_manager._get_theme_data = Mock(side_effect=get_theme_data) theme_manager.progress_form = MagicMock(**{'get_preview.return_value': 'preview'}) theme_manager.load_themes = MagicMock() theme_list = {'Default': get_theme_data('Default'), 'Test': get_theme_data('Test')} # WHEN: ThemeManager.update_preview_images() is called theme_manager.update_preview_images(theme_list) # THEN: Things should work right assert theme_manager.progress_form.theme_list == theme_list theme_manager.progress_form.show.assert_called_once_with() assert theme_manager.progress_form.get_preview.call_args_list == [call('Default', get_theme_data('Default')), call('Test', get_theme_data('Test'))] assert theme_manager.save_preview.call_args_list == [call('Default', 'preview'), call('Test', 'preview')] theme_manager.progress_form.close.assert_called_once_with() theme_manager.load_themes.assert_called_once_with()
def setUp(self): """ Create the UI """ self.registry = Registry() Registry.create() self.setup_application() self.build_settings() State().load_settings() Registry().register('settings', Settings()) Registry().register( 'main_window', MagicMock(service_manager_settings_section='servicemanager')) self.application_id = 'abc' self.secret = '123' Settings().setValue('planningcenter/application_id', self.application_id) Settings().setValue('planningcenter/secret', self.secret) # init the planning center plugin so we have default values defined for Settings() self.planning_center_plugin = PlanningCenterPlugin() # setup our form self.form = SelectPlanForm() self.form.planning_center_api.airplane_mode = True self.form.planning_center_api.airplane_mode_directory = TEST_PATH self.theme_manager = ThemeManager(None) self.theme_manager.get_theme_names = MagicMock() self.theme_manager.get_theme_names.return_value = ['themeA', 'themeB']
def test_export_theme(self, mocked_zipfile_write, mocked_zipfile_init): """ Test exporting a theme . """ # GIVEN: A new ThemeManager instance. theme_manager = ThemeManager() theme_manager.theme_path = RESOURCE_PATH / 'themes' mocked_zipfile_init.return_value = None # WHEN: The theme is exported theme_manager._export_theme(Path('some', 'path', 'Default.otz'), 'Default') # THEN: The zipfile should be created at the given path mocked_zipfile_init.assert_called_with(Path('some', 'path', 'Default.otz'), 'w') mocked_zipfile_write.assert_called_with(RESOURCE_PATH / 'themes' / 'Default' / 'Default.xml', Path('Default', 'Default.xml'))
def test_over_write_message_box_no(self, mocked_translate, mocked_qmessagebox_question): """ Test that theme_manager.over_write_message_box returns False when the user clicks no. """ # GIVEN: A patched QMessageBox.question and an instance of ThemeManager mocked_translate.side_effect = lambda context, text: text theme_manager = ThemeManager(None) # WHEN: Calling over_write_message_box with 'Theme Name' result = theme_manager.over_write_message_box('Theme Name') # THEN: over_write_message_box should return False and the message box should contain the theme name assert result is False mocked_qmessagebox_question.assert_called_once_with( theme_manager, 'Theme Already Exists', 'Theme Theme Name already exists. Do you want to replace it?', defaultButton=ANY)
def test_save_theme_background_override(self, mocked_paths, mocked_delete, mocked_shutil): """ Test that we log a warning if the new background is missing """ # GIVEN: A new theme manager instance, with invalid files. Setup as if the user # has changed the background to a invalid path. # Not using resource dir because I could potentially copy a file folder_path = Path(mkdtemp()) theme_manager = ThemeManager(None) theme_manager.old_background_image_path = folder_path / 'old.png' theme_manager.update_preview_images = MagicMock() theme_manager.theme_path = MagicMock() mocked_theme = MagicMock() mocked_theme.theme_name = 'themename' mocked_theme.background_filename = folder_path / 'new_cached.png' # mocked_theme.background_source.exists() will return True mocked_theme.background_source = MagicMock() # override_background.exists() will return True override_background = MagicMock() # WHEN: Calling save_theme with a background override theme_manager.save_theme(mocked_theme, background_override=override_background) # THEN: The override_background should have been copied rather than the background_source mocked_shutil.copyfile.assert_called_once_with(override_background, mocked_theme.background_filename)
def test_save_theme_missing_original(self, mocked_paths, mocked_delete, mocked_log_exception): """ Test that we revert to the old theme background image if the source is missing when changing the theme. (User doesn't change background but the original is missing) """ # GIVEN: A new theme manager instance, with invalid files. Setup as if the user # has left the background the same, or reselected the same path. # Not using resource dir because I could potentially copy a file folder_path = Path(mkdtemp()) theme_manager = ThemeManager(None) theme_manager.old_background_image_path = folder_path / 'old.png' theme_manager.update_preview_images = MagicMock() theme_manager.theme_path = MagicMock() mocked_theme = MagicMock() mocked_theme.theme_name = 'themename' mocked_theme.background_filename = folder_path / 'old.png' mocked_theme.background_source = folder_path / 'non_existent_original.png' # WHEN: Calling save_theme with a invalid background_filename # Although all filenames are considered invalid in this test, # it is important it reverts to the old background path as this in reality is always # valid unless someone has messed with the cache. theme_manager.save_theme(mocked_theme) # THEN: The old background should not have bee deleted # AND the filename should have been replaced with the old cached background # AND there is no exception assert mocked_delete.called is False, 'delete_file should not be called' assert mocked_theme.background_filename == theme_manager.old_background_image_path, \ 'Background path should be reverted' assert mocked_log_exception.called is False, \ 'Should not have been an exception as the file wasn\'t changed'
def test_initial_theme_manager(self): """ Test the instantiation of theme manager. """ # GIVEN: A new service manager instance. ThemeManager(None) # WHEN: the default theme manager is built. # THEN: The the controller should be registered in the registry. assert Registry().get('theme_manager') is not None, 'The base theme manager should be registered'
def test_unzip_theme_invalid_version(self): """ Test that themes with invalid (< 2.0) or with no version attributes are rejected """ # GIVEN: An instance of ThemeManager whilst mocking a theme that returns a theme with no version attribute with patch('openlp.core.ui.thememanager.zipfile.ZipFile') as mocked_zip_file,\ patch('openlp.core.ui.thememanager.ElementTree.getroot') as mocked_getroot,\ patch('openlp.core.ui.thememanager.XML'),\ patch('openlp.core.ui.thememanager.critical_error_message_box') as mocked_critical_error_message_box: mocked_zip_file.return_value = MagicMock(**{'namelist.return_value': [os.path.join('theme', 'theme.xml')]}) mocked_getroot.return_value = MagicMock(**{'get.return_value': None}) theme_manager = ThemeManager(None) # WHEN: unzip_theme is called theme_manager.unzip_theme(Path('theme.file'), Path('folder')) # THEN: The critical_error_message_box should have been called assert mocked_critical_error_message_box.call_count == 1, 'Should have been called once'
def test_save_theme_special_char_name(self): """ Test that we can save themes with special characters in the name """ # GIVEN: A new theme manager instance, with mocked theme and thememanager-attributes. theme_manager = ThemeManager(None) theme_manager.old_background_image_path = None theme_manager.update_preview_images = MagicMock() theme_manager.theme_path = Path(self.temp_folder) mocked_theme = MagicMock() mocked_theme.theme_name = 'theme 愛 name' mocked_theme.export_theme.return_value = "{}" # WHEN: Calling save_theme with a theme with a name with special characters in it theme_manager.save_theme(mocked_theme) # THEN: It should have been created assert os.path.exists(os.path.join(self.temp_folder, 'theme 愛 name', 'theme 愛 name.json')) is True, \ 'Theme with special characters should have been created!'
def test_unzip_theme(self): """ Test that unzipping of themes works """ # GIVEN: A theme file, a output folder and some mocked out internal functions with patch('openlp.core.ui.thememanager.critical_error_message_box') \ as mocked_critical_error_message_box: theme_manager = ThemeManager(None) theme_manager._create_theme_from_xml = MagicMock() theme_manager.update_preview_images = MagicMock() theme_manager.theme_path = None folder_path = Path(mkdtemp()) theme_file_path = RESOURCE_PATH / 'themes' / 'Moss_on_tree.otz' # WHEN: We try to unzip it theme_manager.unzip_theme(theme_file_path, folder_path) # THEN: Files should be unpacked assert (folder_path / 'Moss on tree' / 'Moss on tree.xml').exists() is True assert mocked_critical_error_message_box.call_count == 0, 'No errors should have happened' shutil.rmtree(folder_path)
def test_save_theme_delete_old_image(self, mocked_create_paths, mocked_delete_file, mocked_shutil): """ Test that we do delete a old theme background image when a new is submitted """ # GIVEN: A new theme manager instance, with mocked builtins.open, # theme, create_paths, thememanager-attributes and background # .filename path is the same as the source path. theme_manager = ThemeManager(None) theme_manager.old_background_image_path = RESOURCE_PATH / 'old_church.png' theme_manager.update_preview_images = MagicMock() theme_manager.theme_path = MagicMock() mocked_theme = MagicMock() mocked_theme.theme_name = 'themename' mocked_theme.background_filename = RESOURCE_PATH / 'church.jpg' mocked_theme.background_source = RESOURCE_PATH / 'church2.jpg' # WHEN: Calling save_theme with both background paths to different images theme_manager.save_theme(mocked_theme) # THEN: The mocked_delete_file should have been called to delete the old cached background assert mocked_delete_file.called is True, 'delete_file should be called'
def test_save_theme_missing_new(self, mocked_paths, mocked_delete, mocked_log_warning): """ Test that we log a warning if the new background is missing """ # GIVEN: A new theme manager instance, with invalid files. Setup as if the user # has changed the background to a invalid path. # Not using resource dir because I could potentially copy a file folder_path = Path(mkdtemp()) theme_manager = ThemeManager(None) theme_manager.old_background_image_path = folder_path / 'old.png' theme_manager.update_preview_images = MagicMock() theme_manager.theme_path = MagicMock() mocked_theme = MagicMock() mocked_theme.theme_name = 'themename' mocked_theme.background_filename = folder_path / 'new_cached.png' mocked_theme.background_source = folder_path / 'new_original.png' # WHEN: Calling save_theme with a invalid background_filename theme_manager.save_theme(mocked_theme) # THEN: A warning should have happened due to attempting to copy a missing file mocked_log_warning.assert_called_once_with('Background does not exist, retaining cached background')
def test_save_theme_same_image(self, mocked_create_paths, mocked_shutil): """ Test that we don't try to overwrite a theme background image with itself """ # GIVEN: A new theme manager instance, with mocked builtins.open, copyfile, # theme, create_paths, thememanager-attributes and background # .filename path is the same as the source path. theme_manager = ThemeManager(None) theme_manager.old_background_image_path = None theme_manager.update_preview_images = MagicMock() theme_manager.theme_path = MagicMock() mocked_theme = MagicMock() mocked_theme.theme_name = 'themename' mocked_theme.extract_formatted_xml = MagicMock() mocked_theme.extract_formatted_xml.return_value = 'fake_theme_xml'.encode() file_path_1 = RESOURCE_PATH / 'church.jpg' mocked_theme.background_filename = file_path_1 mocked_theme.background_source = file_path_1 # WHEN: Calling save_theme with both background paths to the same image theme_manager.save_theme(mocked_theme) # THEN: The mocked_copyfile should not have been called assert mocked_shutil.copyfile.called is False, 'copyfile should not be called'
class TestThemeManager(TestCase, TestMixin): """ Test the functions in the ThemeManager module """ def setUp(self): """ Create the UI """ self.setup_application() self.build_settings() Registry.create() self.theme_manager = ThemeManager() def tearDown(self): """ Delete all the C++ objects at the end so that we don't have a segfault """ self.destroy_settings() del self.theme_manager def test_initialise(self): """ Test the thememanager initialise - basic test """ # GIVEN: A new a call to initialise self.theme_manager.setup_ui = MagicMock() self.theme_manager.build_theme_path = MagicMock() Settings().setValue('themes/global theme', 'my_theme') # WHEN: the initialisation is run self.theme_manager.bootstrap_initialise() # THEN: self.theme_manager.setup_ui.assert_called_once_with(self.theme_manager) assert self.theme_manager.global_theme == 'my_theme' self.theme_manager.build_theme_path.assert_called_once_with() @patch('openlp.core.ui.thememanager.create_paths') @patch('openlp.core.ui.thememanager.AppLocation.get_section_data_path') def test_build_theme_path(self, mocked_get_section_data_path, mocked_create_paths): """ Test the thememanager build_theme_path """ # GIVEN: A mocked out AppLocation.get_directory() and mocked create_paths mocked_get_section_data_path.return_value = Path('tests/my_theme') # WHEN: the build_theme_path is run self.theme_manager.build_theme_path() # THEN: The theme path and the thumb path should be correct assert self.theme_manager.theme_path == Path('tests/my_theme') assert self.theme_manager.thumb_path == Path( 'tests/my_theme/thumbnails') mocked_create_paths.assert_called_once_with( Path('tests/my_theme'), Path('tests/my_theme/thumbnails')) def test_click_on_new_theme(self): """ Test the on_add_theme event handler is called by the UI """ # GIVEN: An initial form Settings().setValue('themes/global theme', 'my_theme') mocked_event = MagicMock() self.theme_manager.on_add_theme = mocked_event self.theme_manager.setup_ui(self.theme_manager) # WHEN displaying the UI and pressing cancel new_theme = self.theme_manager.toolbar.actions['newTheme'] new_theme.trigger() assert mocked_event.call_count == 1, 'The on_add_theme method should have been called once' @patch('openlp.core.ui.themeform.ThemeForm._setup') @patch('openlp.core.ui.filerenameform.FileRenameForm._setup') def test_bootstrap_post(self, mocked_rename_form, mocked_theme_form): """ Test the functions of bootstrap_post_setup are called. """ # GIVEN: self.theme_manager.theme_path = MagicMock() # WHEN: with patch('openlp.core.ui.thememanager.ThemeProgressForm'): self.theme_manager.bootstrap_post_set_up() # THEN: assert self.theme_manager.progress_form is not None assert self.theme_manager.theme_form is not None assert self.theme_manager.file_rename_form is not None def test_bootstrap_completion(self): """ Test the functions of bootstrap_post_setup are called. """ # GIVEN: self.theme_manager.load_themes = MagicMock() self.theme_manager.upgrade_themes = MagicMock() # WHEN: self.theme_manager.bootstrap_completion() # THEN: self.theme_manager.upgrade_themes.assert_called_once() self.theme_manager.load_themes.assert_called_once()