forked from openlp/openlp
Merge branch 'issue-302' into 'master'
Fix issue 302 with theme previews Closes #302 See merge request openlp/openlp!63
This commit is contained in:
commit
99508388d1
@ -670,6 +670,10 @@ class MainWindow(QtWidgets.QMainWindow, Ui_MainWindow, LogMixin, RegistryPropert
|
|||||||
self.application.process_events()
|
self.application.process_events()
|
||||||
plugin.first_time()
|
plugin.first_time()
|
||||||
self.application.process_events()
|
self.application.process_events()
|
||||||
|
# Load the themes from files
|
||||||
|
self.theme_manager_contents.load_first_time_themes()
|
||||||
|
# Update the theme widget
|
||||||
|
self.theme_manager_contents.load_themes()
|
||||||
temp_path = Path(gettempdir(), 'openlp')
|
temp_path = Path(gettempdir(), 'openlp')
|
||||||
shutil.rmtree(temp_path, True)
|
shutil.rmtree(temp_path, True)
|
||||||
|
|
||||||
@ -714,10 +718,6 @@ class MainWindow(QtWidgets.QMainWindow, Ui_MainWindow, LogMixin, RegistryPropert
|
|||||||
self.active_plugin.toggle_status(PluginStatus.Inactive)
|
self.active_plugin.toggle_status(PluginStatus.Inactive)
|
||||||
# Set global theme and
|
# Set global theme and
|
||||||
Registry().execute('theme_update_global')
|
Registry().execute('theme_update_global')
|
||||||
# Load the themes from files
|
|
||||||
self.theme_manager_contents.load_first_time_themes()
|
|
||||||
# Update the theme widget
|
|
||||||
self.theme_manager_contents.load_themes()
|
|
||||||
# Check if any Bibles downloaded. If there are, they will be processed.
|
# Check if any Bibles downloaded. If there are, they will be processed.
|
||||||
Registry().execute('bibles_load_list')
|
Registry().execute('bibles_load_list')
|
||||||
self.application.set_normal_cursor()
|
self.application.set_normal_cursor()
|
||||||
|
@ -149,16 +149,15 @@ class ThemeManager(QtWidgets.QWidget, RegistryBase, Ui_ThemeManager, LogMixin, R
|
|||||||
process the bootstrap initialise setup request
|
process the bootstrap initialise setup request
|
||||||
"""
|
"""
|
||||||
self.setup_ui(self)
|
self.setup_ui(self)
|
||||||
self.progress_form = ThemeProgressForm(self)
|
|
||||||
self.global_theme = Settings().value(self.settings_section + '/global theme')
|
self.global_theme = Settings().value(self.settings_section + '/global theme')
|
||||||
self.build_theme_path()
|
self.build_theme_path()
|
||||||
self.load_first_time_themes()
|
|
||||||
self.upgrade_themes() # TODO: Can be removed when upgrade path from OpenLP 2.4 no longer needed
|
self.upgrade_themes() # TODO: Can be removed when upgrade path from OpenLP 2.4 no longer needed
|
||||||
|
|
||||||
def bootstrap_post_set_up(self):
|
def bootstrap_post_set_up(self):
|
||||||
"""
|
"""
|
||||||
process the bootstrap post setup request
|
process the bootstrap post setup request
|
||||||
"""
|
"""
|
||||||
|
self.progress_form = ThemeProgressForm(self)
|
||||||
self.theme_form = ThemeForm(self)
|
self.theme_form = ThemeForm(self)
|
||||||
self.theme_form.path = self.theme_path
|
self.theme_form.path = self.theme_path
|
||||||
self.file_rename_form = FileRenameForm()
|
self.file_rename_form = FileRenameForm()
|
||||||
@ -481,6 +480,7 @@ class ThemeManager(QtWidgets.QWidget, RegistryBase, Ui_ThemeManager, LogMixin, R
|
|||||||
self.save_theme(theme)
|
self.save_theme(theme)
|
||||||
Settings().setValue(self.settings_section + '/global theme', theme.theme_name)
|
Settings().setValue(self.settings_section + '/global theme', theme.theme_name)
|
||||||
new_themes = [theme.theme_name]
|
new_themes = [theme.theme_name]
|
||||||
|
if new_themes:
|
||||||
self.update_preview_images(new_themes)
|
self.update_preview_images(new_themes)
|
||||||
self.application.set_normal_cursor()
|
self.application.set_normal_cursor()
|
||||||
|
|
||||||
|
@ -36,6 +36,8 @@ class ThemeProgressForm(QtWidgets.QDialog, UiThemeProgressDialog, RegistryProper
|
|||||||
super().__init__(parent)
|
super().__init__(parent)
|
||||||
self.setup_ui(self)
|
self.setup_ui(self)
|
||||||
self._theme_list = []
|
self._theme_list = []
|
||||||
|
|
||||||
|
def show(self):
|
||||||
self.progress_bar.setMinimum(0)
|
self.progress_bar.setMinimum(0)
|
||||||
self.progress_bar.setMaximum(0)
|
self.progress_bar.setMaximum(0)
|
||||||
self.progress_bar.setValue(0)
|
self.progress_bar.setValue(0)
|
||||||
@ -45,6 +47,7 @@ class ThemeProgressForm(QtWidgets.QDialog, UiThemeProgressDialog, RegistryProper
|
|||||||
except ZeroDivisionError:
|
except ZeroDivisionError:
|
||||||
self.ratio = 16 / 9
|
self.ratio = 16 / 9
|
||||||
self.theme_preview_layout.aspect_ratio = self.ratio
|
self.theme_preview_layout.aspect_ratio = self.ratio
|
||||||
|
return super().show()
|
||||||
|
|
||||||
def get_preview(self, theme_name, theme_data):
|
def get_preview(self, theme_name, theme_data):
|
||||||
self.label.setText(theme_name)
|
self.label.setText(theme_name)
|
||||||
|
@ -33,22 +33,24 @@ sys.modules['PyQt5.QtWebEngineWidgets'] = MagicMock()
|
|||||||
|
|
||||||
from openlp.core.display.window import DisplayWindow
|
from openlp.core.display.window import DisplayWindow
|
||||||
from tests.helpers.testmixin import TestMixin
|
from tests.helpers.testmixin import TestMixin
|
||||||
from openlp.core.common.settings import Settings
|
|
||||||
|
|
||||||
|
|
||||||
@patch('PyQt5.QtWidgets.QVBoxLayout')
|
@patch('PyQt5.QtWidgets.QVBoxLayout')
|
||||||
@patch('openlp.core.display.webengine.WebEngineView')
|
@patch('openlp.core.display.webengine.WebEngineView')
|
||||||
|
@patch('openlp.core.display.window.Settings')
|
||||||
class TestDisplayWindow(TestCase, TestMixin):
|
class TestDisplayWindow(TestCase, TestMixin):
|
||||||
"""
|
"""
|
||||||
A test suite to test the functions in DisplayWindow
|
A test suite to test the functions in DisplayWindow
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def test_x11_override_on(self, mocked_webengine, mocked_addWidget):
|
def test_x11_override_on(self, MockSettings, mocked_webengine, mocked_addWidget):
|
||||||
"""
|
"""
|
||||||
Test that the x11 override option bit is set
|
Test that the x11 override option bit is set
|
||||||
"""
|
"""
|
||||||
# GIVEN: x11 bypass is on
|
# GIVEN: x11 bypass is on
|
||||||
Settings().setValue('advanced/x11 bypass wm', True)
|
mocked_settings = MagicMock()
|
||||||
|
mocked_settings.value.return_value = True
|
||||||
|
MockSettings.return_value = mocked_settings
|
||||||
|
|
||||||
# WHEN: A DisplayWindow is generated
|
# WHEN: A DisplayWindow is generated
|
||||||
display_window = DisplayWindow()
|
display_window = DisplayWindow()
|
||||||
@ -57,12 +59,14 @@ class TestDisplayWindow(TestCase, TestMixin):
|
|||||||
x11_bit = display_window.windowFlags() & QtCore.Qt.X11BypassWindowManagerHint
|
x11_bit = display_window.windowFlags() & QtCore.Qt.X11BypassWindowManagerHint
|
||||||
assert x11_bit == QtCore.Qt.X11BypassWindowManagerHint
|
assert x11_bit == QtCore.Qt.X11BypassWindowManagerHint
|
||||||
|
|
||||||
def test_x11_override_off(self, mocked_webengine, mocked_addWidget):
|
def test_x11_override_off(self, MockSettings, mocked_webengine, mocked_addWidget):
|
||||||
"""
|
"""
|
||||||
Test that the x11 override option bit is not set when setting if off
|
Test that the x11 override option bit is not set when setting if off
|
||||||
"""
|
"""
|
||||||
# GIVEN: x11 bypass is off
|
# GIVEN: x11 bypass is off
|
||||||
Settings().setValue('advanced/x11 bypass wm', False)
|
mocked_settings = MagicMock()
|
||||||
|
mocked_settings.value.return_value = False
|
||||||
|
MockSettings.return_value = mocked_settings
|
||||||
|
|
||||||
# WHEN: A DisplayWindow is generated
|
# WHEN: A DisplayWindow is generated
|
||||||
display_window = DisplayWindow()
|
display_window = DisplayWindow()
|
||||||
|
@ -28,9 +28,9 @@ from unittest.mock import MagicMock, patch
|
|||||||
from openlp.core.ui.themeform import ThemeForm
|
from openlp.core.ui.themeform import ThemeForm
|
||||||
|
|
||||||
|
|
||||||
class TestThemeManager(TestCase):
|
class TestThemeForm(TestCase):
|
||||||
"""
|
"""
|
||||||
Test the functions in the ThemeManager Class
|
Test the functions in the ThemeForm Class
|
||||||
"""
|
"""
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
with patch('openlp.core.ui.themeform.ThemeForm._setup'):
|
with patch('openlp.core.ui.themeform.ThemeForm._setup'):
|
||||||
|
@ -58,19 +58,16 @@ class TestThemeManager(TestCase, TestMixin):
|
|||||||
# GIVEN: A new a call to initialise
|
# GIVEN: A new a call to initialise
|
||||||
self.theme_manager.setup_ui = MagicMock()
|
self.theme_manager.setup_ui = MagicMock()
|
||||||
self.theme_manager.build_theme_path = MagicMock()
|
self.theme_manager.build_theme_path = MagicMock()
|
||||||
self.theme_manager.load_first_time_themes = MagicMock()
|
|
||||||
self.theme_manager.upgrade_themes = MagicMock()
|
self.theme_manager.upgrade_themes = MagicMock()
|
||||||
Settings().setValue('themes/global theme', 'my_theme')
|
Settings().setValue('themes/global theme', 'my_theme')
|
||||||
|
|
||||||
# WHEN: the initialisation is run
|
# WHEN: the initialisation is run
|
||||||
with patch('openlp.core.ui.thememanager.ThemeProgressForm'):
|
|
||||||
self.theme_manager.bootstrap_initialise()
|
self.theme_manager.bootstrap_initialise()
|
||||||
|
|
||||||
# THEN:
|
# THEN:
|
||||||
self.theme_manager.setup_ui.assert_called_once_with(self.theme_manager)
|
self.theme_manager.setup_ui.assert_called_once_with(self.theme_manager)
|
||||||
assert self.theme_manager.global_theme == 'my_theme'
|
assert self.theme_manager.global_theme == 'my_theme'
|
||||||
self.theme_manager.build_theme_path.assert_called_once_with()
|
self.theme_manager.build_theme_path.assert_called_once_with()
|
||||||
self.theme_manager.load_first_time_themes.assert_called_once_with()
|
|
||||||
self.theme_manager.upgrade_themes.assert_called_once_with()
|
self.theme_manager.upgrade_themes.assert_called_once_with()
|
||||||
|
|
||||||
@patch('openlp.core.ui.thememanager.create_paths')
|
@patch('openlp.core.ui.thememanager.create_paths')
|
||||||
@ -117,6 +114,7 @@ class TestThemeManager(TestCase, TestMixin):
|
|||||||
self.theme_manager.theme_path = MagicMock()
|
self.theme_manager.theme_path = MagicMock()
|
||||||
|
|
||||||
# WHEN:
|
# WHEN:
|
||||||
|
with patch('openlp.core.ui.thememanager.ThemeProgressForm'):
|
||||||
self.theme_manager.bootstrap_post_set_up()
|
self.theme_manager.bootstrap_post_set_up()
|
||||||
|
|
||||||
# THEN:
|
# THEN:
|
||||||
|
142
tests/openlp_core/ui/test_themeprogressform.py
Normal file
142
tests/openlp_core/ui/test_themeprogressform.py
Normal file
@ -0,0 +1,142 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
##########################################################################
|
||||||
|
# OpenLP - Open Source Lyrics Projection #
|
||||||
|
# ---------------------------------------------------------------------- #
|
||||||
|
# Copyright (c) 2008-2019 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, either version 3 of the License, or #
|
||||||
|
# (at your option) any later version. #
|
||||||
|
# #
|
||||||
|
# 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, see <https://www.gnu.org/licenses/>. #
|
||||||
|
##########################################################################
|
||||||
|
"""
|
||||||
|
Package to test the openlp.core.ui.themeform package.
|
||||||
|
"""
|
||||||
|
# from pathlib import Path
|
||||||
|
from unittest import TestCase
|
||||||
|
from unittest.mock import MagicMock, patch
|
||||||
|
|
||||||
|
from openlp.core.ui.themeprogressform import ThemeProgressForm
|
||||||
|
from tests.helpers.testmixin import TestMixin
|
||||||
|
|
||||||
|
|
||||||
|
class TestThemeProgressForm(TestCase, TestMixin):
|
||||||
|
"""
|
||||||
|
Test the functions in the ThemeProgressForm class
|
||||||
|
"""
|
||||||
|
def setUp(self):
|
||||||
|
self.setup_application()
|
||||||
|
|
||||||
|
def tearDown(self):
|
||||||
|
del self.app
|
||||||
|
|
||||||
|
def _get_theme_progress_form(self):
|
||||||
|
"""Common code used to create the ThemeProgressForm object"""
|
||||||
|
with patch('openlp.core.ui.themeprogressdialog.ThemePreviewRenderer'), \
|
||||||
|
patch('openlp.core.ui.themeprogressdialog.UiThemeProgressDialog.setup_ui'):
|
||||||
|
form = ThemeProgressForm()
|
||||||
|
return form
|
||||||
|
|
||||||
|
def test_init(self):
|
||||||
|
"""Test that the ThemeProgressForm is created without problems"""
|
||||||
|
# GIVEN: ThemeProgressForm class
|
||||||
|
# WHEN: An object is instatiated
|
||||||
|
# THEN: There is no problem
|
||||||
|
self._get_theme_progress_form()
|
||||||
|
|
||||||
|
@patch('openlp.core.ui.themeprogressform.ScreenList')
|
||||||
|
@patch('openlp.core.ui.themeprogressform.QtWidgets.QDialog.show')
|
||||||
|
def test_show(self, mocked_show, MockScreenList):
|
||||||
|
"""Test that the ThemeProgressForm is created without problems"""
|
||||||
|
# GIVEN: ThemeProgressForm object
|
||||||
|
form = self._get_theme_progress_form()
|
||||||
|
mocked_screen_list = MagicMock()
|
||||||
|
mocked_screen_list.current.display_geometry.width.return_value = 1920
|
||||||
|
mocked_screen_list.current.display_geometry.height.return_value = 1080
|
||||||
|
MockScreenList.return_value = mocked_screen_list
|
||||||
|
form.progress_bar = MagicMock()
|
||||||
|
form.theme_preview_layout = MagicMock()
|
||||||
|
|
||||||
|
# WHEN: The show() method is called
|
||||||
|
form.show()
|
||||||
|
|
||||||
|
# THEN: The correct display ratio is calculated and the form is shown
|
||||||
|
expected_ratio = 16 / 9
|
||||||
|
form.progress_bar.setMinimum.assert_called_once_with(0)
|
||||||
|
form.progress_bar.setMaximum.assert_called_once_with(0)
|
||||||
|
form.progress_bar.setValue.assert_called_once_with(0)
|
||||||
|
assert form.ratio == expected_ratio
|
||||||
|
assert form.theme_preview_layout.aspect_ratio == expected_ratio
|
||||||
|
mocked_show.assert_called_once()
|
||||||
|
|
||||||
|
@patch('openlp.core.ui.themeprogressform.ScreenList')
|
||||||
|
@patch('openlp.core.ui.themeprogressform.QtWidgets.QDialog.show')
|
||||||
|
def test_show_divide_by_zero(self, mocked_show, MockScreenList):
|
||||||
|
"""Test that the ThemeProgressForm is created without problems even if there's a divide by zero exception"""
|
||||||
|
# GIVEN: ThemeProgressForm object
|
||||||
|
form = self._get_theme_progress_form()
|
||||||
|
mocked_screen_list = MagicMock()
|
||||||
|
mocked_screen_list.current.display_geometry.width.return_value = 1920
|
||||||
|
mocked_screen_list.current.display_geometry.height.return_value = 0
|
||||||
|
MockScreenList.return_value = mocked_screen_list
|
||||||
|
form.progress_bar = MagicMock()
|
||||||
|
form.theme_preview_layout = MagicMock()
|
||||||
|
|
||||||
|
# WHEN: The show() method is called
|
||||||
|
form.show()
|
||||||
|
|
||||||
|
# THEN: The correct display ratio is calculated and the form is shown
|
||||||
|
expected_ratio = 16 / 9
|
||||||
|
form.progress_bar.setMinimum.assert_called_once_with(0)
|
||||||
|
form.progress_bar.setMaximum.assert_called_once_with(0)
|
||||||
|
form.progress_bar.setValue.assert_called_once_with(0)
|
||||||
|
assert form.ratio == expected_ratio
|
||||||
|
assert form.theme_preview_layout.aspect_ratio == expected_ratio
|
||||||
|
mocked_show.assert_called_once()
|
||||||
|
|
||||||
|
def test_get_preview(self):
|
||||||
|
"""Test that the get_preview() method returns a preview image"""
|
||||||
|
# GIVEN: ThemeProgressForm object
|
||||||
|
test_theme_name = 'Test Theme'
|
||||||
|
test_theme_data = {'name': test_theme_name}
|
||||||
|
form = self._get_theme_progress_form()
|
||||||
|
form.progress_bar = MagicMock(**{'value.return_value': 0})
|
||||||
|
form.label = MagicMock()
|
||||||
|
form.theme_display = MagicMock(**{'width.return_value': 192, 'generate_preview.return_value': 'preview'})
|
||||||
|
form.renderer.width = MagicMock(return_value=1920)
|
||||||
|
|
||||||
|
# WHEN: get_preview() is called
|
||||||
|
preview = form.get_preview(test_theme_name, test_theme_data)
|
||||||
|
|
||||||
|
# THEN: All the correct methods should be called and the correct results should be returned
|
||||||
|
form.label.setText.assert_called_once_with(test_theme_name)
|
||||||
|
form.progress_bar.value.assert_called_once()
|
||||||
|
form.progress_bar.setValue.assert_called_once_with(1)
|
||||||
|
form.theme_display.width.assert_called_once()
|
||||||
|
form.renderer.width.assert_called_once()
|
||||||
|
form.theme_display.set_scale.assert_called_once_with(0.1)
|
||||||
|
form.theme_display.generate_preview.assert_called_once_with(test_theme_data, generate_screenshot=True)
|
||||||
|
assert preview == 'preview'
|
||||||
|
|
||||||
|
def test_theme_list(self):
|
||||||
|
# GIVEN: ThemeProgressForm object and theme list
|
||||||
|
test_theme_list = ['Theme 1', 'Theme 2']
|
||||||
|
form = self._get_theme_progress_form()
|
||||||
|
form.progress_bar = MagicMock()
|
||||||
|
|
||||||
|
# WHEN: theme_list is set and get'ed
|
||||||
|
form.theme_list = test_theme_list
|
||||||
|
theme_list = form.theme_list
|
||||||
|
|
||||||
|
# THEN: The theme list should be correct
|
||||||
|
form.progress_bar.setMaximum.assert_called_once_with(2)
|
||||||
|
assert theme_list == test_theme_list
|
Loading…
Reference in New Issue
Block a user