forked from openlp/openlp
A few fixes for the alpha.
This commit is contained in:
parent
0d2e9b9aa6
commit
a0616ddf0f
@ -106,10 +106,6 @@ class OpenLP(QtCore.QObject, LogMixin):
|
|||||||
else:
|
else:
|
||||||
QtCore.QCoreApplication.exit()
|
QtCore.QCoreApplication.exit()
|
||||||
sys.exit()
|
sys.exit()
|
||||||
# Correct stylesheet bugs
|
|
||||||
application_stylesheet = get_application_stylesheet()
|
|
||||||
if application_stylesheet:
|
|
||||||
self.setStyleSheet(application_stylesheet)
|
|
||||||
can_show_splash = Settings().value('core/show splash')
|
can_show_splash = Settings().value('core/show splash')
|
||||||
if can_show_splash:
|
if can_show_splash:
|
||||||
self.splash = SplashScreen()
|
self.splash = SplashScreen()
|
||||||
@ -122,6 +118,10 @@ class OpenLP(QtCore.QObject, LogMixin):
|
|||||||
loader()
|
loader()
|
||||||
self.main_window = MainWindow()
|
self.main_window = MainWindow()
|
||||||
self.main_window.installEventFilter(self.main_window)
|
self.main_window.installEventFilter(self.main_window)
|
||||||
|
# Correct stylesheet bugs
|
||||||
|
application_stylesheet = get_application_stylesheet()
|
||||||
|
if application_stylesheet:
|
||||||
|
self.main_window.setStyleSheet(application_stylesheet)
|
||||||
Registry().execute('bootstrap_initialise')
|
Registry().execute('bootstrap_initialise')
|
||||||
State().flush_preconditions()
|
State().flush_preconditions()
|
||||||
Registry().execute('bootstrap_post_set_up')
|
Registry().execute('bootstrap_post_set_up')
|
||||||
|
@ -173,6 +173,14 @@ class DisplayWindow(QtWidgets.QWidget, RegistryProperties):
|
|||||||
if len(ScreenList()) > 1 or Settings().value('core/display on monitor'):
|
if len(ScreenList()) > 1 or Settings().value('core/display on monitor'):
|
||||||
self.show()
|
self.show()
|
||||||
|
|
||||||
|
def deregister_display(self):
|
||||||
|
"""
|
||||||
|
De-register this displays callbacks in the registry to be able to remove it
|
||||||
|
"""
|
||||||
|
if self.is_display:
|
||||||
|
Registry().remove_function('live_display_hide', self.hide_display)
|
||||||
|
Registry().remove_function('live_display_show', self.show_display)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def is_initialised(self):
|
def is_initialised(self):
|
||||||
return self._is_initialised
|
return self._is_initialised
|
||||||
|
@ -100,7 +100,7 @@ class Ui_ExceptionDialog(object):
|
|||||||
'<strong>Oops, OpenLP hit a problem and couldn\'t recover!<br><br>'
|
'<strong>Oops, OpenLP hit a problem and couldn\'t recover!<br><br>'
|
||||||
'You can help </strong> the OpenLP developers to <strong>fix this</strong>'
|
'You can help </strong> the OpenLP developers to <strong>fix this</strong>'
|
||||||
' by<br> sending them a <strong>bug report to {email}</strong>{newlines}'
|
' by<br> sending them a <strong>bug report to {email}</strong>{newlines}'
|
||||||
).format(email='<a href = "mailto:bugs@openlp.org" > bugs@openlp.org</a>',
|
).format(email='<a href = "mailto:bugs3@openlp.org" > bugs3@openlp.org</a>',
|
||||||
newlines='<br><br>'))
|
newlines='<br><br>'))
|
||||||
self.message_label.setText(
|
self.message_label.setText(
|
||||||
translate('OpenLP.ExceptionDialog', '{first_part}'
|
translate('OpenLP.ExceptionDialog', '{first_part}'
|
||||||
|
@ -139,7 +139,7 @@ class ExceptionForm(QtWidgets.QDialog, Ui_ExceptionDialog, RegistryProperties):
|
|||||||
libs=content['libs']))
|
libs=content['libs']))
|
||||||
if self.file_attachment:
|
if self.file_attachment:
|
||||||
mail_urlquery.addQueryItem('attach', self.file_attachment)
|
mail_urlquery.addQueryItem('attach', self.file_attachment)
|
||||||
mail_to_url = QtCore.QUrl('mailto:bugs@openlp.org')
|
mail_to_url = QtCore.QUrl('mailto:bugs3@openlp.org')
|
||||||
mail_to_url.setQuery(mail_urlquery)
|
mail_to_url.setQuery(mail_urlquery)
|
||||||
QtGui.QDesktopServices.openUrl(mail_to_url)
|
QtGui.QDesktopServices.openUrl(mail_to_url)
|
||||||
|
|
||||||
|
@ -101,8 +101,9 @@ class FirstTimeForm(QtWidgets.QWizard, UiFirstTimeWizard, RegistryProperties):
|
|||||||
Create and set up the first time wizard.
|
Create and set up the first time wizard.
|
||||||
"""
|
"""
|
||||||
super(FirstTimeForm, self).__init__(parent)
|
super(FirstTimeForm, self).__init__(parent)
|
||||||
self.web_access = True
|
self.has_web_access = True
|
||||||
self.web = ''
|
self.web = ''
|
||||||
|
self.is_index_downloaded = False
|
||||||
self.setup_ui(self)
|
self.setup_ui(self)
|
||||||
self.customButtonClicked.connect(self._on_custom_button_clicked)
|
self.customButtonClicked.connect(self._on_custom_button_clicked)
|
||||||
self.themes_list_widget.itemSelectionChanged.connect(self.on_themes_list_widget_selection_changed)
|
self.themes_list_widget.itemSelectionChanged.connect(self.on_themes_list_widget_selection_changed)
|
||||||
@ -132,7 +133,7 @@ class FirstTimeForm(QtWidgets.QWizard, UiFirstTimeWizard, RegistryProperties):
|
|||||||
"""
|
"""
|
||||||
self.application.process_events()
|
self.application.process_events()
|
||||||
if self.currentId() == FirstTimePage.Download:
|
if self.currentId() == FirstTimePage.Download:
|
||||||
if not self.web_access:
|
if not self.has_web_access:
|
||||||
return FirstTimePage.NoInternet
|
return FirstTimePage.NoInternet
|
||||||
else:
|
else:
|
||||||
return FirstTimePage.Songs
|
return FirstTimePage.Songs
|
||||||
@ -164,11 +165,14 @@ class FirstTimeForm(QtWidgets.QWizard, UiFirstTimeWizard, RegistryProperties):
|
|||||||
"""
|
"""
|
||||||
Download the configuration file and kick off the theme screenshot download threads
|
Download the configuration file and kick off the theme screenshot download threads
|
||||||
"""
|
"""
|
||||||
|
# Check if the index file has already been downloaded
|
||||||
|
if self.is_index_downloaded:
|
||||||
|
return
|
||||||
# check to see if we have web access
|
# check to see if we have web access
|
||||||
self.web_access = False
|
self.has_web_access = False
|
||||||
self.config = ''
|
self.config = ''
|
||||||
web_config = None
|
web_config = None
|
||||||
user_agent = 'OpenLP/' + Registry().get('application').applicationVersion()
|
user_agent = 'OpenLP/' + QtWidgets.QApplication.applicationVersion()
|
||||||
self.application.process_events()
|
self.application.process_events()
|
||||||
try:
|
try:
|
||||||
web_config = get_web_page('{host}{name}'.format(host=self.web, name='download_3.0.json'),
|
web_config = get_web_page('{host}{name}'.format(host=self.web, name='download_3.0.json'),
|
||||||
@ -179,10 +183,11 @@ class FirstTimeForm(QtWidgets.QWizard, UiFirstTimeWizard, RegistryProperties):
|
|||||||
'to connect to retrieve initial configuration information'),
|
'to connect to retrieve initial configuration information'),
|
||||||
QtWidgets.QMessageBox.Ok)
|
QtWidgets.QMessageBox.Ok)
|
||||||
if web_config and self._parse_config(web_config):
|
if web_config and self._parse_config(web_config):
|
||||||
self.web_access = True
|
self.has_web_access = True
|
||||||
self.application.process_events()
|
self.application.process_events()
|
||||||
self.downloading = translate('OpenLP.FirstTimeWizard', 'Downloading {name}...')
|
self.downloading = translate('OpenLP.FirstTimeWizard', 'Downloading {name}...')
|
||||||
self.application.set_normal_cursor()
|
self.application.set_normal_cursor()
|
||||||
|
self.is_index_downloaded = True
|
||||||
|
|
||||||
def _parse_config(self, web_config):
|
def _parse_config(self, web_config):
|
||||||
try:
|
try:
|
||||||
@ -419,7 +424,7 @@ class FirstTimeForm(QtWidgets.QWizard, UiFirstTimeWizard, RegistryProperties):
|
|||||||
'download, so further downloads will be skipped. Try to re-run the '
|
'download, so further downloads will be skipped. Try to re-run the '
|
||||||
'First Time Wizard later.'))
|
'First Time Wizard later.'))
|
||||||
self.max_progress = 0
|
self.max_progress = 0
|
||||||
self.web_access = None
|
self.has_web_access = None
|
||||||
if self.max_progress:
|
if self.max_progress:
|
||||||
# Add on 2 for plugins status setting plus a "finished" point.
|
# Add on 2 for plugins status setting plus a "finished" point.
|
||||||
self.max_progress += 2
|
self.max_progress += 2
|
||||||
@ -465,7 +470,7 @@ class FirstTimeForm(QtWidgets.QWizard, UiFirstTimeWizard, RegistryProperties):
|
|||||||
Run the tasks in the wizard.
|
Run the tasks in the wizard.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
if self.web_access:
|
if self.has_web_access:
|
||||||
if not self._download_selected():
|
if not self._download_selected():
|
||||||
critical_error_message_box(translate('OpenLP.FirstTimeWizard', 'Download Error'),
|
critical_error_message_box(translate('OpenLP.FirstTimeWizard', 'Download Error'),
|
||||||
translate('OpenLP.FirstTimeWizard', 'There was a connection problem while '
|
translate('OpenLP.FirstTimeWizard', 'There was a connection problem while '
|
||||||
|
@ -28,7 +28,9 @@ from PyQt5 import QtGui, QtWidgets
|
|||||||
|
|
||||||
from openlp.core.common import Singleton
|
from openlp.core.common import Singleton
|
||||||
from openlp.core.common.applocation import AppLocation
|
from openlp.core.common.applocation import AppLocation
|
||||||
|
from openlp.core.common.settings import Settings
|
||||||
from openlp.core.lib import build_icon
|
from openlp.core.lib import build_icon
|
||||||
|
from openlp.core.ui.style import HAS_DARK_STYLE
|
||||||
|
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
@ -164,6 +166,7 @@ class UiIcons(metaclass=Singleton):
|
|||||||
"""
|
"""
|
||||||
Load the list of icons to be processed
|
Load the list of icons to be processed
|
||||||
"""
|
"""
|
||||||
|
is_dark = (HAS_DARK_STYLE and Settings().value('advanced/use_dark_style'))
|
||||||
for key in icon_list:
|
for key in icon_list:
|
||||||
try:
|
try:
|
||||||
icon = icon_list[key]['icon']
|
icon = icon_list[key]['icon']
|
||||||
@ -171,7 +174,10 @@ class UiIcons(metaclass=Singleton):
|
|||||||
attr = icon_list[key]['attr']
|
attr = icon_list[key]['attr']
|
||||||
setattr(self, key, qta.icon(icon, color=attr))
|
setattr(self, key, qta.icon(icon, color=attr))
|
||||||
except KeyError:
|
except KeyError:
|
||||||
setattr(self, key, qta.icon(icon))
|
if is_dark:
|
||||||
|
setattr(self, key, qta.icon(icon, color='white'))
|
||||||
|
else:
|
||||||
|
setattr(self, key, qta.icon(icon))
|
||||||
except Exception:
|
except Exception:
|
||||||
import sys
|
import sys
|
||||||
log.error('Unexpected error: %s' % sys.exc_info())
|
log.error('Unexpected error: %s' % sys.exc_info())
|
||||||
|
@ -169,11 +169,16 @@ class SlideController(QtWidgets.QWidget, LogMixin, RegistryProperties):
|
|||||||
return
|
return
|
||||||
if self.displays:
|
if self.displays:
|
||||||
# Delete any existing displays
|
# Delete any existing displays
|
||||||
del self.displays[:]
|
for display in self.displays:
|
||||||
|
display.deregister_display()
|
||||||
|
display.setParent(None)
|
||||||
|
del display
|
||||||
|
self.displays = []
|
||||||
for screen in self.screens:
|
for screen in self.screens:
|
||||||
if screen.is_display:
|
if screen.is_display:
|
||||||
display = DisplayWindow(self, screen)
|
display = DisplayWindow(self, screen)
|
||||||
self.displays.append(display)
|
self.displays.append(display)
|
||||||
|
self._reset_blank(False)
|
||||||
if self.display:
|
if self.display:
|
||||||
self.__add_actions_to_widget(self.display)
|
self.__add_actions_to_widget(self.display)
|
||||||
|
|
||||||
|
@ -126,7 +126,7 @@
|
|||||||
<item>
|
<item>
|
||||||
<widget class="QLabel" name="messageLabel">
|
<widget class="QLabel" name="messageLabel">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>Oops! OpenLP hit a problem, and couldn't recover. The text in the box below contains information that might be helpful to the OpenLP developers, so please e-mail it to bugs@openlp.org, along with a detailed description of what you were doing when the problem occurred.</string>
|
<string>Oops! OpenLP hit a problem, and couldn't recover. The text in the box below contains information that might be helpful to the OpenLP developers, so please e-mail it to bugs3@openlp.org, along with a detailed description of what you were doing when the problem occurred.</string>
|
||||||
</property>
|
</property>
|
||||||
<property name="wordWrap">
|
<property name="wordWrap">
|
||||||
<bool>true</bool>
|
<bool>true</bool>
|
||||||
|
@ -220,16 +220,16 @@ def test_set_normal_cursor(mocked_restoreOverrideCursor, mocked_processEvents, q
|
|||||||
|
|
||||||
@patch('openlp.core.app.get_version')
|
@patch('openlp.core.app.get_version')
|
||||||
@patch('openlp.core.app.QtWidgets.QMessageBox.question')
|
@patch('openlp.core.app.QtWidgets.QMessageBox.question')
|
||||||
def test_backup_on_upgrade_first_install(mocked_question, mocked_get_version, qapp):
|
def test_backup_on_upgrade_first_install(mocked_question, mocked_get_version, qapp, settings):
|
||||||
"""
|
"""
|
||||||
Test that we don't try to backup on a new install
|
Test that we don't try to backup on a new install
|
||||||
"""
|
"""
|
||||||
# GIVEN: Mocked data version and OpenLP version which are the same
|
# GIVEN: Mocked data version and OpenLP version which are the same
|
||||||
old_install = False
|
old_install = False
|
||||||
MOCKED_VERSION = {
|
MOCKED_VERSION = {
|
||||||
'full': '2.4.0-bzr000',
|
'full': '2.4.0',
|
||||||
'version': '2.4.0',
|
'version': '2.4.0',
|
||||||
'build': 'bzr000'
|
'build': None
|
||||||
}
|
}
|
||||||
Settings().setValue('core/application version', '2.4.0')
|
Settings().setValue('core/application version', '2.4.0')
|
||||||
mocked_get_version.return_value = MOCKED_VERSION
|
mocked_get_version.return_value = MOCKED_VERSION
|
||||||
@ -245,18 +245,18 @@ def test_backup_on_upgrade_first_install(mocked_question, mocked_get_version, qa
|
|||||||
|
|
||||||
@patch('openlp.core.app.get_version')
|
@patch('openlp.core.app.get_version')
|
||||||
@patch('openlp.core.app.QtWidgets.QMessageBox.question')
|
@patch('openlp.core.app.QtWidgets.QMessageBox.question')
|
||||||
def test_backup_on_upgrade(mocked_question, mocked_get_version, qapp):
|
def test_backup_on_upgrade(mocked_question, mocked_get_version, qapp, settings):
|
||||||
"""
|
"""
|
||||||
Test that we try to backup on a new install
|
Test that we try to backup on a new install
|
||||||
"""
|
"""
|
||||||
# GIVEN: Mocked data version and OpenLP version which are different
|
# GIVEN: Mocked data version and OpenLP version which are different
|
||||||
old_install = True
|
old_install = True
|
||||||
MOCKED_VERSION = {
|
MOCKED_VERSION = {
|
||||||
'full': '2.4.0-bzr000',
|
'full': '2.9.0.dev2963+97ba02d1f',
|
||||||
'version': '2.4.0',
|
'version': '2.9.0',
|
||||||
'build': 'bzr000'
|
'build': '97ba02d1f'
|
||||||
}
|
}
|
||||||
Settings().setValue('core/application version', '2.0.5')
|
Settings().setValue('core/application version', '2.4.6')
|
||||||
qapp.splash = MagicMock()
|
qapp.splash = MagicMock()
|
||||||
qapp.splash.isVisible.return_value = True
|
qapp.splash.isVisible.return_value = True
|
||||||
mocked_get_version.return_value = MOCKED_VERSION
|
mocked_get_version.return_value = MOCKED_VERSION
|
||||||
@ -266,7 +266,7 @@ def test_backup_on_upgrade(mocked_question, mocked_get_version, qapp):
|
|||||||
qapp.backup_on_upgrade(old_install, True)
|
qapp.backup_on_upgrade(old_install, True)
|
||||||
|
|
||||||
# THEN: It should ask if we want to create a backup
|
# THEN: It should ask if we want to create a backup
|
||||||
assert Settings().value('core/application version') == '2.4.0', 'Version should be upgraded!'
|
assert Settings().value('core/application version') == '2.9.0', 'Version should be upgraded!'
|
||||||
assert mocked_question.call_count == 1, 'A question should have been asked!'
|
assert mocked_question.call_count == 1, 'A question should have been asked!'
|
||||||
qapp.splash.hide.assert_called_once_with()
|
qapp.splash.hide.assert_called_once_with()
|
||||||
qapp.splash.show.assert_called_once_with()
|
qapp.splash.show.assert_called_once_with()
|
||||||
|
@ -121,7 +121,7 @@ class TestFirstTimeForm(TestCase, TestMixin):
|
|||||||
|
|
||||||
# THEN: The screens should be set up, and the default values initialised
|
# THEN: The screens should be set up, and the default values initialised
|
||||||
assert expected_screens == frw.screens, 'The screens should be correct'
|
assert expected_screens == frw.screens, 'The screens should be correct'
|
||||||
assert frw.web_access is True, 'The default value of self.web_access should be True'
|
assert frw.has_web_access is True, 'The default value of self.web_access should be True'
|
||||||
assert [] == frw.thumbnail_download_threads, 'The list of threads should be empty'
|
assert [] == frw.thumbnail_download_threads, 'The list of threads should be empty'
|
||||||
assert frw.has_run_wizard is False, 'has_run_wizard should be False'
|
assert frw.has_run_wizard is False, 'has_run_wizard should be False'
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user