2014-10-25 20:26:19 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4
|
|
|
|
|
|
|
|
###############################################################################
|
|
|
|
# OpenLP - Open Source Lyrics Projection #
|
|
|
|
# --------------------------------------------------------------------------- #
|
2016-12-31 11:01:36 +00:00
|
|
|
# Copyright (c) 2008-2017 OpenLP Developers #
|
2014-10-25 20:26:19 +00:00
|
|
|
# --------------------------------------------------------------------------- #
|
|
|
|
# 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.ui.settingsform package.
|
|
|
|
"""
|
|
|
|
from unittest import TestCase
|
2017-04-24 05:17:55 +00:00
|
|
|
from unittest.mock import MagicMock, patch
|
|
|
|
|
|
|
|
from PyQt5 import QtWidgets
|
2014-10-25 20:26:19 +00:00
|
|
|
|
|
|
|
from openlp.core.common import Registry
|
|
|
|
from openlp.core.ui.settingsform import SettingsForm
|
|
|
|
|
|
|
|
|
|
|
|
class TestSettingsForm(TestCase):
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
"""
|
|
|
|
Set up a few things for the tests
|
|
|
|
"""
|
|
|
|
Registry.create()
|
|
|
|
|
2016-05-31 21:40:13 +00:00
|
|
|
def test_insert_tab_visible(self):
|
2014-10-25 20:26:19 +00:00
|
|
|
"""
|
|
|
|
Test that the insert_tab() method works correctly when a visible tab is inserted
|
|
|
|
"""
|
|
|
|
# GIVEN: A mocked tab and a Settings Form
|
|
|
|
settings_form = SettingsForm(None)
|
|
|
|
general_tab = MagicMock()
|
|
|
|
general_tab.tab_title = 'mock'
|
|
|
|
general_tab.tab_title_visible = 'Mock'
|
2016-10-27 17:45:50 +00:00
|
|
|
general_tab.icon_path = ':/icon/openlp-logo.svg'
|
2014-10-25 20:26:19 +00:00
|
|
|
|
|
|
|
# WHEN: We insert the general tab
|
|
|
|
with patch.object(settings_form.stacked_layout, 'addWidget') as mocked_add_widget, \
|
|
|
|
patch.object(settings_form.setting_list_widget, 'addItem') as mocked_add_item:
|
|
|
|
settings_form.insert_tab(general_tab, is_visible=True)
|
|
|
|
|
2014-10-28 19:02:06 +00:00
|
|
|
# THEN: The general tab should have been inserted into the stacked layout and an item inserted into the list
|
2014-10-25 20:26:19 +00:00
|
|
|
mocked_add_widget.assert_called_with(general_tab)
|
|
|
|
self.assertEqual(1, mocked_add_item.call_count, 'addItem should have been called')
|
|
|
|
|
2016-05-31 21:40:13 +00:00
|
|
|
def test_insert_tab_not_visible(self):
|
2014-10-25 20:26:19 +00:00
|
|
|
"""
|
|
|
|
Test that the insert_tab() method works correctly when a tab that should not be visible is inserted
|
|
|
|
"""
|
|
|
|
# GIVEN: A general tab and a Settings Form
|
|
|
|
settings_form = SettingsForm(None)
|
|
|
|
general_tab = MagicMock()
|
|
|
|
general_tab.tab_title = 'mock'
|
|
|
|
|
|
|
|
# WHEN: We insert the general tab
|
|
|
|
with patch.object(settings_form.stacked_layout, 'addWidget') as mocked_add_widget, \
|
|
|
|
patch.object(settings_form.setting_list_widget, 'addItem') as mocked_add_item:
|
|
|
|
settings_form.insert_tab(general_tab, is_visible=False)
|
|
|
|
|
2014-10-28 19:02:06 +00:00
|
|
|
# THEN: The general tab should have been inserted, but no list item should have been inserted into the list
|
2014-10-25 20:26:19 +00:00
|
|
|
mocked_add_widget.assert_called_with(general_tab)
|
|
|
|
self.assertEqual(0, mocked_add_item.call_count, 'addItem should not have been called')
|
2014-10-28 19:02:06 +00:00
|
|
|
|
2016-05-31 21:40:13 +00:00
|
|
|
def test_accept_with_inactive_plugins(self):
|
2014-10-28 19:40:01 +00:00
|
|
|
"""
|
|
|
|
Test that the accept() method works correctly when some of the plugins are inactive
|
|
|
|
"""
|
|
|
|
# GIVEN: A visible general tab and an invisible theme tab in a Settings Form
|
|
|
|
settings_form = SettingsForm(None)
|
2015-11-07 00:49:40 +00:00
|
|
|
general_tab = QtWidgets.QWidget(None)
|
2014-10-28 19:40:01 +00:00
|
|
|
general_tab.tab_title = 'mock-general'
|
|
|
|
general_tab.tab_title_visible = 'Mock General'
|
2016-10-27 17:45:50 +00:00
|
|
|
general_tab.icon_path = ':/icon/openlp-logo.svg'
|
2014-10-28 19:40:01 +00:00
|
|
|
mocked_general_save = MagicMock()
|
|
|
|
general_tab.save = mocked_general_save
|
2017-08-12 20:19:15 +00:00
|
|
|
mocked_general_load = MagicMock()
|
|
|
|
general_tab.load = mocked_general_load
|
2014-10-28 19:40:01 +00:00
|
|
|
settings_form.insert_tab(general_tab, is_visible=True)
|
2015-11-07 00:49:40 +00:00
|
|
|
themes_tab = QtWidgets.QWidget(None)
|
2014-10-28 19:40:01 +00:00
|
|
|
themes_tab.tab_title = 'mock-themes'
|
|
|
|
themes_tab.tab_title_visible = 'Mock Themes'
|
2016-10-27 17:45:50 +00:00
|
|
|
themes_tab.icon_path = ':/icon/openlp-logo.svg'
|
2014-10-28 19:40:01 +00:00
|
|
|
mocked_theme_save = MagicMock()
|
|
|
|
themes_tab.save = mocked_theme_save
|
2017-08-12 20:19:15 +00:00
|
|
|
mocked_theme_load = MagicMock()
|
|
|
|
themes_tab.load = mocked_theme_load
|
2014-10-28 19:40:01 +00:00
|
|
|
settings_form.insert_tab(themes_tab, is_visible=False)
|
|
|
|
|
|
|
|
# WHEN: The accept() method is called
|
|
|
|
settings_form.accept()
|
|
|
|
|
|
|
|
# THEN: The general tab's save() method should have been called, but not the themes tab
|
|
|
|
mocked_general_save.assert_called_with()
|
|
|
|
self.assertEqual(0, mocked_theme_save.call_count, 'The Themes tab\'s save() should not have been called')
|
2014-10-28 20:27:09 +00:00
|
|
|
|
2016-05-31 21:40:13 +00:00
|
|
|
def test_list_item_changed_invalid_item(self):
|
2014-10-28 19:02:06 +00:00
|
|
|
"""
|
|
|
|
Test that the list_item_changed() slot handles a non-existent item
|
|
|
|
"""
|
|
|
|
# GIVEN: A mocked tab inserted into a Settings Form
|
|
|
|
settings_form = SettingsForm(None)
|
2015-11-07 00:49:40 +00:00
|
|
|
general_tab = QtWidgets.QWidget(None)
|
2014-10-28 19:02:06 +00:00
|
|
|
general_tab.tab_title = 'mock'
|
|
|
|
general_tab.tab_title_visible = 'Mock'
|
2016-10-27 17:45:50 +00:00
|
|
|
general_tab.icon_path = ':/icon/openlp-logo.svg'
|
2017-08-12 20:19:15 +00:00
|
|
|
mocked_general_load = MagicMock()
|
|
|
|
general_tab.load = mocked_general_load
|
2014-10-28 19:02:06 +00:00
|
|
|
settings_form.insert_tab(general_tab, is_visible=True)
|
|
|
|
|
|
|
|
with patch.object(settings_form.stacked_layout, 'count') as mocked_count:
|
|
|
|
# WHEN: The list_item_changed() slot is called with an invalid item index
|
|
|
|
settings_form.list_item_changed(100)
|
|
|
|
|
|
|
|
# THEN: The rest of the method should not have been called
|
|
|
|
self.assertEqual(0, mocked_count.call_count, 'The count method of the stacked layout should not be called')
|
2014-10-30 22:53:06 +00:00
|
|
|
|
2016-05-31 21:40:13 +00:00
|
|
|
def test_reject_with_inactive_items(self):
|
2014-10-30 22:53:06 +00:00
|
|
|
"""
|
|
|
|
Test that the reject() method works correctly when some of the plugins are inactive
|
|
|
|
"""
|
|
|
|
# GIVEN: A visible general tab and an invisible theme tab in a Settings Form
|
|
|
|
settings_form = SettingsForm(None)
|
2015-11-07 00:49:40 +00:00
|
|
|
general_tab = QtWidgets.QWidget(None)
|
2014-10-30 22:53:06 +00:00
|
|
|
general_tab.tab_title = 'mock-general'
|
|
|
|
general_tab.tab_title_visible = 'Mock General'
|
2016-10-27 17:45:50 +00:00
|
|
|
general_tab.icon_path = ':/icon/openlp-logo.svg'
|
2014-10-30 22:53:06 +00:00
|
|
|
mocked_general_cancel = MagicMock()
|
|
|
|
general_tab.cancel = mocked_general_cancel
|
2017-08-12 20:19:15 +00:00
|
|
|
mocked_general_load = MagicMock()
|
|
|
|
general_tab.load = mocked_general_load
|
2014-10-30 22:53:06 +00:00
|
|
|
settings_form.insert_tab(general_tab, is_visible=True)
|
2015-11-07 00:49:40 +00:00
|
|
|
themes_tab = QtWidgets.QWidget(None)
|
2014-10-30 22:53:06 +00:00
|
|
|
themes_tab.tab_title = 'mock-themes'
|
|
|
|
themes_tab.tab_title_visible = 'Mock Themes'
|
2016-10-27 17:45:50 +00:00
|
|
|
themes_tab.icon_path = ':/icon/openlp-logo.svg'
|
2014-10-30 22:53:06 +00:00
|
|
|
mocked_theme_cancel = MagicMock()
|
|
|
|
themes_tab.cancel = mocked_theme_cancel
|
|
|
|
settings_form.insert_tab(themes_tab, is_visible=False)
|
|
|
|
|
|
|
|
# WHEN: The reject() method is called
|
|
|
|
settings_form.reject()
|
|
|
|
|
|
|
|
# THEN: The general tab's cancel() method should have been called, but not the themes tab
|
|
|
|
mocked_general_cancel.assert_called_with()
|
2014-11-06 09:42:54 +00:00
|
|
|
self.assertEqual(0, mocked_theme_cancel.call_count, 'The Themes tab\'s cancel() should not have been called')
|
2017-03-02 00:07:16 +00:00
|
|
|
|
|
|
|
def test_register_post_process(self):
|
|
|
|
"""
|
|
|
|
Test that the register_post_process() method works correctly
|
|
|
|
"""
|
|
|
|
# GIVEN: A settings form instance
|
|
|
|
settings_form = SettingsForm(None)
|
|
|
|
fake_function = MagicMock()
|
|
|
|
|
|
|
|
# WHEN: register_post_process() is called
|
|
|
|
settings_form.register_post_process(fake_function)
|
|
|
|
|
|
|
|
# THEN: The fake function should be in the settings form's list
|
|
|
|
assert fake_function in settings_form.processes
|