# -*- coding: utf-8 -*- # vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4 ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # # Copyright (c) 2008-2015 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 # ############################################################################### """ Package to test the openlp.core.__init__ package. """ import os from unittest import TestCase from PyQt4 import QtCore, QtGui from openlp.core import OpenLP, parse_options from openlp.core.common import Settings from tests.helpers.testmixin import TestMixin from tests.functional import MagicMock, patch, call TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), '..', 'resources')) class TestInit(TestCase, TestMixin): def setUp(self): self.build_settings() with patch('openlp.core.common.OpenLPMixin.__init__') as constructor: constructor.return_value = None self.openlp = OpenLP(list()) def tearDown(self): self.destroy_settings() del self.openlp def event_test(self): """ Test the reimplemented event method """ # GIVEN: A file path and a QEvent. file_path = os.path.join(TEST_PATH, 'church.jpg') mocked_file_method = MagicMock(return_value=file_path) event = QtCore.QEvent(QtCore.QEvent.FileOpen) event.file = mocked_file_method # WHEN: Call the vent method. result = self.openlp.event(event) # THEN: The path should be inserted. self.assertTrue(result, "The method should have returned True.") mocked_file_method.assert_called_once_with() self.assertEqual(self.openlp.args[0], file_path, "The path should be in args.") @patch('openlp.core.is_macosx') def application_activate_event_test(self, mocked_is_macosx): """ Test that clicking on the dock icon on Mac OS X restores the main window if it is minimized """ # GIVEN: Mac OS X and an ApplicationActivate event mocked_is_macosx.return_value = True event = MagicMock() event.type.return_value = QtCore.QEvent.ApplicationActivate mocked_main_window = MagicMock() self.openlp.main_window = mocked_main_window # WHEN: The icon in the dock is clicked result = self.openlp.event(event) # THEN: self.assertTrue(result, "The method should have returned True.") # self.assertFalse(self.openlp.main_window.isMinimized()) def backup_on_upgrade_first_install_test(self): """ Test that we don't try to backup on a new install """ # GIVEN: Mocked data version and OpenLP version which are the same old_install = False MOCKED_VERSION = { 'full': '2.2.0-bzr000', 'version': '2.2.0', 'build': 'bzr000' } Settings().setValue('core/application version', '2.2.0') with patch('openlp.core.get_application_version') as mocked_get_application_version,\ patch('openlp.core.QtGui.QMessageBox.question') as mocked_question: mocked_get_application_version.return_value = MOCKED_VERSION mocked_question.return_value = QtGui.QMessageBox.No # WHEN: We check if a backup should be created self.openlp.backup_on_upgrade(old_install) # THEN: It should not ask if we want to create a backup self.assertEqual(Settings().value('core/application version'), '2.2.0', 'Version should be the same!') self.assertEqual(mocked_question.call_count, 0, 'No question should have been asked!') def backup_on_upgrade_test(self): """ Test that we try to backup on a new install """ # GIVEN: Mocked data version and OpenLP version which are different old_install = True MOCKED_VERSION = { 'full': '2.2.0-bzr000', 'version': '2.2.0', 'build': 'bzr000' } Settings().setValue('core/application version', '2.0.5') with patch('openlp.core.get_application_version') as mocked_get_application_version,\ patch('openlp.core.QtGui.QMessageBox.question') as mocked_question: mocked_get_application_version.return_value = MOCKED_VERSION mocked_question.return_value = QtGui.QMessageBox.No # WHEN: We check if a backup should be created self.openlp.backup_on_upgrade(old_install) # THEN: It should ask if we want to create a backup self.assertEqual(Settings().value('core/application version'), '2.2.0', 'Version should be upgraded!') self.assertEqual(mocked_question.call_count, 1, 'A question should have been asked!') @patch(u'openlp.core.OptionParser') def parse_options_test(self, MockedOptionParser): """ Test that parse_options sets up OptionParser correctly and parses the options given """ # GIVEN: A list of valid options and a mocked out OptionParser object options = ['-e', '-l', 'debug', '-pd', '-s', 'style', 'extra', 'qt', 'args'] mocked_parser = MagicMock() MockedOptionParser.return_value = mocked_parser expected_calls = [ call('-e', '--no-error-form', dest='no_error_form', action='store_true', help='Disable the error notification form.'), call('-l', '--log-level', dest='loglevel', default='warning', metavar='LEVEL', help='Set logging to LEVEL level. Valid values are "debug", "info", "warning".'), call('-p', '--portable', dest='portable', action='store_true', help='Specify if this should be run as a portable app, off a USB flash drive (not implemented).'), call('-d', '--dev-version', dest='dev_version', action='store_true', help='Ignore the version file and pull the version directly from Bazaar'), call('-s', '--style', dest='style', help='Set the Qt4 style (passed directly to Qt4).') ] # WHEN: Calling parse_options parse_options(options) # THEN: A tuple should be returned with the parsed options and left over options MockedOptionParser.assert_called_with(usage='Usage: %prog [options] [qt-options]') self.assertEquals(expected_calls, mocked_parser.add_option.call_args_list) mocked_parser.parse_args.assert_called_with(options) @patch(u'openlp.core.OptionParser') def parse_options_from_sys_argv_test(self, MockedOptionParser): """ Test that parse_options sets up OptionParser correctly and parses sys.argv """ # GIVEN: A list of valid options and a mocked out OptionParser object mocked_parser = MagicMock() MockedOptionParser.return_value = mocked_parser expected_calls = [ call('-e', '--no-error-form', dest='no_error_form', action='store_true', help='Disable the error notification form.'), call('-l', '--log-level', dest='loglevel', default='warning', metavar='LEVEL', help='Set logging to LEVEL level. Valid values are "debug", "info", "warning".'), call('-p', '--portable', dest='portable', action='store_true', help='Specify if this should be run as a portable app, off a USB flash drive (not implemented).'), call('-d', '--dev-version', dest='dev_version', action='store_true', help='Ignore the version file and pull the version directly from Bazaar'), call('-s', '--style', dest='style', help='Set the Qt4 style (passed directly to Qt4).') ] # WHEN: Calling parse_options parse_options([]) # THEN: A tuple should be returned with the parsed options and left over options MockedOptionParser.assert_called_with(usage='Usage: %prog [options] [qt-options]') self.assertEquals(expected_calls, mocked_parser.add_option.call_args_list) mocked_parser.parse_args.assert_called_with()