From 6a67a772407cebbb958efe83dc0341998d1e53dd Mon Sep 17 00:00:00 2001 From: Raoul Snyman Date: Fri, 31 Oct 2014 21:47:36 +0200 Subject: [PATCH 1/5] Fix bug #1387309: Filter out ampersands and angle brackets --- openlp/core/common/__init__.py | 7 +++++ openlp/core/ui/firsttimewizard.py | 6 ++-- openlp/core/ui/projector/__init__.py | 31 +++++++++++++++++++ .../openlp_core_common/test_common.py | 16 +++++++++- 4 files changed, 56 insertions(+), 4 deletions(-) create mode 100644 openlp/core/ui/projector/__init__.py diff --git a/openlp/core/common/__init__.py b/openlp/core/common/__init__.py index 833aa5d10..8929a54de 100644 --- a/openlp/core/common/__init__.py +++ b/openlp/core/common/__init__.py @@ -232,6 +232,13 @@ def qmd5_hash(salt, data): log.debug('qmd5_hash() returning "%s"' % hash_value) return decode(hash_value.data(), 'ascii') +def clean_button_text(button_text): + """ + Clean the & and other characters out of button text + + :param button_text: The text to clean + """ + return button_text.replace('&', '').replace('< ', '').replace(' >', '') from .openlpmixin import OpenLPMixin from .registry import Registry diff --git a/openlp/core/ui/firsttimewizard.py b/openlp/core/ui/firsttimewizard.py index a3c8dd7b2..4e83a3e74 100644 --- a/openlp/core/ui/firsttimewizard.py +++ b/openlp/core/ui/firsttimewizard.py @@ -31,7 +31,7 @@ The UI widgets for the first time wizard. """ from PyQt4 import QtCore, QtGui -from openlp.core.common import translate, is_macosx +from openlp.core.common import translate, is_macosx, clean_button_text from openlp.core.lib import build_icon from openlp.core.lib.ui import add_welcome_page @@ -220,7 +220,7 @@ class UiFirstTimeWizard(object): first_time_wizard.information_label.setText( translate('OpenLP.FirstTimeWizard', 'This wizard will help you to configure OpenLP for initial use. ' 'Click the %s button below to start.') % - first_time_wizard.buttonText(QtGui.QWizard.NextButton)) + clean_button_text(first_time_wizard.buttonText(QtGui.QWizard.NextButton))) self.plugin_page.setTitle(translate('OpenLP.FirstTimeWizard', 'Activate required Plugins')) self.plugin_page.setSubTitle(translate('OpenLP.FirstTimeWizard', 'Select the Plugins you wish to use. ')) self.songs_check_box.setText(translate('OpenLP.FirstTimeWizard', 'Songs')) @@ -245,7 +245,7 @@ class UiFirstTimeWizard(object): self.cancel_wizard_text = translate('OpenLP.FirstTimeWizard', '\n\nTo cancel the First Time Wizard completely (and not start OpenLP), ' 'click the %s button now.') % \ - first_time_wizard.buttonText(QtGui.QWizard.CancelButton) + clean_button_text(first_time_wizard.buttonText(QtGui.QWizard.CancelButton)) self.songs_page.setTitle(translate('OpenLP.FirstTimeWizard', 'Sample Songs')) self.songs_page.setSubTitle(translate('OpenLP.FirstTimeWizard', 'Select and download public domain songs.')) self.bibles_page.setTitle(translate('OpenLP.FirstTimeWizard', 'Sample Bibles')) diff --git a/openlp/core/ui/projector/__init__.py b/openlp/core/ui/projector/__init__.py new file mode 100644 index 000000000..9b51f110b --- /dev/null +++ b/openlp/core/ui/projector/__init__.py @@ -0,0 +1,31 @@ +# -*- coding: utf-8 -*- +# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4 + +############################################################################### +# OpenLP - Open Source Lyrics Projection # +# --------------------------------------------------------------------------- # +# Copyright (c) 2008-2014 Raoul Snyman # +# Portions copyright (c) 2008-2014 Tim Bentley, Gerald Britton, Jonathan # +# Corwin, Samuel Findlay, Michael Gorven, Scott Guerrieri, Matthias Hub, # +# Meinert Jordan, Armin Köhler, Erik Lundin, Edwin Lunando, Brian T. Meyer. # +# Joshua Miller, Stevan Pettit, Andreas Preikschat, Mattias Põldaru, # +# Christian Richter, Philip Ridout, Simon Scudder, Jeffrey Smith, # +# Maikel Stuivenberg, Martin Thompson, Jon Tibble, Dave Warnock, # +# Frode Woldsund, Martin Zibricky, Patrick Zimmermann # +# --------------------------------------------------------------------------- # +# 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 # +############################################################################### +""" +The Projector driver module. +""" \ No newline at end of file diff --git a/tests/functional/openlp_core_common/test_common.py b/tests/functional/openlp_core_common/test_common.py index 0474bd404..7398b885e 100644 --- a/tests/functional/openlp_core_common/test_common.py +++ b/tests/functional/openlp_core_common/test_common.py @@ -33,7 +33,7 @@ Functional tests to test the AppLocation class and related methods. from unittest import TestCase from openlp.core.common import check_directory_exists, de_hump, trace_error_handler, translate, is_win, is_macosx, \ - is_linux + is_linux, clean_button_text from tests.functional import MagicMock, patch @@ -188,3 +188,17 @@ class TestCommonFunctions(TestCase): self.assertTrue(is_linux(), 'is_linux() should return True') self.assertFalse(is_win(), 'is_win() should return False') self.assertFalse(is_macosx(), 'is_macosx() should return False') + + def clean_button_text_test(self): + """ + Test the clean_button_text() function. + """ + # GIVEN: Button text + input_text = '&Next >' + expected_text = 'Next' + + # WHEN: The button caption is sent through the clean_button_text function + actual_text = clean_button_text(input_text) + + # THEN: The text should have been cleaned + self.assertEqual(expected_text, actual_text, 'The text should be clean') From ee7fb49e49ce3d28194a14f5813fbad7b6744b83 Mon Sep 17 00:00:00 2001 From: Raoul Snyman Date: Fri, 31 Oct 2014 22:12:06 +0200 Subject: [PATCH 2/5] Fix some linting issues --- openlp/core/common/__init__.py | 4 +++- tests/functional/openlp_core_common/test_common.py | 5 +++-- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/openlp/core/common/__init__.py b/openlp/core/common/__init__.py index 8929a54de..9f200fea9 100644 --- a/openlp/core/common/__init__.py +++ b/openlp/core/common/__init__.py @@ -232,14 +232,16 @@ def qmd5_hash(salt, data): log.debug('qmd5_hash() returning "%s"' % hash_value) return decode(hash_value.data(), 'ascii') + def clean_button_text(button_text): """ Clean the & and other characters out of button text - + :param button_text: The text to clean """ return button_text.replace('&', '').replace('< ', '').replace(' >', '') + from .openlpmixin import OpenLPMixin from .registry import Registry from .registrymixin import RegistryMixin diff --git a/tests/functional/openlp_core_common/test_common.py b/tests/functional/openlp_core_common/test_common.py index 7398b885e..34231c976 100644 --- a/tests/functional/openlp_core_common/test_common.py +++ b/tests/functional/openlp_core_common/test_common.py @@ -196,9 +196,10 @@ class TestCommonFunctions(TestCase): # GIVEN: Button text input_text = '&Next >' expected_text = 'Next' - + # WHEN: The button caption is sent through the clean_button_text function actual_text = clean_button_text(input_text) - + # THEN: The text should have been cleaned self.assertEqual(expected_text, actual_text, 'The text should be clean') + From 0e46a05cccfc26bc6ac3e49e210f19428a5e8134 Mon Sep 17 00:00:00 2001 From: Raoul Snyman Date: Fri, 31 Oct 2014 22:15:44 +0200 Subject: [PATCH 3/5] Apparently pylint doesnt like blank lines at the end of the file. fussy. Fixes: https://launchpad.net/bugs/1387309 --- tests/functional/openlp_core_common/test_common.py | 1 - 1 file changed, 1 deletion(-) diff --git a/tests/functional/openlp_core_common/test_common.py b/tests/functional/openlp_core_common/test_common.py index 34231c976..bd506cb64 100644 --- a/tests/functional/openlp_core_common/test_common.py +++ b/tests/functional/openlp_core_common/test_common.py @@ -202,4 +202,3 @@ class TestCommonFunctions(TestCase): # THEN: The text should have been cleaned self.assertEqual(expected_text, actual_text, 'The text should be clean') - From 9f1638959e5b8b2d93c6c843550e91ca297be702 Mon Sep 17 00:00:00 2001 From: Raoul Snyman Date: Sat, 1 Nov 2014 12:35:54 +0200 Subject: [PATCH 4/5] Fix some more instances of button text --- openlp/core/ui/firsttimeform.py | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/openlp/core/ui/firsttimeform.py b/openlp/core/ui/firsttimeform.py index 1887eb53a..f5c3f7b2a 100644 --- a/openlp/core/ui/firsttimeform.py +++ b/openlp/core/ui/firsttimeform.py @@ -41,7 +41,8 @@ from configparser import ConfigParser from PyQt4 import QtCore, QtGui -from openlp.core.common import Registry, RegistryProperties, AppLocation, Settings, check_directory_exists, translate +from openlp.core.common import Registry, RegistryProperties, AppLocation, Settings, check_directory_exists, translate, + clean_button_text from openlp.core.lib import PluginStatus, build_icon from openlp.core.utils import get_web_page from .firsttimewizard import UiFirstTimeWizard, FirstTimePage @@ -395,20 +396,20 @@ class FirstTimeForm(QtGui.QWizard, UiFirstTimeWizard, RegistryProperties): if self.has_run_wizard: self.progress_label.setText(translate('OpenLP.FirstTimeWizard', 'Download complete. Click the %s button to return to OpenLP.') % - self.buttonText(QtGui.QWizard.FinishButton)) + clean_button_text(self.buttonText(QtGui.QWizard.FinishButton))) else: self.progress_label.setText(translate('OpenLP.FirstTimeWizard', 'Download complete. Click the %s button to start OpenLP.') % - self.buttonText(QtGui.QWizard.FinishButton)) + clean_button_text(self.buttonText(QtGui.QWizard.FinishButton))) else: if self.has_run_wizard: self.progress_label.setText(translate('OpenLP.FirstTimeWizard', 'Click the %s button to return to OpenLP.') % - self.buttonText(QtGui.QWizard.FinishButton)) + clean_button_text(self.buttonText(QtGui.QWizard.FinishButton))) else: self.progress_label.setText(translate('OpenLP.FirstTimeWizard', 'Click the %s button to start OpenLP.') % - self.buttonText(QtGui.QWizard.FinishButton)) + clean_button_text(self.buttonText(QtGui.QWizard.FinishButton))) self.finish_button.setVisible(True) self.finish_button.setEnabled(True) self.cancel_button.setVisible(False) From 39fa2641af854c5c934d3eb1f4c500f2b059ff84 Mon Sep 17 00:00:00 2001 From: Raoul Snyman Date: Sat, 1 Nov 2014 12:38:33 +0200 Subject: [PATCH 5/5] Fixed up an import statement --- openlp/core/ui/firsttimeform.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/openlp/core/ui/firsttimeform.py b/openlp/core/ui/firsttimeform.py index f5c3f7b2a..02d9e65f7 100644 --- a/openlp/core/ui/firsttimeform.py +++ b/openlp/core/ui/firsttimeform.py @@ -41,8 +41,8 @@ from configparser import ConfigParser from PyQt4 import QtCore, QtGui -from openlp.core.common import Registry, RegistryProperties, AppLocation, Settings, check_directory_exists, translate, - clean_button_text +from openlp.core.common import Registry, RegistryProperties, AppLocation, Settings, check_directory_exists, \ + translate, clean_button_text from openlp.core.lib import PluginStatus, build_icon from openlp.core.utils import get_web_page from .firsttimewizard import UiFirstTimeWizard, FirstTimePage