diff --git a/openlp/core/common/__init__.py b/openlp/core/common/__init__.py index e891e5502..b382a719f 100644 --- a/openlp/core/common/__init__.py +++ b/openlp/core/common/__init__.py @@ -242,3 +242,18 @@ from .settings import Settings from .applocation import AppLocation from .actions import ActionList from .languagemanager import LanguageManager + + +def add_actions(target, actions): + """ + Adds multiple actions to a menu or toolbar in one command. + + :param target: The menu or toolbar to add actions to + :param actions: The actions to be added. An action consisting of the keyword ``None`` + will result in a separator being inserted into the target. + """ + for action in actions: + if action is None: + target.addSeparator() + else: + target.addAction(action) diff --git a/openlp/core/ui/mainwindow.py b/openlp/core/ui/mainwindow.py index 3fd154c14..9618b1c48 100644 --- a/openlp/core/ui/mainwindow.py +++ b/openlp/core/ui/mainwindow.py @@ -35,7 +35,7 @@ from tempfile import gettempdir from PyQt5 import QtCore, QtGui, QtWidgets from openlp.core.common import Registry, RegistryProperties, AppLocation, LanguageManager, Settings, \ - check_directory_exists, translate, is_win, is_macosx + check_directory_exists, translate, is_win, is_macosx, add_actions from openlp.core.common.actions import ActionList, CategoryOrder from openlp.core.lib import Renderer, OpenLPDockWidget, PluginManager, ImageManager, PluginStatus, ScreenList, \ build_icon @@ -46,7 +46,7 @@ from openlp.core.ui.firsttimeform import FirstTimeForm from openlp.core.ui.media import MediaController from openlp.core.ui.printserviceform import PrintServiceForm from openlp.core.ui.projector.manager import ProjectorManager -from openlp.core.utils import get_application_version, add_actions +from openlp.core.utils import get_application_version log = logging.getLogger(__name__) diff --git a/openlp/core/utils/__init__.py b/openlp/core/utils/__init__.py index 72fe6c138..68b807b3c 100644 --- a/openlp/core/utils/__init__.py +++ b/openlp/core/utils/__init__.py @@ -267,21 +267,6 @@ def check_latest_version(current_version): return version_string -def add_actions(target, actions): - """ - Adds multiple actions to a menu or toolbar in one command. - - :param target: The menu or toolbar to add actions to - :param actions: The actions to be added. An action consisting of the keyword ``None`` - will result in a separator being inserted into the target. - """ - for action in actions: - if action is None: - target.addSeparator() - else: - target.addAction(action) - - def get_filesystem_encoding(): """ Returns the name of the encoding used to convert Unicode filenames into system file names. @@ -535,5 +520,5 @@ def get_natural_key(string): return key __all__ = ['get_application_version', 'check_latest_version', - 'add_actions', 'get_filesystem_encoding', 'get_web_page', 'get_uno_command', 'get_uno_instance', + 'get_filesystem_encoding', 'get_web_page', 'get_uno_command', 'get_uno_instance', 'delete_file', 'clean_filename', 'format_time', 'get_locale_key', 'get_natural_key'] diff --git a/tests/functional/openlp_core_common/test_init.py b/tests/functional/openlp_core_common/test_init.py new file mode 100644 index 000000000..70fe6e943 --- /dev/null +++ b/tests/functional/openlp_core_common/test_init.py @@ -0,0 +1,95 @@ +# -*- coding: utf-8 -*- +# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4 + +############################################################################### +# OpenLP - Open Source Lyrics Projection # +# --------------------------------------------------------------------------- # +# Copyright (c) 2008-2016 OpenLP Developers # +# --------------------------------------------------------------------------- # +# This program is free software; you can redistribute it and/or modify it # +# under the terms of the GNU General Public License as published by the Free # +# Software Foundation; version 2 of the License. # +# # +# This program is distributed in the hope that it will be useful, but WITHOUT # +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or # +# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for # +# more details. # +# # +# You should have received a copy of the GNU General Public License along # +# with this program; if not, write to the Free Software Foundation, Inc., 59 # +# Temple Place, Suite 330, Boston, MA 02111-1307 USA # +############################################################################### +""" +Functional tests to test the AppLocation class and related methods. +""" +import os +from unittest import TestCase + +from openlp.core.common import add_actions +from tests.functional import MagicMock, patch + + +class TestInit(TestCase): + """ + A test suite to test out various methods around the common __init__ class. + """ + + def add_actions_empty_list_test(self): + """ + Test that no actions are added when the list is empty + """ + # GIVEN: a mocked action list, and an empty list + mocked_target = MagicMock() + empty_list = [] + + # WHEN: The empty list is added to the mocked target + add_actions(mocked_target, empty_list) + + # THEN: The add method on the mocked target is never called + self.assertEqual(0, mocked_target.addSeparator.call_count, 'addSeparator method should not have been called') + self.assertEqual(0, mocked_target.addAction.call_count, 'addAction method should not have been called') + + def add_actions_none_action_test(self): + """ + Test that a separator is added when a None action is in the list + """ + # GIVEN: a mocked action list, and a list with None in it + mocked_target = MagicMock() + separator_list = [None] + + # WHEN: The list is added to the mocked target + add_actions(mocked_target, separator_list) + + # THEN: The addSeparator method is called, but the addAction method is never called + mocked_target.addSeparator.assert_called_with() + self.assertEqual(0, mocked_target.addAction.call_count, 'addAction method should not have been called') + + def add_actions_add_action_test(self): + """ + Test that an action is added when a valid action is in the list + """ + # GIVEN: a mocked action list, and a list with an action in it + mocked_target = MagicMock() + action_list = ['action'] + + # WHEN: The list is added to the mocked target + add_actions(mocked_target, action_list) + + # THEN: The addSeparator method is not called, and the addAction method is called + self.assertEqual(0, mocked_target.addSeparator.call_count, 'addSeparator method should not have been called') + mocked_target.addAction.assert_called_with('action') + + def add_actions_action_and_none_test(self): + """ + Test that an action and a separator are added when a valid action and None are in the list + """ + # GIVEN: a mocked action list, and a list with an action and None in it + mocked_target = MagicMock() + action_list = ['action', None] + + # WHEN: The list is added to the mocked target + add_actions(mocked_target, action_list) + + # THEN: The addSeparator method is called, and the addAction method is called + mocked_target.addSeparator.assert_called_with() + mocked_target.addAction.assert_called_with('action') diff --git a/tests/functional/openlp_core_utils/test_utils.py b/tests/functional/openlp_core_utils/test_utils.py index a9e402369..fd033cd88 100644 --- a/tests/functional/openlp_core_utils/test_utils.py +++ b/tests/functional/openlp_core_utils/test_utils.py @@ -26,7 +26,8 @@ import os from unittest import TestCase from openlp.core.utils import clean_filename, delete_file, get_filesystem_encoding, get_locale_key, \ - get_natural_key, split_filename, _get_user_agent, get_web_page, get_uno_instance, add_actions + get_natural_key, split_filename, _get_user_agent, get_web_page, get_uno_instance + from tests.functional import MagicMock, patch @@ -34,65 +35,6 @@ class TestUtils(TestCase): """ A test suite to test out various methods around the AppLocation class. """ - def add_actions_empty_list_test(self): - """ - Test that no actions are added when the list is empty - """ - # GIVEN: a mocked action list, and an empty list - mocked_target = MagicMock() - empty_list = [] - - # WHEN: The empty list is added to the mocked target - add_actions(mocked_target, empty_list) - - # THEN: The add method on the mocked target is never called - self.assertEqual(0, mocked_target.addSeparator.call_count, 'addSeparator method should not have been called') - self.assertEqual(0, mocked_target.addAction.call_count, 'addAction method should not have been called') - - def add_actions_none_action_test(self): - """ - Test that a separator is added when a None action is in the list - """ - # GIVEN: a mocked action list, and a list with None in it - mocked_target = MagicMock() - separator_list = [None] - - # WHEN: The list is added to the mocked target - add_actions(mocked_target, separator_list) - - # THEN: The addSeparator method is called, but the addAction method is never called - mocked_target.addSeparator.assert_called_with() - self.assertEqual(0, mocked_target.addAction.call_count, 'addAction method should not have been called') - - def add_actions_add_action_test(self): - """ - Test that an action is added when a valid action is in the list - """ - # GIVEN: a mocked action list, and a list with an action in it - mocked_target = MagicMock() - action_list = ['action'] - - # WHEN: The list is added to the mocked target - add_actions(mocked_target, action_list) - - # THEN: The addSeparator method is not called, and the addAction method is called - self.assertEqual(0, mocked_target.addSeparator.call_count, 'addSeparator method should not have been called') - mocked_target.addAction.assert_called_with('action') - - def add_actions_action_and_none_test(self): - """ - Test that an action and a separator are added when a valid action and None are in the list - """ - # GIVEN: a mocked action list, and a list with an action and None in it - mocked_target = MagicMock() - action_list = ['action', None] - - # WHEN: The list is added to the mocked target - add_actions(mocked_target, action_list) - - # THEN: The addSeparator method is called, and the addAction method is called - mocked_target.addSeparator.assert_called_with() - mocked_target.addAction.assert_called_with('action') def get_filesystem_encoding_sys_function_not_called_test(self): """