diff --git a/.bzrignore b/.bzrignore index 01c96078a..9fa1b4bb0 100644 --- a/.bzrignore +++ b/.bzrignore @@ -45,3 +45,4 @@ tags output htmlcov openlp-test-projectordb.sqlite +.cache diff --git a/copyright.txt b/copyright.txt index ea62548f4..711ded4ae 100644 --- a/copyright.txt +++ b/copyright.txt @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp.py b/openlp.py index 9bccc526f..38e270a9d 100755 --- a/openlp.py +++ b/openlp.py @@ -5,7 +5,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -39,7 +39,7 @@ def set_up_fault_handling(): """ # Create the cache directory if it doesn't exist, and enable the fault handler to log to an error log file create_paths(AppLocation.get_directory(AppLocation.CacheDir)) - faulthandler.enable(open(str(AppLocation.get_directory(AppLocation.CacheDir) / 'error.log'), 'wb')) + faulthandler.enable((AppLocation.get_directory(AppLocation.CacheDir) / 'error.log').open('wb')) if __name__ == '__main__': diff --git a/openlp/__init__.py b/openlp/__init__.py index 2074ec39a..acd4725ec 100644 --- a/openlp/__init__.py +++ b/openlp/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/__init__.py b/openlp/core/__init__.py index b3fa9b6a6..a25aadd1c 100644 --- a/openlp/core/__init__.py +++ b/openlp/core/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/api/__init__.py b/openlp/core/api/__init__.py index 015f0cec3..f3081d022 100644 --- a/openlp/core/api/__init__.py +++ b/openlp/core/api/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -20,9 +20,9 @@ # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### -from openlp.core.api.http.endpoint import Endpoint from openlp.core.api.http import register_endpoint, requires_auth -from openlp.core.api.tab import ApiTab +from openlp.core.api.http.endpoint import Endpoint from openlp.core.api.poll import Poller +from openlp.core.api.tab import ApiTab __all__ = ['Endpoint', 'ApiTab', 'register_endpoint', 'requires_auth'] diff --git a/openlp/core/api/deploy.py b/openlp/core/api/deploy.py index 83eef9ea4..61893f768 100644 --- a/openlp/core/api/deploy.py +++ b/openlp/core/api/deploy.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,8 +25,8 @@ Download and "install" the remote web client from zipfile import ZipFile from openlp.core.common.applocation import AppLocation -from openlp.core.common.registry import Registry from openlp.core.common.httputils import download_file, get_web_page, get_url_file_size +from openlp.core.common.registry import Registry def deploy_zipfile(app_root_path, zip_name): diff --git a/openlp/core/api/endpoint/__init__.py b/openlp/core/api/endpoint/__init__.py index fcba538e5..ffc1d8628 100644 --- a/openlp/core/api/endpoint/__init__.py +++ b/openlp/core/api/endpoint/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/api/endpoint/controller.py b/openlp/core/api/endpoint/controller.py index 13e8d1681..4e897f370 100644 --- a/openlp/core/api/endpoint/controller.py +++ b/openlp/core/api/endpoint/controller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -19,14 +19,14 @@ # with this program; if not, write to the Free Software Foundation, Inc., 59 # # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### +import json import logging import os -import urllib.request import urllib.error -import json +import urllib.request -from openlp.core.api.http.endpoint import Endpoint from openlp.core.api.http import requires_auth +from openlp.core.api.http.endpoint import Endpoint from openlp.core.common.applocation import AppLocation from openlp.core.common.path import Path from openlp.core.common.registry import Registry diff --git a/openlp/core/api/endpoint/core.py b/openlp/core/api/endpoint/core.py index 8b9bcc4c0..9ad95f4df 100644 --- a/openlp/core/api/endpoint/core.py +++ b/openlp/core/api/endpoint/core.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,11 +27,10 @@ import os from openlp.core.api.http import requires_auth from openlp.core.api.http.endpoint import Endpoint -from openlp.core.common.registry import Registry from openlp.core.common.i18n import UiStrings, translate +from openlp.core.common.registry import Registry from openlp.core.lib import PluginStatus, StringContent, image_to_byte - template_dir = 'templates' static_dir = 'static' blank_dir = os.path.join(static_dir, 'index') diff --git a/openlp/core/api/endpoint/pluginhelpers.py b/openlp/core/api/endpoint/pluginhelpers.py index b8f606fbc..a74fa524a 100644 --- a/openlp/core/api/endpoint/pluginhelpers.py +++ b/openlp/core/api/endpoint/pluginhelpers.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/api/endpoint/remote.py b/openlp/core/api/endpoint/remote.py index 3a408f74e..0e637339f 100644 --- a/openlp/core/api/endpoint/remote.py +++ b/openlp/core/api/endpoint/remote.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,9 +21,8 @@ ############################################################################### import logging -from openlp.core.api.http.endpoint import Endpoint from openlp.core.api.endpoint.core import TRANSLATED_STRINGS - +from openlp.core.api.http.endpoint import Endpoint log = logging.getLogger(__name__) diff --git a/openlp/core/api/endpoint/service.py b/openlp/core/api/endpoint/service.py index ab9ae6740..b642c3151 100644 --- a/openlp/core/api/endpoint/service.py +++ b/openlp/core/api/endpoint/service.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -19,14 +19,13 @@ # with this program; if not, write to the Free Software Foundation, Inc., 59 # # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### -import logging import json +import logging from openlp.core.api.http import requires_auth from openlp.core.api.http.endpoint import Endpoint from openlp.core.common.registry import Registry - log = logging.getLogger(__name__) service_endpoint = Endpoint('service') diff --git a/openlp/core/api/http/__init__.py b/openlp/core/api/http/__init__.py index 8ff08b1e7..9b8086519 100644 --- a/openlp/core/api/http/__init__.py +++ b/openlp/core/api/http/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,10 +22,11 @@ import base64 from functools import wraps + from webob import Response -from openlp.core.common.settings import Settings from openlp.core.api.http.wsgiapp import WSGIApplication +from openlp.core.common.settings import Settings from .errors import NotFound, ServerError, HttpError application = WSGIApplication('api') diff --git a/openlp/core/api/http/endpoint.py b/openlp/core/api/http/endpoint.py index 011b7e73a..29184f6f8 100644 --- a/openlp/core/api/http/endpoint.py +++ b/openlp/core/api/http/endpoint.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/api/http/errors.py b/openlp/core/api/http/errors.py index acb851aad..4b344ff97 100644 --- a/openlp/core/api/http/errors.py +++ b/openlp/core/api/http/errors.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/api/http/server.py b/openlp/core/api/http/server.py index cb50d5078..6c63e6936 100644 --- a/openlp/core/api/http/server.py +++ b/openlp/core/api/http/server.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -32,10 +32,10 @@ from waitress import serve from openlp.core.api.deploy import download_and_check, download_sha256 from openlp.core.api.endpoint.controller import controller_endpoint, api_controller_endpoint from openlp.core.api.endpoint.core import chords_endpoint, stage_endpoint, blank_endpoint, main_endpoint -from openlp.core.api.endpoint.service import service_endpoint, api_service_endpoint from openlp.core.api.endpoint.remote import remote_endpoint -from openlp.core.api.http import register_endpoint +from openlp.core.api.endpoint.service import service_endpoint, api_service_endpoint from openlp.core.api.http import application +from openlp.core.api.http import register_endpoint from openlp.core.api.poll import Poller from openlp.core.common.applocation import AppLocation from openlp.core.common.i18n import UiStrings diff --git a/openlp/core/api/http/wsgiapp.py b/openlp/core/api/http/wsgiapp.py index 4c863b7cb..3c262e365 100644 --- a/openlp/core/api/http/wsgiapp.py +++ b/openlp/core/api/http/wsgiapp.py @@ -5,7 +5,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -30,9 +30,8 @@ import re from webob import Request, Response from webob.static import DirectoryApp -from openlp.core.common.applocation import AppLocation from openlp.core.api.http.errors import HttpError, NotFound, ServerError - +from openlp.core.common.applocation import AppLocation ARGS_REGEX = re.compile(r'''\{(\w+)(?::([^}]+))?\}''', re.VERBOSE) diff --git a/openlp/core/api/poll.py b/openlp/core/api/poll.py index d2d36f60a..b3149d470 100644 --- a/openlp/core/api/poll.py +++ b/openlp/core/api/poll.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/api/tab.py b/openlp/core/api/tab.py index ddca61176..eaa021800 100644 --- a/openlp/core/api/tab.py +++ b/openlp/core/api/tab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/api/websockets.py b/openlp/core/api/websockets.py index dc7cf8f82..bf303249f 100644 --- a/openlp/core/api/websockets.py +++ b/openlp/core/api/websockets.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -24,11 +24,11 @@ The :mod:`http` module contains the API web server. This is a lightweight web se with OpenLP. It uses JSON to communicate with the remotes. """ import asyncio -import websockets import json import logging import time +import websockets from PyQt5 import QtCore from openlp.core.common.mixins import LogMixin, RegistryProperties diff --git a/openlp/core/app.py b/openlp/core/app.py index 114a62807..94ecdb450 100644 --- a/openlp/core/app.py +++ b/openlp/core/app.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -42,7 +42,6 @@ from openlp.core.common.mixins import LogMixin from openlp.core.common.path import create_paths, copytree from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings -from openlp.core.version import check_for_update, get_version from openlp.core.display.screens import ScreenList from openlp.core.resources import qInitResources from openlp.core.ui import SplashScreen @@ -51,7 +50,7 @@ from openlp.core.ui.firsttimeform import FirstTimeForm from openlp.core.ui.firsttimelanguageform import FirstTimeLanguageForm from openlp.core.ui.mainwindow import MainWindow from openlp.core.ui.style import get_application_stylesheet - +from openlp.core.version import check_for_update, get_version __all__ = ['OpenLP', 'main'] diff --git a/openlp/core/common/__init__.py b/openlp/core/common/__init__.py index b6d759f42..e4c806f22 100644 --- a/openlp/core/common/__init__.py +++ b/openlp/core/common/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -30,13 +30,13 @@ import os import re import sys import traceback -from chardet.universaldetector import UniversalDetector from ipaddress import IPv4Address, IPv6Address, AddressValueError from shutil import which from subprocess import check_output, CalledProcessError, STDOUT from PyQt5 import QtGui from PyQt5.QtCore import QCryptographicHash as QHash +from chardet.universaldetector import UniversalDetector log = logging.getLogger(__name__ + '.__init__') diff --git a/openlp/core/common/actions.py b/openlp/core/common/actions.py index a5b417017..f4fbdd9db 100644 --- a/openlp/core/common/actions.py +++ b/openlp/core/common/actions.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,7 +29,6 @@ from PyQt5 import QtCore, QtGui, QtWidgets from openlp.core.common.settings import Settings - log = logging.getLogger(__name__) diff --git a/openlp/core/common/applocation.py b/openlp/core/common/applocation.py index 279c49002..a219e2906 100644 --- a/openlp/core/common/applocation.py +++ b/openlp/core/common/applocation.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/common/db.py b/openlp/core/common/db.py index a88577932..ef5b7b2b7 100644 --- a/openlp/core/common/db.py +++ b/openlp/core/common/db.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,7 +27,6 @@ from copy import deepcopy import sqlalchemy - log = logging.getLogger(__name__) diff --git a/openlp/core/common/httputils.py b/openlp/core/common/httputils.py index d07185638..e7d11fad5 100644 --- a/openlp/core/common/httputils.py +++ b/openlp/core/common/httputils.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/common/i18n.py b/openlp/core/common/i18n.py index 9149f3fe6..cb0c2904c 100644 --- a/openlp/core/common/i18n.py +++ b/openlp/core/common/i18n.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/common/json.py b/openlp/core/common/json.py index f0e45ee2a..ed785ee72 100644 --- a/openlp/core/common/json.py +++ b/openlp/core/common/json.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/common/mixins.py b/openlp/core/common/mixins.py index a07940e10..28c478b93 100644 --- a/openlp/core/common/mixins.py +++ b/openlp/core/common/mixins.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,8 +22,8 @@ """ Provide Error Handling and login Services """ -import logging import inspect +import logging from openlp.core.common import is_win, trace_error_handler from openlp.core.common.registry import Registry diff --git a/openlp/core/common/path.py b/openlp/core/common/path.py index 0e4b45c2a..7d0c386db 100644 --- a/openlp/core/common/path.py +++ b/openlp/core/common/path.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/common/registry.py b/openlp/core/common/registry.py index 4c9e92108..969518297 100644 --- a/openlp/core/common/registry.py +++ b/openlp/core/common/registry.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/common/settings.py b/openlp/core/common/settings.py index 54f1d9b2a..1c1186feb 100644 --- a/openlp/core/common/settings.py +++ b/openlp/core/common/settings.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,8 +23,8 @@ This class contains the core default settings. """ import datetime -import logging import json +import logging import os from tempfile import gettempdir diff --git a/openlp/core/display/__init__.py b/openlp/core/display/__init__.py index dea4ef4db..a35bd3243 100644 --- a/openlp/core/display/__init__.py +++ b/openlp/core/display/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/display/renderer.py b/openlp/core/display/renderer.py index 836e5edea..54d0aaf10 100644 --- a/openlp/core/display/renderer.py +++ b/openlp/core/display/renderer.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,10 +21,11 @@ ############################################################################### import re - from string import Template + from PyQt5 import QtGui, QtCore, QtWebKitWidgets +from openlp.core.common import ThemeLevel from openlp.core.common.mixins import LogMixin, RegistryProperties from openlp.core.common.path import path_to_str from openlp.core.common.registry import Registry, RegistryBase @@ -32,7 +33,6 @@ from openlp.core.common.settings import Settings from openlp.core.display.screens import ScreenList from openlp.core.lib import FormattingTags, ImageSource, ItemCapabilities, ServiceItem, expand_tags, build_chords_css, \ build_lyrics_format_css, build_lyrics_outline_css -from openlp.core.common import ThemeLevel from openlp.core.ui.maindisplay import MainDisplay VERSE = 'The Lord said to {r}Noah{/r}: \n' \ diff --git a/openlp/core/display/screens.py b/openlp/core/display/screens.py index 0a1a4cd28..f0a05f31b 100644 --- a/openlp/core/display/screens.py +++ b/openlp/core/display/screens.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,14 +23,14 @@ The :mod:`screen` module provides management functionality for a machines' displays. """ -import logging import copy +import logging from PyQt5 import QtCore +from openlp.core.common.i18n import translate from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings -from openlp.core.common.i18n import translate log = logging.getLogger(__name__) diff --git a/openlp/core/lib/__init__.py b/openlp/core/lib/__init__.py index b2e1efd32..bcc87c19e 100644 --- a/openlp/core/lib/__init__.py +++ b/openlp/core/lib/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,8 +25,8 @@ OpenLP work. """ import html import logging -import re import math +import re from PyQt5 import QtCore, QtGui, QtWidgets diff --git a/openlp/core/lib/db.py b/openlp/core/lib/db.py index 9e3c5aff9..6898e0469 100644 --- a/openlp/core/lib/db.py +++ b/openlp/core/lib/db.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/lib/exceptions.py b/openlp/core/lib/exceptions.py index 26ff56a79..63cebfa8c 100644 --- a/openlp/core/lib/exceptions.py +++ b/openlp/core/lib/exceptions.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/lib/formattingtags.py b/openlp/core/lib/formattingtags.py index c364d388e..33fd28a5a 100644 --- a/openlp/core/lib/formattingtags.py +++ b/openlp/core/lib/formattingtags.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -24,8 +24,8 @@ Provide HTML Tag management and Formatting Tag access class """ import json -from openlp.core.common.settings import Settings from openlp.core.common.i18n import translate +from openlp.core.common.settings import Settings class FormattingTags(object): diff --git a/openlp/core/lib/htmlbuilder.py b/openlp/core/lib/htmlbuilder.py index 0330f10c8..f6a0c6e61 100644 --- a/openlp/core/lib/htmlbuilder.py +++ b/openlp/core/lib/htmlbuilder.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -407,8 +407,8 @@ is the function which has to be called from outside. The generated and returned """ import logging - from string import Template + from PyQt5 import QtWebKit from openlp.core.common.settings import Settings diff --git a/openlp/core/lib/imagemanager.py b/openlp/core/lib/imagemanager.py index 96b315717..f452278c1 100644 --- a/openlp/core/lib/imagemanager.py +++ b/openlp/core/lib/imagemanager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -26,8 +26,8 @@ wait for the conversion to happen. """ import logging import os -import time import queue +import time from PyQt5 import QtCore diff --git a/openlp/core/lib/json/__init__.py b/openlp/core/lib/json/__init__.py index ea62548f4..711ded4ae 100644 --- a/openlp/core/lib/json/__init__.py +++ b/openlp/core/lib/json/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/lib/mediamanageritem.py b/openlp/core/lib/mediamanageritem.py index 85aa406b1..f5fc6d445 100644 --- a/openlp/core/lib/mediamanageritem.py +++ b/openlp/core/lib/mediamanageritem.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -28,8 +28,8 @@ import re from PyQt5 import QtCore, QtWidgets from openlp.core.common.i18n import UiStrings, translate -from openlp.core.common.path import path_to_str, str_to_path from openlp.core.common.mixins import RegistryProperties +from openlp.core.common.path import path_to_str, str_to_path from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings from openlp.core.lib import ServiceItem, StringContent, ServiceItemContext @@ -331,8 +331,7 @@ class MediaManagerItem(QtWidgets.QWidget, RegistryProperties): """ new_file_paths = [] error_shown = False - for file_name in data['files']: - file_path = str_to_path(file_name) + for file_path in data['file_paths']: if file_path.suffix[1:].lower() not in self.on_new_file_masks: if not error_shown: critical_error_message_box( diff --git a/openlp/core/lib/plugin.py b/openlp/core/lib/plugin.py index 7e3b2e416..acb874119 100644 --- a/openlp/core/lib/plugin.py +++ b/openlp/core/lib/plugin.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/lib/pluginmanager.py b/openlp/core/lib/pluginmanager.py index c82e26eec..00f2dd6d1 100644 --- a/openlp/core/lib/pluginmanager.py +++ b/openlp/core/lib/pluginmanager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/lib/serviceitem.py b/openlp/core/lib/serviceitem.py index 3a824d424..5d11f0c1f 100644 --- a/openlp/core/lib/serviceitem.py +++ b/openlp/core/lib/serviceitem.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -26,9 +26,9 @@ type and capability of an item. import datetime import html import logging +import ntpath import os import uuid -import ntpath from PyQt5 import QtGui diff --git a/openlp/core/lib/settingstab.py b/openlp/core/lib/settingstab.py index 06009ee3d..324628cd9 100644 --- a/openlp/core/lib/settingstab.py +++ b/openlp/core/lib/settingstab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/lib/theme.py b/openlp/core/lib/theme.py index 92d12ebfd..b8baa97a5 100644 --- a/openlp/core/lib/theme.py +++ b/openlp/core/lib/theme.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/lib/ui.py b/openlp/core/lib/ui.py index 0d5b3c0bd..ac8441cf3 100644 --- a/openlp/core/lib/ui.py +++ b/openlp/core/lib/ui.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -32,7 +32,6 @@ from openlp.core.common.i18n import UiStrings, translate from openlp.core.common.registry import Registry from openlp.core.lib import build_icon - log = logging.getLogger(__name__) diff --git a/openlp/core/projectors/__init__.py b/openlp/core/projectors/__init__.py index 66cfd6080..bde2301fe 100644 --- a/openlp/core/projectors/__init__.py +++ b/openlp/core/projectors/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/projectors/constants.py b/openlp/core/projectors/constants.py index a9410d109..cabef8169 100644 --- a/openlp/core/projectors/constants.py +++ b/openlp/core/projectors/constants.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -32,9 +32,128 @@ log.debug('projector_constants loaded') # Set common constants. CR = chr(0x0D) # \r LF = chr(0x0A) # \n -PJLINK_PORT = 4352 -TIMEOUT = 30.0 +PJLINK_CLASS = '1' # Default to class 1 until we query the projector PJLINK_MAX_PACKET = 136 +PJLINK_PREFIX = '%' +PJLINK_PORT = 4352 +PJLINK_SUFFIX = CR +PJLINK_TIMEOUT = 30.0 + +# Error and status codes +S_OK = E_OK = 0 # E_OK included since I sometimes forget + +# Error codes. Start at 200 so we don't duplicate system error codes. +E_GENERAL = 200 # Unknown error +E_NOT_CONNECTED = 201 +E_UNDEFINED = 202 # PJLink ERR1 +E_PARAMETER = 203 # PJLink ERR2 +E_UNAVAILABLE = 204 # PJLink ERR3 +E_PROJECTOR = 205 # PJLink ERR4 +E_AUTHENTICATION = 206 # PJLink ERRA +E_NO_AUTHENTICATION = 207 # PJLink authentication mismatch between projector and program +E_PREFIX = 208 # PJLink invalid prefix for packet +E_CLASS = 209 # PJLink class version mismatch +E_INVALID_DATA = 210 +E_WARN = 211 +E_ERROR = 212 +E_FAN = 213 +E_LAMP = 214 +E_TEMP = 215 +E_COVER = 216 +E_FILTER = 217 +E_UNKNOWN = 218 + +# Remap Qt socket error codes to local error codes +E_CONNECTION_REFUSED = 230 +E_REMOTE_HOST_CLOSED_CONNECTION = 231 +E_HOST_NOT_FOUND = 232 +E_SOCKET_ACCESS = 233 +E_SOCKET_RESOURCE = 234 +E_SOCKET_TIMEOUT = 235 +E_DATAGRAM_TOO_LARGE = 236 +E_NETWORK = 237 +E_ADDRESS_IN_USE = 238 +E_SOCKET_ADDRESS_NOT_AVAILABLE = 239 +E_UNSUPPORTED_SOCKET_OPERATION = 240 +E_PROXY_AUTHENTICATION_REQUIRED = 241 +E_SLS_HANDSHAKE_FAILED = 242 +E_UNFINISHED_SOCKET_OPERATION = 243 +E_PROXY_CONNECTION_REFUSED = 244 +E_PROXY_CONNECTION_CLOSED = 245 +E_PROXY_CONNECTION_TIMEOUT = 246 +E_PROXY_NOT_FOUND = 247 +E_PROXY_PROTOCOL = 248 +E_UNKNOWN_SOCKET_ERROR = 249 + +# Status codes start at 300 + +# Remap Qt socket states to local status codes +S_NOT_CONNECTED = 300 +S_HOST_LOOKUP = 301 +S_CONNECTING = 302 +S_CONNECTED = 303 +S_BOUND = 304 +S_LISTENING = 305 # Listed as internal use only in QAbstractSocket +S_CLOSING = 306 + +# Projector states +S_INITIALIZE = 310 +S_STATUS = 311 +S_OFF = 312 +S_STANDBY = 313 +S_WARMUP = 314 +S_ON = 315 +S_COOLDOWN = 316 +S_INFO = 317 + +# Information that does not affect status +S_NETWORK_IDLE = 400 +S_NETWORK_SENDING = 401 +S_NETWORK_RECEIVING = 402 + +# Map PJlink errors to local status +PJLINK_ERRORS = { + 'ERRA': E_AUTHENTICATION, # Authentication error + 'ERR1': E_UNDEFINED, # Undefined command error + 'ERR2': E_PARAMETER, # Invalid parameter error + 'ERR3': E_UNAVAILABLE, # Projector busy + 'ERR4': E_PROJECTOR, # Projector or display failure + E_AUTHENTICATION: 'ERRA', + E_UNDEFINED: 'ERR1', + E_PARAMETER: 'ERR2', + E_UNAVAILABLE: 'ERR3', + E_PROJECTOR: 'ERR4' +} + +# Map QAbstractSocketState enums to local status +QSOCKET_STATE = { + 0: S_NOT_CONNECTED, # 'UnconnectedState', + 1: S_HOST_LOOKUP, # 'HostLookupState', + 2: S_CONNECTING, # 'ConnectingState', + 3: S_CONNECTED, # 'ConnectedState', + 4: S_BOUND, # 'BoundState', + 5: S_LISTENING, # 'ListeningState' - Noted as "Internal Use Only" on Qt website + 6: S_CLOSING, # 'ClosingState', + S_NOT_CONNECTED: 0, + S_HOST_LOOKUP: 1, + S_CONNECTING: 2, + S_CONNECTED: 3, + S_BOUND: 4, + S_LISTENING: 5, + S_CLOSING: 6 +} + +PROJECTOR_STATE = [ + S_INITIALIZE, + S_STATUS, + S_OFF, + S_STANDBY, + S_WARMUP, + S_ON, + S_COOLDOWN, + S_INFO +] + # NOTE: Changed format to account for some commands are both class 1 and 2 PJLINK_VALID_CMD = { 'ACKN': {'version': ['2', ], @@ -144,227 +263,140 @@ PJLINK_VALID_CMD = { } } -# QAbstractSocketState enums converted to string -S_QSOCKET_STATE = { - 0: 'QSocketState - UnconnectedState', - 1: 'QSocketState - HostLookupState', - 2: 'QSocketState - ConnectingState', - 3: 'QSocketState - ConnectedState', - 4: 'QSocketState - BoundState', - 5: 'QSocketState - ListeningState (internal use only)', - 6: 'QSocketState - ClosingState', - 'UnconnectedState': 0, - 'HostLookupState': 1, - 'ConnectingState': 2, - 'ConnectedState': 3, - 'BoundState': 4, - 'ListeningState': 5, - 'ClosingState': 6 -} +CONNECTION_ERRORS = [ + E_ADDRESS_IN_USE, + E_CONNECTION_REFUSED, + E_DATAGRAM_TOO_LARGE, + E_HOST_NOT_FOUND, + E_NETWORK, + E_NOT_CONNECTED, + E_PROXY_AUTHENTICATION_REQUIRED, + E_PROXY_CONNECTION_CLOSED, + E_PROXY_CONNECTION_REFUSED, + E_PROXY_CONNECTION_TIMEOUT, + E_PROXY_NOT_FOUND, + E_PROXY_PROTOCOL, + E_REMOTE_HOST_CLOSED_CONNECTION, + E_SLS_HANDSHAKE_FAILED, + E_SOCKET_ACCESS, + E_SOCKET_ADDRESS_NOT_AVAILABLE, + E_SOCKET_RESOURCE, + E_SOCKET_TIMEOUT, + E_UNFINISHED_SOCKET_OPERATION, + E_UNKNOWN_SOCKET_ERROR, + E_UNSUPPORTED_SOCKET_OPERATION +] -# Error and status codes -S_OK = E_OK = 0 # E_OK included since I sometimes forget -# Error codes. Start at 200 so we don't duplicate system error codes. -E_GENERAL = 200 # Unknown error -E_NOT_CONNECTED = 201 -E_FAN = 202 -E_LAMP = 203 -E_TEMP = 204 -E_COVER = 205 -E_FILTER = 206 -E_NO_AUTHENTICATION = 207 # PIN set and no authentication set on projector -E_UNDEFINED = 208 # ERR1 -E_PARAMETER = 209 # ERR2 -E_UNAVAILABLE = 210 # ERR3 -E_PROJECTOR = 211 # ERR4 -E_INVALID_DATA = 212 -E_WARN = 213 -E_ERROR = 214 -E_AUTHENTICATION = 215 # ERRA -E_CLASS = 216 -E_PREFIX = 217 +PROJECTOR_ERRORS = [ + E_AUTHENTICATION, + E_CLASS, + E_INVALID_DATA, + E_NO_AUTHENTICATION, + E_PARAMETER, + E_PREFIX, + E_PROJECTOR, + E_UNAVAILABLE, + E_UNDEFINED, + E_UNKNOWN +] -# Remap Qt socket error codes to projector error codes -E_CONNECTION_REFUSED = 230 -E_REMOTE_HOST_CLOSED_CONNECTION = 231 -E_HOST_NOT_FOUND = 232 -E_SOCKET_ACCESS = 233 -E_SOCKET_RESOURCE = 234 -E_SOCKET_TIMEOUT = 235 -E_DATAGRAM_TOO_LARGE = 236 -E_NETWORK = 237 -E_ADDRESS_IN_USE = 238 -E_SOCKET_ADDRESS_NOT_AVAILABLE = 239 -E_UNSUPPORTED_SOCKET_OPERATION = 240 -E_PROXY_AUTHENTICATION_REQUIRED = 241 -E_SLS_HANDSHAKE_FAILED = 242 -E_UNFINISHED_SOCKET_OPERATION = 243 -E_PROXY_CONNECTION_REFUSED = 244 -E_PROXY_CONNECTION_CLOSED = 245 -E_PROXY_CONNECTION_TIMEOUT = 246 -E_PROXY_NOT_FOUND = 247 -E_PROXY_PROTOCOL = 248 -E_UNKNOWN_SOCKET_ERROR = -1 - -# Status codes start at 300 -S_NOT_CONNECTED = 300 -S_CONNECTING = 301 -S_CONNECTED = 302 -S_INITIALIZE = 303 -S_STATUS = 304 -S_OFF = 305 -S_STANDBY = 306 -S_WARMUP = 307 -S_ON = 308 -S_COOLDOWN = 309 -S_INFO = 310 - -# Information that does not affect status -S_NETWORK_SENDING = 400 -S_NETWORK_RECEIVED = 401 - -CONNECTION_ERRORS = { - E_NOT_CONNECTED, E_NO_AUTHENTICATION, E_AUTHENTICATION, E_CLASS, - E_PREFIX, E_CONNECTION_REFUSED, E_REMOTE_HOST_CLOSED_CONNECTION, - E_HOST_NOT_FOUND, E_SOCKET_ACCESS, E_SOCKET_RESOURCE, E_SOCKET_TIMEOUT, - E_DATAGRAM_TOO_LARGE, E_NETWORK, E_ADDRESS_IN_USE, E_SOCKET_ADDRESS_NOT_AVAILABLE, - E_UNSUPPORTED_SOCKET_OPERATION, E_PROXY_AUTHENTICATION_REQUIRED, - E_SLS_HANDSHAKE_FAILED, E_UNFINISHED_SOCKET_OPERATION, E_PROXY_CONNECTION_REFUSED, - E_PROXY_CONNECTION_CLOSED, E_PROXY_CONNECTION_TIMEOUT, E_PROXY_NOT_FOUND, - E_PROXY_PROTOCOL, E_UNKNOWN_SOCKET_ERROR -} - -PJLINK_ERRORS = { - 'ERRA': E_AUTHENTICATION, # Authentication error - 'ERR1': E_UNDEFINED, # Undefined command error - 'ERR2': E_PARAMETER, # Invalid parameter error - 'ERR3': E_UNAVAILABLE, # Projector busy - 'ERR4': E_PROJECTOR, # Projector or display failure - E_AUTHENTICATION: 'ERRA', - E_UNDEFINED: 'ERR1', - E_PARAMETER: 'ERR2', - E_UNAVAILABLE: 'ERR3', - E_PROJECTOR: 'ERR4' -} - -# Map error/status codes to string -ERROR_STRING = { - 0: 'S_OK', - E_GENERAL: 'E_GENERAL', - E_NOT_CONNECTED: 'E_NOT_CONNECTED', - E_FAN: 'E_FAN', - E_LAMP: 'E_LAMP', - E_TEMP: 'E_TEMP', - E_COVER: 'E_COVER', - E_FILTER: 'E_FILTER', - E_AUTHENTICATION: 'E_AUTHENTICATION', - E_NO_AUTHENTICATION: 'E_NO_AUTHENTICATION', - E_UNDEFINED: 'E_UNDEFINED', - E_PARAMETER: 'E_PARAMETER', - E_UNAVAILABLE: 'E_UNAVAILABLE', - E_PROJECTOR: 'E_PROJECTOR', - E_INVALID_DATA: 'E_INVALID_DATA', - E_WARN: 'E_WARN', - E_ERROR: 'E_ERROR', - E_CLASS: 'E_CLASS', - E_PREFIX: 'E_PREFIX', # Last projector error - E_CONNECTION_REFUSED: 'E_CONNECTION_REFUSED', # First QtSocket error - E_REMOTE_HOST_CLOSED_CONNECTION: 'E_REMOTE_HOST_CLOSED_CONNECTION', - E_HOST_NOT_FOUND: 'E_HOST_NOT_FOUND', - E_SOCKET_ACCESS: 'E_SOCKET_ACCESS', - E_SOCKET_RESOURCE: 'E_SOCKET_RESOURCE', - E_SOCKET_TIMEOUT: 'E_SOCKET_TIMEOUT', - E_DATAGRAM_TOO_LARGE: 'E_DATAGRAM_TOO_LARGE', - E_NETWORK: 'E_NETWORK', +# Show status code as string +STATUS_CODE = { E_ADDRESS_IN_USE: 'E_ADDRESS_IN_USE', - E_SOCKET_ADDRESS_NOT_AVAILABLE: 'E_SOCKET_ADDRESS_NOT_AVAILABLE', - E_UNSUPPORTED_SOCKET_OPERATION: 'E_UNSUPPORTED_SOCKET_OPERATION', + E_AUTHENTICATION: 'E_AUTHENTICATION', + E_CLASS: 'E_CLASS', + E_CONNECTION_REFUSED: 'E_CONNECTION_REFUSED', + E_COVER: 'E_COVER', + E_DATAGRAM_TOO_LARGE: 'E_DATAGRAM_TOO_LARGE', + E_ERROR: 'E_ERROR', + E_FAN: 'E_FAN', + E_FILTER: 'E_FILTER', + E_GENERAL: 'E_GENERAL', + E_HOST_NOT_FOUND: 'E_HOST_NOT_FOUND', + E_INVALID_DATA: 'E_INVALID_DATA', + E_LAMP: 'E_LAMP', + E_NETWORK: 'E_NETWORK', + E_NO_AUTHENTICATION: 'E_NO_AUTHENTICATION', + E_NOT_CONNECTED: 'E_NOT_CONNECTED', + E_PARAMETER: 'E_PARAMETER', + E_PREFIX: 'E_PREFIX', + E_PROJECTOR: 'E_PROJECTOR', E_PROXY_AUTHENTICATION_REQUIRED: 'E_PROXY_AUTHENTICATION_REQUIRED', - E_SLS_HANDSHAKE_FAILED: 'E_SLS_HANDSHAKE_FAILED', - E_UNFINISHED_SOCKET_OPERATION: 'E_UNFINISHED_SOCKET_OPERATION', - E_PROXY_CONNECTION_REFUSED: 'E_PROXY_CONNECTION_REFUSED', E_PROXY_CONNECTION_CLOSED: 'E_PROXY_CONNECTION_CLOSED', + E_PROXY_CONNECTION_REFUSED: 'E_PROXY_CONNECTION_REFUSED', E_PROXY_CONNECTION_TIMEOUT: 'E_PROXY_CONNECTION_TIMEOUT', E_PROXY_NOT_FOUND: 'E_PROXY_NOT_FOUND', E_PROXY_PROTOCOL: 'E_PROXY_PROTOCOL', - E_UNKNOWN_SOCKET_ERROR: 'E_UNKNOWN_SOCKET_ERROR' -} - -STATUS_STRING = { - S_NOT_CONNECTED: 'S_NOT_CONNECTED', - S_CONNECTING: 'S_CONNECTING', - S_CONNECTED: 'S_CONNECTED', - S_STATUS: 'S_STATUS', - S_OFF: 'S_OFF', - S_INITIALIZE: 'S_INITIALIZE', - S_STANDBY: 'S_STANDBY', - S_WARMUP: 'S_WARMUP', - S_ON: 'S_ON', + E_REMOTE_HOST_CLOSED_CONNECTION: 'E_REMOTE_HOST_CLOSED_CONNECTION', + E_SLS_HANDSHAKE_FAILED: 'E_SLS_HANDSHAKE_FAILED', + E_SOCKET_ACCESS: 'E_SOCKET_ACCESS', + E_SOCKET_ADDRESS_NOT_AVAILABLE: 'E_SOCKET_ADDRESS_NOT_AVAILABLE', + E_SOCKET_RESOURCE: 'E_SOCKET_RESOURCE', + E_SOCKET_TIMEOUT: 'E_SOCKET_TIMEOUT', + E_TEMP: 'E_TEMP', + E_UNAVAILABLE: 'E_UNAVAILABLE', + E_UNDEFINED: 'E_UNDEFINED', + E_UNFINISHED_SOCKET_OPERATION: 'E_UNFINISHED_SOCKET_OPERATION', + E_UNKNOWN: 'E_UNKNOWN', + E_UNKNOWN_SOCKET_ERROR: 'E_UNKNOWN_SOCKET_ERROR', + E_UNSUPPORTED_SOCKET_OPERATION: 'E_UNSUPPORTED_SOCKET_OPERATION', + E_WARN: 'E_WARN', + S_BOUND: 'S_BOUND', S_COOLDOWN: 'S_COOLDOWN', + S_CLOSING: 'S_CLOSING', + S_CONNECTED: 'S_CONNECTED', + S_CONNECTING: 'S_CONNECTING', + S_HOST_LOOKUP: 'S_HOST_LOOKUP', S_INFO: 'S_INFO', + S_INITIALIZE: 'S_INITIALIZE', + S_LISTENING: 'S_LISTENING', + S_NETWORK_RECEIVING: 'S_NETWORK_RECEIVING', S_NETWORK_SENDING: 'S_NETWORK_SENDING', - S_NETWORK_RECEIVED: 'S_NETWORK_RECEIVED' + S_NETWORK_IDLE: 'S_NETWORK_IDLE', + S_NOT_CONNECTED: 'S_NOT_CONNECTED', + S_OFF: 'S_OFF', + S_OK: 'S_OK', # S_OK or E_OK + S_ON: 'S_ON', + S_STANDBY: 'S_STANDBY', + S_STATUS: 'S_STATUS', + S_WARMUP: 'S_WARMUP', } -# Map error/status codes to message strings -ERROR_MSG = { - E_OK: translate('OpenLP.ProjectorConstants', 'OK'), # E_OK | S_OK - E_GENERAL: translate('OpenLP.ProjectorConstants', 'General projector error'), - E_NOT_CONNECTED: translate('OpenLP.ProjectorConstants', 'Not connected error'), - E_LAMP: translate('OpenLP.ProjectorConstants', 'Lamp error'), - E_FAN: translate('OpenLP.ProjectorConstants', 'Fan error'), - E_TEMP: translate('OpenLP.ProjectorConstants', 'High temperature detected'), - E_COVER: translate('OpenLP.ProjectorConstants', 'Cover open detected'), - E_FILTER: translate('OpenLP.ProjectorConstants', 'Check filter'), - E_AUTHENTICATION: translate('OpenLP.ProjectorConstants', 'Authentication Error'), - E_UNDEFINED: translate('OpenLP.ProjectorConstants', 'Undefined Command'), - E_PARAMETER: translate('OpenLP.ProjectorConstants', 'Invalid Parameter'), - E_UNAVAILABLE: translate('OpenLP.ProjectorConstants', 'Projector Busy'), - E_PROJECTOR: translate('OpenLP.ProjectorConstants', 'Projector/Display Error'), - E_INVALID_DATA: translate('OpenLP.ProjectorConstants', 'Invalid packet received'), - E_WARN: translate('OpenLP.ProjectorConstants', 'Warning condition detected'), - E_ERROR: translate('OpenLP.ProjectorConstants', 'Error condition detected'), - E_CLASS: translate('OpenLP.ProjectorConstants', 'PJLink class not supported'), - E_PREFIX: translate('OpenLP.ProjectorConstants', 'Invalid prefix character'), - E_CONNECTION_REFUSED: translate('OpenLP.ProjectorConstants', - 'The connection was refused by the peer (or timed out)'), - E_REMOTE_HOST_CLOSED_CONNECTION: translate('OpenLP.ProjectorConstants', - 'The remote host closed the connection'), - E_HOST_NOT_FOUND: translate('OpenLP.ProjectorConstants', 'The host address was not found'), - E_SOCKET_ACCESS: translate('OpenLP.ProjectorConstants', - 'The socket operation failed because the application ' - 'lacked the required privileges'), - E_SOCKET_RESOURCE: translate('OpenLP.ProjectorConstants', - 'The local system ran out of resources (e.g., too many sockets)'), - E_SOCKET_TIMEOUT: translate('OpenLP.ProjectorConstants', - 'The socket operation timed out'), - E_DATAGRAM_TOO_LARGE: translate('OpenLP.ProjectorConstants', - 'The datagram was larger than the operating system\'s limit'), - E_NETWORK: translate('OpenLP.ProjectorConstants', - 'An error occurred with the network (Possibly someone pulled the plug?)'), +# Map status codes to message strings +STATUS_MSG = { E_ADDRESS_IN_USE: translate('OpenLP.ProjectorConstants', 'The address specified with socket.bind() ' 'is already in use and was set to be exclusive'), - E_SOCKET_ADDRESS_NOT_AVAILABLE: translate('OpenLP.ProjectorConstants', - 'The address specified to socket.bind() ' - 'does not belong to the host'), - E_UNSUPPORTED_SOCKET_OPERATION: translate('OpenLP.ProjectorConstants', - 'The requested socket operation is not supported by the local ' - 'operating system (e.g., lack of IPv6 support)'), + E_AUTHENTICATION: translate('OpenLP.ProjectorConstants', 'PJLink returned "ERRA: Authentication Error"'), + E_CONNECTION_REFUSED: translate('OpenLP.ProjectorConstants', + 'The connection was refused by the peer (or timed out)'), + E_COVER: translate('OpenLP.ProjectorConstants', 'Projector cover open detected'), + E_CLASS: translate('OpenLP.ProjectorConstants', 'PJLink class not supported'), + E_DATAGRAM_TOO_LARGE: translate('OpenLP.ProjectorConstants', + "The datagram was larger than the operating system's limit"), + E_ERROR: translate('OpenLP.ProjectorConstants', 'Error condition detected'), + E_FAN: translate('OpenLP.ProjectorConstants', 'Projector fan error'), + E_FILTER: translate('OpenLP.ProjectorConstants', 'Projector check filter'), + E_GENERAL: translate('OpenLP.ProjectorConstants', 'General projector error'), + E_HOST_NOT_FOUND: translate('OpenLP.ProjectorConstants', 'The host address was not found'), + E_INVALID_DATA: translate('OpenLP.ProjectorConstants', 'PJLink invalid packet received'), + E_LAMP: translate('OpenLP.ProjectorConstants', 'Projector lamp error'), + E_NETWORK: translate('OpenLP.ProjectorConstants', + 'An error occurred with the network (Possibly someone pulled the plug?)'), + E_NO_AUTHENTICATION: translate('OpenLP.ProjectorConstants', 'PJlink authentication Mismatch Error'), + E_NOT_CONNECTED: translate('OpenLP.ProjectorConstants', 'Projector not connected error'), + E_PARAMETER: translate('OpenLP.ProjectorConstants', 'PJLink returned "ERR2: Invalid Parameter"'), + E_PREFIX: translate('OpenLP.ProjectorConstants', 'PJLink Invalid prefix character'), + E_PROJECTOR: translate('OpenLP.ProjectorConstants', 'PJLink returned "ERR4: Projector/Display Error"'), E_PROXY_AUTHENTICATION_REQUIRED: translate('OpenLP.ProjectorConstants', 'The socket is using a proxy, ' 'and the proxy requires authentication'), - E_SLS_HANDSHAKE_FAILED: translate('OpenLP.ProjectorConstants', - 'The SSL/TLS handshake failed'), - E_UNFINISHED_SOCKET_OPERATION: translate('OpenLP.ProjectorConstants', - 'The last operation attempted has not finished yet ' - '(still in progress in the background)'), - E_PROXY_CONNECTION_REFUSED: translate('OpenLP.ProjectorConstants', - 'Could not contact the proxy server because the connection ' - 'to that server was denied'), E_PROXY_CONNECTION_CLOSED: translate('OpenLP.ProjectorConstants', 'The connection to the proxy server was closed unexpectedly ' '(before the connection to the final peer was established)'), + E_PROXY_CONNECTION_REFUSED: translate('OpenLP.ProjectorConstants', + 'Could not contact the proxy server because the connection ' + 'to that server was denied'), E_PROXY_CONNECTION_TIMEOUT: translate('OpenLP.ProjectorConstants', 'The connection to the proxy server timed out or the proxy ' 'server stopped responding in the authentication phase.'), @@ -373,51 +405,91 @@ ERROR_MSG = { E_PROXY_PROTOCOL: translate('OpenLP.ProjectorConstants', 'The connection negotiation with the proxy server failed because the ' 'response from the proxy server could not be understood'), - E_UNKNOWN_SOCKET_ERROR: translate('OpenLP.ProjectorConstants', 'An unidentified error occurred'), - S_NOT_CONNECTED: translate('OpenLP.ProjectorConstants', 'Not connected'), - S_CONNECTING: translate('OpenLP.ProjectorConstants', 'Connecting'), + E_REMOTE_HOST_CLOSED_CONNECTION: translate('OpenLP.ProjectorConstants', + 'The remote host closed the connection'), + E_SLS_HANDSHAKE_FAILED: translate('OpenLP.ProjectorConstants', + 'The SSL/TLS handshake failed'), + E_SOCKET_ADDRESS_NOT_AVAILABLE: translate('OpenLP.ProjectorConstants', + 'The address specified to socket.bind() ' + 'does not belong to the host'), + E_SOCKET_ACCESS: translate('OpenLP.ProjectorConstants', + 'The socket operation failed because the application ' + 'lacked the required privileges'), + E_SOCKET_RESOURCE: translate('OpenLP.ProjectorConstants', + 'The local system ran out of resources (e.g., too many sockets)'), + E_SOCKET_TIMEOUT: translate('OpenLP.ProjectorConstants', + 'The socket operation timed out'), + E_TEMP: translate('OpenLP.ProjectorConstants', 'Projector high temperature detected'), + E_UNAVAILABLE: translate('OpenLP.ProjectorConstants', 'PJLink returned "ERR3: Busy"'), + E_UNDEFINED: translate('OpenLP.ProjectorConstants', 'PJLink returned "ERR1: Undefined Command"'), + E_UNFINISHED_SOCKET_OPERATION: translate('OpenLP.ProjectorConstants', + 'The last operation attempted has not finished yet ' + '(still in progress in the background)'), + E_UNKNOWN: translate('OpenLP.ProjectorConstants', 'Unknown condiction detected'), + E_UNKNOWN_SOCKET_ERROR: translate('OpenLP.ProjectorConstants', 'An unidentified socket error occurred'), + E_UNSUPPORTED_SOCKET_OPERATION: translate('OpenLP.ProjectorConstants', + 'The requested socket operation is not supported by the local ' + 'operating system (e.g., lack of IPv6 support)'), + E_WARN: translate('OpenLP.ProjectorConstants', 'Warning condition detected'), + S_BOUND: translate('OpenLP.ProjectorConstants', 'Socket is bount to an address or port'), + S_CLOSING: translate('OpenLP.ProjectorConstants', 'Socket is about to close'), S_CONNECTED: translate('OpenLP.ProjectorConstants', 'Connected'), - S_STATUS: translate('OpenLP.ProjectorConstants', 'Getting status'), - S_OFF: translate('OpenLP.ProjectorConstants', 'Off'), - S_INITIALIZE: translate('OpenLP.ProjectorConstants', 'Initialize in progress'), - S_STANDBY: translate('OpenLP.ProjectorConstants', 'Power in standby'), - S_WARMUP: translate('OpenLP.ProjectorConstants', 'Warmup in progress'), - S_ON: translate('OpenLP.ProjectorConstants', 'Power is on'), + S_CONNECTING: translate('OpenLP.ProjectorConstants', 'Connecting'), S_COOLDOWN: translate('OpenLP.ProjectorConstants', 'Cooldown in progress'), + S_HOST_LOOKUP: translate('OpenLP.ProjectorConstants', 'Performing a host name lookup'), S_INFO: translate('OpenLP.ProjectorConstants', 'Projector Information available'), + S_INITIALIZE: translate('OpenLP.ProjectorConstants', 'Initialize in progress'), + S_LISTENING: translate('OpenLP.ProjectorConstants', 'Socket it listening (internal use only)'), + S_NETWORK_IDLE: translate('OpenLP.ProjectorConstants', 'No network activity at this time'), + S_NETWORK_RECEIVING: translate('OpenLP.ProjectorConstants', 'Received data'), S_NETWORK_SENDING: translate('OpenLP.ProjectorConstants', 'Sending data'), - S_NETWORK_RECEIVED: translate('OpenLP.ProjectorConstants', 'Received data') + S_NOT_CONNECTED: translate('OpenLP.ProjectorConstants', 'Not Connected'), + S_OFF: translate('OpenLP.ProjectorConstants', 'Off'), + S_OK: translate('OpenLP.ProjectorConstants', 'OK'), + S_ON: translate('OpenLP.ProjectorConstants', 'Power is on'), + S_STANDBY: translate('OpenLP.ProjectorConstants', 'Power in standby'), + S_STATUS: translate('OpenLP.ProjectorConstants', 'Getting status'), + S_WARMUP: translate('OpenLP.ProjectorConstants', 'Warmup in progress'), } -# Map ERST return code positions to equipment +# Map ERST reply positions to equipment +PJLINK_ERST_LIST = { + "FAN": translate('OpenLP.PJLink', 'Fan'), + "LAMP": translate('OpenLP.PJLink', 'Lamp'), + "TEMP": translate('OpenLP.PJLink', 'Temperature'), + "COVER": translate('OpenLP.PJLink', 'Cover'), + "FILTER": translate('OpenLP.PJLink', 'Filter'), + "OTHER": translate('OpenPL.PJLink', 'Other') +} + +# Map projector item to ERST data position PJLINK_ERST_DATA = { - 'DATA_LENGTH': 6, - 0: 'FAN', - 1: 'LAMP', - 2: 'TEMP', - 3: 'COVER', - 4: 'FILTER', - 5: 'OTHER', + 'DATA_LENGTH': 6, # Zero based so enums are 0-5 'FAN': 0, 'LAMP': 1, 'TEMP': 2, 'COVER': 3, 'FILTER': 4, - 'OTHER': 5 + 'OTHER': 5, + 0: 'FAN', + 1: 'LAMP', + 2: 'TEMP', + 3: 'COVER', + 4: 'FILTER', + 5: 'OTHER' } -# Map for ERST return codes to string +# Map ERST reply codes to string PJLINK_ERST_STATUS = { - '0': 'OK', - '1': ERROR_STRING[E_WARN], - '2': ERROR_STRING[E_ERROR], - 'OK': '0', - E_OK: '0', + '0': S_OK, + '1': E_WARN, + '2': E_ERROR, + S_OK: '0', E_WARN: '1', E_ERROR: '2' } -# Map for POWR return codes to status code +# Map POWR return codes to status code PJLINK_POWR_STATUS = { '0': S_STANDBY, '1': S_ON, diff --git a/openlp/core/projectors/db.py b/openlp/core/projectors/db.py index fe8785861..a2f060d75 100644 --- a/openlp/core/projectors/db.py +++ b/openlp/core/projectors/db.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/projectors/editform.py b/openlp/core/projectors/editform.py index 4ae1f96d9..a88681836 100644 --- a/openlp/core/projectors/editform.py +++ b/openlp/core/projectors/editform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -30,8 +30,8 @@ from PyQt5 import QtCore, QtWidgets from openlp.core.common import verify_ip_address from openlp.core.common.i18n import translate from openlp.core.lib import build_icon -from openlp.core.projectors.db import Projector from openlp.core.projectors.constants import PJLINK_PORT +from openlp.core.projectors.db import Projector log = logging.getLogger(__name__) log.debug('editform loaded') diff --git a/openlp/core/projectors/manager.py b/openlp/core/projectors/manager.py index ef3d2bda4..3144f7274 100644 --- a/openlp/core/projectors/manager.py +++ b/openlp/core/projectors/manager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -35,12 +35,28 @@ from openlp.core.common.registry import RegistryBase from openlp.core.common.settings import Settings from openlp.core.lib.ui import create_widget_action from openlp.core.projectors import DialogSourceStyle -from openlp.core.projectors.constants import ERROR_MSG, ERROR_STRING, E_AUTHENTICATION, E_ERROR, \ - E_NETWORK, E_NOT_CONNECTED, E_UNKNOWN_SOCKET_ERROR, STATUS_STRING, S_CONNECTED, S_CONNECTING, S_COOLDOWN, \ - S_INITIALIZE, S_NOT_CONNECTED, S_OFF, S_ON, S_STANDBY, S_WARMUP +from openlp.core.projectors.constants import \ + E_AUTHENTICATION, \ + E_ERROR, \ + E_NETWORK, \ + E_NOT_CONNECTED, \ + E_UNKNOWN_SOCKET_ERROR, \ + S_CONNECTED, \ + S_CONNECTING, \ + S_COOLDOWN, \ + S_INITIALIZE, \ + S_NOT_CONNECTED, \ + S_OFF, \ + S_ON, \ + S_STANDBY, \ + S_WARMUP, \ + STATUS_CODE, \ + STATUS_MSG, \ + QSOCKET_STATE + from openlp.core.projectors.db import ProjectorDB -from openlp.core.projectors.pjlink import PJLink, PJLinkUDP from openlp.core.projectors.editform import ProjectorEditForm +from openlp.core.projectors.pjlink import PJLink, PJLinkUDP from openlp.core.projectors.sourceselectform import SourceSelectTabs, SourceSelectSingle from openlp.core.widgets.toolbar import OpenLPToolbar @@ -439,11 +455,12 @@ class ProjectorManager(QtWidgets.QWidget, RegistryBase, UiProjectorManager, LogM :param opt: Needed by PyQt5 """ projector = item.data(QtCore.Qt.UserRole) - if projector.link.state() != projector.link.ConnectedState: + if QSOCKET_STATE[projector.link.state()] != S_CONNECTED: try: + log.debug('ProjectorManager: Calling connect_to_host() on "{ip}"'.format(ip=projector.link.ip)) projector.link.connect_to_host() except: - pass + log.debug('ProjectorManager: "{ip}" already connected - skipping'.format(ip=projector.link.ip)) return def on_connect_projector(self, opt=None): @@ -646,7 +663,7 @@ class ProjectorManager(QtWidgets.QWidget, RegistryBase, UiProjectorManager, LogM 'Other info'), data=projector.link.other_info) message += '{title}: {data}
'.format(title=translate('OpenLP.ProjectorManager', 'Power status'), - data=ERROR_MSG[projector.link.power]) + data=STATUS_MSG[projector.link.power]) message += '{title}: {data}
'.format(title=translate('OpenLP.ProjectorManager', 'Shutter is'), data=translate('OpenLP.ProjectorManager', 'Closed') if projector.link.shutter @@ -691,7 +708,7 @@ class ProjectorManager(QtWidgets.QWidget, RegistryBase, UiProjectorManager, LogM else: message += '{data}'.format(data=translate('OpenLP.ProjectorManager', 'Current errors/warnings')) for (key, val) in projector.link.projector_errors.items(): - message += '{key}: {data}
'.format(key=key, data=ERROR_MSG[val]) + message += '{key}: {data}
'.format(key=key, data=STATUS_MSG[val]) QtWidgets.QMessageBox.information(self, translate('OpenLP.ProjectorManager', 'Projector Information'), message) def _add_projector(self, projector): @@ -816,31 +833,18 @@ class ProjectorManager(QtWidgets.QWidget, RegistryBase, UiProjectorManager, LogM if ip == list_item.link.ip: item = list_item break - message = translate('OpenLP.ProjectorManager', 'No message') if msg is None else msg - if status in STATUS_STRING: - status_code = STATUS_STRING[status] - message = ERROR_MSG[status] if msg is None else msg - elif status in ERROR_STRING: - status_code = ERROR_STRING[status] - message = ERROR_MSG[status] if msg is None else msg - else: - status_code = status - message = ERROR_MSG[status] if msg is None else msg - log.debug('({name}) updateStatus(status={status}) message: "{message}"'.format(name=item.link.name, - status=status_code, - message=message)) - if status in STATUS_ICONS: - if item.status == status: - return - item.status = status - item.icon = QtGui.QIcon(QtGui.QPixmap(STATUS_ICONS[status])) - if status in ERROR_STRING: - status_code = ERROR_STRING[status] - elif status in STATUS_STRING: - status_code = STATUS_STRING[status] - log.debug('({name}) Updating icon with {code}'.format(name=item.link.name, code=status_code)) - item.widget.setIcon(item.icon) - self.update_icons() + if item is None: + log.error('ProjectorManager: Unknown item "{ip}" - not updating status'.format(ip=ip)) + return + elif item.status == status: + log.debug('ProjectorManager: No status change for "{ip}" - not updating status'.format(ip=ip)) + return + + item.status = status + item.icon = QtGui.QIcon(QtGui.QPixmap(STATUS_ICONS[status])) + log.debug('({name}) Updating icon with {code}'.format(name=item.link.name, code=STATUS_CODE[status])) + item.widget.setIcon(item.icon) + return self.update_icons() def get_toolbar_item(self, name, enabled=False, hidden=False): item = self.one_toolbar.findChild(QtWidgets.QAction, name) @@ -876,7 +880,7 @@ class ProjectorManager(QtWidgets.QWidget, RegistryBase, UiProjectorManager, LogM self.get_toolbar_item('show_projector_multiple', hidden=True) elif count == 1: projector = self.projector_list_widget.selectedItems()[0].data(QtCore.Qt.UserRole) - connected = projector.link.state() == projector.link.ConnectedState + connected = QSOCKET_STATE[projector.link.state()] == S_CONNECTED power = projector.link.power == S_ON self.get_toolbar_item('connect_projector_multiple', hidden=True) self.get_toolbar_item('disconnect_projector_multiple', hidden=True) diff --git a/openlp/core/projectors/pjlink.py b/openlp/core/projectors/pjlink.py index 3adb90a26..3e3bb3d2f 100644 --- a/openlp/core/projectors/pjlink.py +++ b/openlp/core/projectors/pjlink.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -54,11 +54,12 @@ from PyQt5 import QtCore, QtNetwork from openlp.core.common import qmd5_hash from openlp.core.common.i18n import translate -from openlp.core.projectors.constants import CONNECTION_ERRORS, CR, ERROR_MSG, ERROR_STRING, \ - E_AUTHENTICATION, E_CONNECTION_REFUSED, E_GENERAL, E_INVALID_DATA, E_NETWORK, E_NOT_CONNECTED, E_OK, \ - E_PARAMETER, E_PROJECTOR, E_SOCKET_TIMEOUT, E_UNAVAILABLE, E_UNDEFINED, PJLINK_ERRORS, PJLINK_ERST_DATA, \ - PJLINK_ERST_STATUS, PJLINK_MAX_PACKET, PJLINK_PORT, PJLINK_POWR_STATUS, PJLINK_VALID_CMD, \ - STATUS_STRING, S_CONNECTED, S_CONNECTING, S_INFO, S_NOT_CONNECTED, S_OFF, S_OK, S_ON, S_QSOCKET_STATE, S_STATUS +from openlp.core.projectors.constants import CONNECTION_ERRORS, PJLINK_CLASS, PJLINK_DEFAULT_CODES, PJLINK_ERRORS, \ + PJLINK_ERST_DATA, PJLINK_ERST_STATUS, PJLINK_MAX_PACKET, PJLINK_PREFIX, PJLINK_PORT, PJLINK_POWR_STATUS, \ + PJLINK_SUFFIX, PJLINK_VALID_CMD, PROJECTOR_STATE, STATUS_CODE, STATUS_MSG, QSOCKET_STATE, \ + E_AUTHENTICATION, E_CONNECTION_REFUSED, E_GENERAL, E_INVALID_DATA, E_NETWORK, E_NOT_CONNECTED, \ + E_OK, E_SOCKET_TIMEOUT, \ + S_CONNECTED, S_CONNECTING, S_INFO, S_NOT_CONNECTED, S_OFF, S_OK, S_ON, S_STATUS log = logging.getLogger(__name__) log.debug('pjlink loaded') @@ -69,12 +70,9 @@ __all__ = ['PJLink'] SocketError = QtNetwork.QAbstractSocket.SocketError SocketSTate = QtNetwork.QAbstractSocket.SocketState -PJLINK_PREFIX = '%' -PJLINK_CLASS = '1' # Default to class 1 until we query the projector # Add prefix here, but defer linkclass expansion until later when we have the actual # PJLink class for the command PJLINK_HEADER = '{prefix}{{linkclass}}'.format(prefix=PJLINK_PREFIX) -PJLINK_SUFFIX = CR class PJLinkUDP(QtNetwork.QUdpSocket): @@ -136,8 +134,9 @@ class PJLinkCommands(object): """ Initialize instance variables. Also used to reset projector-specific information to default. """ + conn_state = STATUS_CODE[QSOCKET_STATE[self.state()]] log.debug('({ip}) reset_information() connect status is {state}'.format(ip=self.ip, - state=S_QSOCKET_STATE[self.state()])) + state=conn_state)) self.fan = None # ERST self.filter_time = None # FILT self.lamp = None # LAMP @@ -183,42 +182,25 @@ class PJLinkCommands(object): # Due to some replies should stay as mixed-case, validate using separate uppercase check _data = data.upper() # Check if we have a future command not available yet - if cmd not in PJLINK_VALID_CMD: - log.error('({ip}) Ignoring command="{cmd}" (Invalid/Unknown)'.format(ip=self.ip, cmd=cmd)) + if cmd not in self.pjlink_functions: + log.warning('({ip}) Unable to process command="{cmd}" (Future option?)'.format(ip=self.ip, cmd=cmd)) return elif _data == 'OK': log.debug('({ip}) Command "{cmd}" returned OK'.format(ip=self.ip, cmd=cmd)) # A command returned successfully, so do a query on command to verify status return self.send_command(cmd=cmd) - elif cmd not in self.pjlink_functions: - log.warning('({ip}) Unable to process command="{cmd}" (Future option?)'.format(ip=self.ip, cmd=cmd)) - return elif _data in PJLINK_ERRORS: # Oops - projector error - log.error('({ip}) Projector returned error "{data}"'.format(ip=self.ip, data=data)) - if _data == PJLINK_ERRORS[E_AUTHENTICATION]: - # Authentication error + log.error('({ip}) {cmd}: {err}'.format(ip=self.ip, + cmd=cmd, + err=STATUS_MSG[PJLINK_ERRORS[_data]])) + if PJLINK_ERRORS[_data] == E_AUTHENTICATION: self.disconnect_from_host() - self.change_status(E_AUTHENTICATION) - log.debug('({ip}) emitting projectorAuthentication() signal'.format(ip=self.ip)) self.projectorAuthentication.emit(self.name) - elif _data == PJLINK_ERRORS[E_UNDEFINED]: - # Projector does not recognize command - self.change_status(E_UNDEFINED, '{error}: "{data}"'.format(error=ERROR_MSG[E_UNDEFINED], - data=cmd)) - elif _data == PJLINK_ERRORS[E_PARAMETER]: - # Invalid parameter - self.change_status(E_PARAMETER) - elif _data == PJLINK_ERRORS[E_UNAVAILABLE]: - # Projector busy - self.change_status(E_UNAVAILABLE) - elif _data == PJLINK_ERRORS[E_PROJECTOR]: - # Projector/display error - self.change_status(E_PROJECTOR) - return + return self.change_status(status=E_AUTHENTICATION) # Command checks already passed log.debug('({ip}) Calling function for {cmd}'.format(ip=self.ip, cmd=cmd)) - self.pjlink_functions[cmd](data) + self.pjlink_functions[cmd](data=data) def process_avmt(self, data): """ @@ -313,22 +295,22 @@ class PJLinkCommands(object): data[PJLINK_ERST_DATA['COVER']], data[PJLINK_ERST_DATA['FILTER']], data[PJLINK_ERST_DATA['OTHER']]) - if fan != PJLINK_ERST_STATUS[E_OK]: + if fan != PJLINK_ERST_STATUS[S_OK]: self.projector_errors[translate('OpenLP.ProjectorPJLink', 'Fan')] = \ PJLINK_ERST_STATUS[fan] - if lamp != PJLINK_ERST_STATUS[E_OK]: + if lamp != PJLINK_ERST_STATUS[S_OK]: self.projector_errors[translate('OpenLP.ProjectorPJLink', 'Lamp')] = \ PJLINK_ERST_STATUS[lamp] - if temp != PJLINK_ERST_STATUS[E_OK]: + if temp != PJLINK_ERST_STATUS[S_OK]: self.projector_errors[translate('OpenLP.ProjectorPJLink', 'Temperature')] = \ PJLINK_ERST_STATUS[temp] - if cover != PJLINK_ERST_STATUS[E_OK]: + if cover != PJLINK_ERST_STATUS[S_OK]: self.projector_errors[translate('OpenLP.ProjectorPJLink', 'Cover')] = \ PJLINK_ERST_STATUS[cover] - if filt != PJLINK_ERST_STATUS[E_OK]: + if filt != PJLINK_ERST_STATUS[S_OK]: self.projector_errors[translate('OpenLP.ProjectorPJLink', 'Filter')] = \ PJLINK_ERST_STATUS[filt] - if other != PJLINK_ERST_STATUS[E_OK]: + if other != PJLINK_ERST_STATUS[S_OK]: self.projector_errors[translate('OpenLP.ProjectorPJLink', 'Other')] = \ PJLINK_ERST_STATUS[other] return @@ -373,8 +355,18 @@ class PJLinkCommands(object): :param data: Currently selected source """ + # First, see if we have a valid input based on what is installed (if available) + if self.source_available is not None: + # We have available inputs, so verify it's in the list + if data not in self.source_available: + log.warn('({ip}) Input source not listed in available sources - ignoring'.format(ip=self.ip)) + return + elif data not in PJLINK_DEFAULT_CODES: + # Hmm - no sources available yet, so check with PJLink defaults + log.warn('({ip}) Input source not listed as a PJLink available source - ignoring'.format(ip=self.ip)) + return self.source = data - log.info('({ip}) Setting data source to "{data}"'.format(ip=self.ip, data=self.source)) + log.debug('({ip}) Setting data source to "{data}"'.format(ip=self.ip, data=self.source)) return def process_inst(self, data): @@ -390,7 +382,6 @@ class PJLinkCommands(object): sources.append(source) sources.sort() self.source_available = sources - self.projectorUpdateIcons.emit() log.debug('({ip}) Setting projector sources_available to "{data}"'.format(ip=self.ip, data=self.source_available)) return @@ -551,17 +542,15 @@ class PJLinkCommands(object): return elif self.sw_version is None: log.debug('({ip}) Setting projector software version to "{data}"'.format(ip=self.ip, data=data)) - self.sw_version = data - self.db_update = True else: - # Compare software version and see if we got the same projector - if self.serial_no != data: + if self.sw_version != data: log.warning('({ip}) Projector software version does not match saved ' 'software version'.format(ip=self.ip)) log.warning('({ip}) Saved: "{old}"'.format(ip=self.ip, old=self.sw_version)) log.warning('({ip}) Received: "{new}"'.format(ip=self.ip, new=data)) - log.warning('({ip}) Saving new serial number as sw_version_received'.format(ip=self.ip)) - self.sw_version_received = data + log.warning('({ip}) Updating software version'.format(ip=self.ip)) + self.sw_version = data + self.db_update = True class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): @@ -678,7 +667,7 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): Retrieve information from projector that changes. Normally called by timer(). """ - if self.state() != S_QSOCKET_STATE['ConnectedState']: + if QSOCKET_STATE[self.state()] != S_CONNECTED: log.warning('({ip}) poll_loop(): Not connected - returning'.format(ip=self.ip)) return log.debug('({ip}) poll_loop(): Updating projector status'.format(ip=self.ip)) @@ -688,13 +677,8 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): self.timer.setInterval(self.poll_time) # Restart timer self.timer.start() - # These commands may change during connection - check_list = ['POWR', 'ERST', 'LAMP', 'AVMT', 'INPT'] - if self.pjlink_class == '2': - check_list.extend(['FILT', 'FREZ']) - for command in check_list: - self.send_command(command) # The following commands do not change, so only check them once + # Call them first in case other functions rely on something here if self.power == S_ON and self.source_available is None: self.send_command('INST') if self.other_info is None: @@ -715,22 +699,28 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): self.send_command('RFIL') if self.model_lamp is None: self.send_command('RLMP') + # These commands may change during connection + check_list = ['POWR', 'ERST', 'LAMP', 'AVMT', 'INPT'] + if self.pjlink_class == '2': + check_list.extend(['FILT', 'FREZ']) + for command in check_list: + self.send_command(command) def _get_status(self, status): """ Helper to retrieve status/error codes and convert to strings. :param status: Status/Error code - :returns: (Status/Error code, String) + :returns: tuple (-1 if code not INT, None) + :returns: tuple (string: code as string, None if no description) + :returns: tuple (string: code as string, string: Status/Error description) """ if not isinstance(status, int): - return -1, 'Invalid status code' - elif status in ERROR_STRING: - return ERROR_STRING[status], ERROR_MSG[status] - elif status in STATUS_STRING: - return STATUS_STRING[status], ERROR_MSG[status] + return -1, None + elif status not in STATUS_MSG: + return None, None else: - return status, translate('OpenLP.PJLink', 'Unknown status') + return STATUS_CODE[status], STATUS_MSG[status] def change_status(self, status, msg=None): """ @@ -740,19 +730,27 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): :param status: Status code :param msg: Optional message """ - message = translate('OpenLP.PJLink', 'No message') if msg is None else msg - (code, message) = self._get_status(status) - if msg is not None: - message = msg + if status in STATUS_CODE: + log.debug('({ip}) Changing status to {status} ' + '"{msg}"'.format(ip=self.ip, + status=STATUS_CODE[status], + msg=msg if msg is not None else STATUS_MSG[status])) + else: + log.warning('({ip}) Unknown status change code: {code}'.format(ip=self.ip, + code=status)) + return if status in CONNECTION_ERRORS: - # Projector, connection state - self.projector_status = self.error_status = self.status_connect = E_NOT_CONNECTED - elif status >= S_NOT_CONNECTED and status < S_STATUS: + # Connection state error affects both socket and projector + self.error_status = status + self.status_connect = E_NOT_CONNECTED + elif status >= S_NOT_CONNECTED and status in QSOCKET_STATE: + # Socket connection status update self.status_connect = status - self.projector_status = S_NOT_CONNECTED - elif status <= S_INFO: - self.status_connect = S_CONNECTED + elif status >= S_NOT_CONNECTED and status in PROJECTOR_STATE: + # Only affects the projector status self.projector_status = status + + # These log entries are for troubleshooting only (status_code, status_message) = self._get_status(self.status_connect) log.debug('({ip}) status_connect: {code}: "{message}"'.format(ip=self.ip, code=status_code, @@ -765,6 +763,15 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): log.debug('({ip}) error_status: {code}: "{message}"'.format(ip=self.ip, code=status_code, message=status_message if msg is None else msg)) + + # Now that we logged extra information for debugging, broadcast the original change/message + (code, message) = self._get_status(status) + if msg is not None: + message = msg + elif message is None: + # No message for status code + message = translate('OpenLP.PJLink', 'No message') if msg is None else msg + self.changeStatus.emit(self.ip, status, message) self.projectorUpdateIcons.emit() @@ -794,7 +801,7 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): data = decode(read, 'utf-8') # Possibility of extraneous data on input when reading. # Clean out extraneous characters in buffer. - self.readLine(self.max_size) + self.read(1024) log.debug('({ip}) check_login() read "{data}"'.format(ip=self.ip, data=data.strip())) # At this point, we should only have the initial login prompt with # possible authentication @@ -805,6 +812,7 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): # Invalid initial packet - close socket log.error('({ip}) Invalid initial packet received - closing socket'.format(ip=self.ip)) return self.disconnect_from_host() + # Convert the initial login prompt with the expected PJLink normal command format for processing log.debug('({ip}) check_login(): Formatting initial connection prompt to PJLink packet'.format(ip=self.ip)) return self.get_data('{start}{clss}{data}'.format(start=PJLINK_PREFIX, clss='1', @@ -895,7 +903,7 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): Get data from TCP socket. """ log.debug('({ip}) get_socket(): Reading data'.format(ip=self.ip)) - if self.state() != self.ConnectedState: + if QSOCKET_STATE[self.state()] != S_CONNECTED: log.debug('({ip}) get_socket(): Not connected - returning'.format(ip=self.ip)) self.send_busy = False return @@ -907,8 +915,7 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): log.debug('({ip}) get_socket(): No data available (-1)'.format(ip=self.ip)) return self.receive_data_signal() self.socket_timer.stop() - self.get_data(buff=read, ip=self.ip) - return self.receive_data_signal() + return self.get_data(buff=read, ip=self.ip) def get_data(self, buff, ip=None): """ @@ -927,13 +934,17 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): data = data_in.strip() # Initial packet checks if (len(data) < 7): - return self._trash_buffer(msg='get_data(): Invalid packet - length') + self._trash_buffer(msg='get_data(): Invalid packet - length') + return self.receive_data_signal() elif len(data) > self.max_size: - return self._trash_buffer(msg='get_data(): Invalid packet - too long') + self._trash_buffer(msg='get_data(): Invalid packet - too long') + return self.receive_data_signal() elif not data.startswith(PJLINK_PREFIX): - return self._trash_buffer(msg='get_data(): Invalid packet - PJLink prefix missing') + self._trash_buffer(msg='get_data(): Invalid packet - PJLink prefix missing') + return self.receive_data_signal() elif '=' not in data: - return self._trash_buffer(msg='get_data(): Invalid reply - Does not have "="') + self._trash_buffer(msg='get_data(): Invalid reply - Does not have "="') + return self.receive_data_signal() log.debug('({ip}) get_data(): Checking new data "{data}"'.format(ip=self.ip, data=data)) header, data = data.split('=') # At this point, the header should contain: @@ -947,15 +958,17 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): except ValueError as e: self.change_status(E_INVALID_DATA) log.warning('({ip}) get_data(): Received data: "{data}"'.format(ip=self.ip, data=data_in)) - return self._trash_buffer('get_data(): Expected header + command + data') + self._trash_buffer('get_data(): Expected header + command + data') + return self.receive_data_signal() if cmd not in PJLINK_VALID_CMD: log.warning('({ip}) get_data(): Invalid packet - unknown command "{data}"'.format(ip=self.ip, data=cmd)) - return self._trash_buffer(msg='get_data(): Unknown command "{data}"'.format(data=cmd)) + self._trash_buffer(msg='get_data(): Unknown command "{data}"'.format(data=cmd)) + return self.receive_data_signal() if int(self.pjlink_class) < int(version): log.warning('({ip}) get_data(): Projector returned class reply higher ' 'than projector stated class'.format(ip=self.ip)) - self.send_busy = False - return self.process_command(cmd, data) + self.process_command(cmd, data) + return self.receive_data_signal() @QtCore.pyqtSlot(QtNetwork.QAbstractSocket.SocketError) def get_error(self, err): @@ -993,7 +1006,7 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): :param salt: Optional salt for md5 hash initial authentication :param priority: Option to send packet now rather than queue it up """ - if self.state() != self.ConnectedState: + if QSOCKET_STATE[self.state()] != S_CONNECTED: log.warning('({ip}) send_command(): Not connected - returning'.format(ip=self.ip)) return self.reset_information() if cmd not in PJLINK_VALID_CMD: @@ -1018,7 +1031,7 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): header=header, command=cmd, options=opts, - suffix=CR) + suffix=PJLINK_SUFFIX) if out in self.priority_queue: log.debug('({ip}) send_command(): Already in priority queue - skipping'.format(ip=self.ip)) elif out in self.send_queue: @@ -1044,9 +1057,10 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): """ # Funny looking data check, but it's a quick check for data=None log.debug('({ip}) _send_command(data="{data}")'.format(ip=self.ip, data=data.strip() if data else data)) + conn_state = STATUS_CODE[QSOCKET_STATE[self.state()]] log.debug('({ip}) _send_command(): Connection status: {data}'.format(ip=self.ip, - data=S_QSOCKET_STATE[self.state()])) - if self.state() != self.ConnectedState: + data=conn_state)) + if QSOCKET_STATE[self.state()] != S_CONNECTED: log.debug('({ip}) _send_command() Not connected - abort'.format(ip=self.ip)) self.send_busy = False return self.disconnect_from_host() @@ -1088,10 +1102,11 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): """ Initiate connection to projector. """ - log.debug('{ip}) connect_to_host(): Starting connection'.format(ip=self.ip)) - if self.state() == self.ConnectedState: + log.debug('({ip}) connect_to_host(): Starting connection'.format(ip=self.ip)) + if QSOCKET_STATE[self.state()] == S_CONNECTED: log.warning('({ip}) connect_to_host(): Already connected - returning'.format(ip=self.ip)) return + self.error_status = S_OK self.change_status(S_CONNECTING) self.connectToHost(self.ip, self.port if isinstance(self.port, int) else int(self.port)) @@ -1100,12 +1115,13 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): """ Close socket and cleanup. """ - if abort or self.state() != self.ConnectedState: + if abort or QSOCKET_STATE[self.state()] != S_NOT_CONNECTED: if abort: log.warning('({ip}) disconnect_from_host(): Aborting connection'.format(ip=self.ip)) + self.abort() else: log.warning('({ip}) disconnect_from_host(): Not connected'.format(ip=self.ip)) - self.disconnectFromHost() + self.disconnectFromHost() try: self.readyRead.disconnect(self.get_socket) except TypeError: @@ -1201,7 +1217,7 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): elif src not in self.source_available: return log.debug('({ip}) Setting input source to "{data}"'.format(ip=self.ip, data=src)) - self.send_command(cmd='INPT', opts=src) + self.send_command(cmd='INPT', opts=src, priority=True) self.poll_loop() def set_power_on(self): @@ -1209,7 +1225,7 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): Send command to turn power to on. """ log.debug('({ip}) Setting POWR to 1 (on)'.format(ip=self.ip)) - self.send_command(cmd='POWR', opts='1') + self.send_command(cmd='POWR', opts='1', priority=True) self.poll_loop() def set_power_off(self): @@ -1217,7 +1233,7 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): Send command to turn power to standby. """ log.debug('({ip}) Setting POWR to 0 (standby)'.format(ip=self.ip)) - self.send_command(cmd='POWR', opts='0') + self.send_command(cmd='POWR', opts='0', priority=True) self.poll_loop() def set_shutter_closed(self): @@ -1225,7 +1241,7 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): Send command to set shutter to closed position. """ log.debug('({ip}) Setting AVMT to 11 (shutter closed)'.format(ip=self.ip)) - self.send_command(cmd='AVMT', opts='11') + self.send_command(cmd='AVMT', opts='11', priority=True) self.poll_loop() def set_shutter_open(self): @@ -1233,8 +1249,9 @@ class PJLink(QtNetwork.QTcpSocket, PJLinkCommands): Send command to set shutter to open position. """ log.debug('({ip}) Setting AVMT to "10" (shutter open)'.format(ip=self.ip)) - self.send_command(cmd='AVMT', opts='10') + self.send_command(cmd='AVMT', opts='10', priority=True) self.poll_loop() + self.projectorUpdateIcons.emit() def receive_data_signal(self): """ diff --git a/openlp/core/projectors/sourceselectform.py b/openlp/core/projectors/sourceselectform.py index aaf8170ac..b9c3501a4 100644 --- a/openlp/core/projectors/sourceselectform.py +++ b/openlp/core/projectors/sourceselectform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -31,8 +31,8 @@ from PyQt5 import QtCore, QtWidgets from openlp.core.common import is_macosx from openlp.core.common.i18n import translate from openlp.core.lib import build_icon -from openlp.core.projectors.db import ProjectorSource from openlp.core.projectors.constants import PJLINK_DEFAULT_SOURCES, PJLINK_DEFAULT_CODES +from openlp.core.projectors.db import ProjectorSource log = logging.getLogger(__name__) diff --git a/openlp/core/projectors/tab.py b/openlp/core/projectors/tab.py index 29e6a9511..2f308d83a 100644 --- a/openlp/core/projectors/tab.py +++ b/openlp/core/projectors/tab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/projectors/upgrade.py b/openlp/core/projectors/upgrade.py index 83cd2defb..1bcd756dc 100644 --- a/openlp/core/projectors/upgrade.py +++ b/openlp/core/projectors/upgrade.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/threading.py b/openlp/core/threading.py index 96c80cbfd..b978b2c22 100644 --- a/openlp/core/threading.py +++ b/openlp/core/threading.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/__init__.py b/openlp/core/ui/__init__.py index 5c2463e5d..e6cd930b1 100644 --- a/openlp/core/ui/__init__.py +++ b/openlp/core/ui/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/aboutdialog.py b/openlp/core/ui/aboutdialog.py index 8cd422ecf..d60f0ee0c 100644 --- a/openlp/core/ui/aboutdialog.py +++ b/openlp/core/ui/aboutdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/aboutform.py b/openlp/core/ui/aboutform.py index e2b4eca87..5967108d5 100644 --- a/openlp/core/ui/aboutform.py +++ b/openlp/core/ui/aboutform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -26,8 +26,8 @@ import webbrowser from PyQt5 import QtCore, QtWidgets -from openlp.core.version import get_version from openlp.core.common.i18n import translate +from openlp.core.version import get_version from .aboutdialog import UiAboutDialog diff --git a/openlp/core/ui/advancedtab.py b/openlp/core/ui/advancedtab.py index 2d434c0c6..ffec0e5b8 100644 --- a/openlp/core/ui/advancedtab.py +++ b/openlp/core/ui/advancedtab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/exceptiondialog.py b/openlp/core/ui/exceptiondialog.py index 0cdd3d28d..bb46868a2 100644 --- a/openlp/core/ui/exceptiondialog.py +++ b/openlp/core/ui/exceptiondialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/exceptionform.py b/openlp/core/ui/exceptionform.py index 45124dac8..b981bddbc 100644 --- a/openlp/core/ui/exceptionform.py +++ b/openlp/core/ui/exceptionform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/filerenamedialog.py b/openlp/core/ui/filerenamedialog.py index 0c2e089af..9db2dbb06 100644 --- a/openlp/core/ui/filerenamedialog.py +++ b/openlp/core/ui/filerenamedialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/filerenameform.py b/openlp/core/ui/filerenameform.py index 249ea1f10..471242207 100644 --- a/openlp/core/ui/filerenameform.py +++ b/openlp/core/ui/filerenameform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/firsttimeform.py b/openlp/core/ui/firsttimeform.py index 940b1ccec..7dae8a938 100644 --- a/openlp/core/ui/firsttimeform.py +++ b/openlp/core/ui/firsttimeform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -26,9 +26,9 @@ import logging import os import socket import time -import urllib.request -import urllib.parse import urllib.error +import urllib.parse +import urllib.request from configparser import ConfigParser, MissingSectionHeaderError, NoOptionError, NoSectionError from tempfile import gettempdir @@ -399,7 +399,7 @@ class FirstTimeForm(QtWidgets.QWizard, UiFirstTimeWizard, RegistryProperties): screenshot = self.config.get('theme_{theme}'.format(theme=theme), 'screenshot') item = self.themes_list_widget.item(index) if item: - item.setIcon(build_icon(os.path.join(gettempdir(), 'openlp', screenshot))) + item.setIcon(build_icon(Path(gettempdir(), 'openlp', screenshot))) def _download_progress(self, count, block_size): """ @@ -548,9 +548,9 @@ class FirstTimeForm(QtWidgets.QWizard, UiFirstTimeWizard, RegistryProperties): Download selected songs, bibles and themes. Returns False on download error """ # Build directories for downloads - songs_destination = os.path.join(gettempdir(), 'openlp') - bibles_destination = str(AppLocation.get_section_data_path('bibles')) - themes_destination = str(AppLocation.get_section_data_path('themes')) + songs_destination_path = Path(gettempdir(), 'openlp') + bibles_destination_path = AppLocation.get_section_data_path('bibles') + themes_destination_path = AppLocation.get_section_data_path('themes') missed_files = [] # Download songs for i in range(self.songs_list_widget.count()): @@ -559,7 +559,7 @@ class FirstTimeForm(QtWidgets.QWizard, UiFirstTimeWizard, RegistryProperties): filename, sha256 = item.data(QtCore.Qt.UserRole) self._increment_progress_bar(self.downloading.format(name=filename), 0) self.previous_size = 0 - destination = Path(songs_destination, str(filename)) + destination = songs_destination_path / str(filename) if not download_file(self, '{path}{name}'.format(path=self.songs_url, name=filename), destination, sha256): missed_files.append('Song: {name}'.format(name=filename)) @@ -572,8 +572,7 @@ class FirstTimeForm(QtWidgets.QWizard, UiFirstTimeWizard, RegistryProperties): self._increment_progress_bar(self.downloading.format(name=bible), 0) self.previous_size = 0 if not download_file(self, '{path}{name}'.format(path=self.bibles_url, name=bible), - Path(bibles_destination, bible), - sha256): + bibles_destination_path / bible, sha256): missed_files.append('Bible: {name}'.format(name=bible)) bibles_iterator += 1 # Download themes @@ -584,8 +583,7 @@ class FirstTimeForm(QtWidgets.QWizard, UiFirstTimeWizard, RegistryProperties): self._increment_progress_bar(self.downloading.format(name=theme), 0) self.previous_size = 0 if not download_file(self, '{path}{name}'.format(path=self.themes_url, name=theme), - Path(themes_destination, theme), - sha256): + themes_destination_path / theme, sha256): missed_files.append('Theme: {name}'.format(name=theme)) if missed_files: file_list = '' diff --git a/openlp/core/ui/firsttimelanguagedialog.py b/openlp/core/ui/firsttimelanguagedialog.py index abe12aa63..21aeac5e5 100644 --- a/openlp/core/ui/firsttimelanguagedialog.py +++ b/openlp/core/ui/firsttimelanguagedialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/firsttimelanguageform.py b/openlp/core/ui/firsttimelanguageform.py index 1131883bf..aae5ee739 100644 --- a/openlp/core/ui/firsttimelanguageform.py +++ b/openlp/core/ui/firsttimelanguageform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/firsttimewizard.py b/openlp/core/ui/firsttimewizard.py index 5212479ef..9f9261015 100644 --- a/openlp/core/ui/firsttimewizard.py +++ b/openlp/core/ui/firsttimewizard.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/formattingtagcontroller.py b/openlp/core/ui/formattingtagcontroller.py index 4b9d75fee..198a9f975 100644 --- a/openlp/core/ui/formattingtagcontroller.py +++ b/openlp/core/ui/formattingtagcontroller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/formattingtagdialog.py b/openlp/core/ui/formattingtagdialog.py index fa36fa818..f9a12489c 100644 --- a/openlp/core/ui/formattingtagdialog.py +++ b/openlp/core/ui/formattingtagdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/formattingtagform.py b/openlp/core/ui/formattingtagform.py index ab0bfc79f..e4045e59e 100644 --- a/openlp/core/ui/formattingtagform.py +++ b/openlp/core/ui/formattingtagform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -28,8 +28,8 @@ from PyQt5 import QtCore, QtWidgets from openlp.core.common.i18n import translate from openlp.core.lib import FormattingTags -from openlp.core.ui.formattingtagdialog import Ui_FormattingTagDialog from openlp.core.ui.formattingtagcontroller import FormattingTagController +from openlp.core.ui.formattingtagdialog import Ui_FormattingTagDialog class EditColumn(object): diff --git a/openlp/core/ui/generaltab.py b/openlp/core/ui/generaltab.py index a908ac91d..7197aee7b 100644 --- a/openlp/core/ui/generaltab.py +++ b/openlp/core/ui/generaltab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/maindisplay.py b/openlp/core/ui/maindisplay.py index 80cccdb4c..181d241ff 100644 --- a/openlp/core/ui/maindisplay.py +++ b/openlp/core/ui/maindisplay.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/mainwindow.py b/openlp/core/ui/mainwindow.py index d905aec25..a16bfaa19 100644 --- a/openlp/core/ui/mainwindow.py +++ b/openlp/core/ui/mainwindow.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,8 +23,6 @@ This is the main window, where all the action happens. """ import logging -import os -import shutil import sys import time from datetime import datetime @@ -40,25 +38,24 @@ from openlp.core.common import is_win, is_macosx, add_actions from openlp.core.common.actions import ActionList, CategoryOrder from openlp.core.common.applocation import AppLocation from openlp.core.common.i18n import LanguageManager, UiStrings, translate -from openlp.core.common.path import Path, copyfile, create_paths from openlp.core.common.mixins import RegistryProperties +from openlp.core.common.path import Path, copyfile, create_paths from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings -from openlp.core.display.screens import ScreenList from openlp.core.display.renderer import Renderer +from openlp.core.display.screens import ScreenList from openlp.core.lib import PluginManager, ImageManager, PluginStatus, build_icon from openlp.core.lib.ui import create_action from openlp.core.projectors.manager import ProjectorManager from openlp.core.ui import AboutForm, SettingsForm, ServiceManager, ThemeManager, LiveController, PluginForm, \ ShortcutListForm, FormattingTagForm, PreviewController from openlp.core.ui.firsttimeform import FirstTimeForm -from openlp.core.widgets.dialogs import FileDialog -from openlp.core.widgets.docks import OpenLPDockWidget, MediaDockManager from openlp.core.ui.media import MediaController from openlp.core.ui.printserviceform import PrintServiceForm from openlp.core.ui.style import PROGRESSBAR_STYLE, get_library_stylesheet from openlp.core.version import get_version - +from openlp.core.widgets.dialogs import FileDialog +from openlp.core.widgets.docks import OpenLPDockWidget, MediaDockManager log = logging.getLogger(__name__) diff --git a/openlp/core/ui/media/__init__.py b/openlp/core/ui/media/__init__.py index 145f5e8bd..da80aee5f 100644 --- a/openlp/core/ui/media/__init__.py +++ b/openlp/core/ui/media/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/media/endpoint.py b/openlp/core/ui/media/endpoint.py index af7623003..dce41de8d 100644 --- a/openlp/core/ui/media/endpoint.py +++ b/openlp/core/ui/media/endpoint.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -24,8 +24,8 @@ The :mod:`~openlp.core.api.endpoint` module contains various API endpoints """ import logging -from openlp.core.api.http.endpoint import Endpoint from openlp.core.api.http import requires_auth +from openlp.core.api.http.endpoint import Endpoint from openlp.core.common.registry import Registry log = logging.getLogger(__name__) diff --git a/openlp/core/ui/media/mediacontroller.py b/openlp/core/ui/media/mediacontroller.py index 87d3a3063..ed593dd88 100644 --- a/openlp/core/ui/media/mediacontroller.py +++ b/openlp/core/ui/media/mediacontroller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,9 +23,10 @@ The :mod:`~openlp.core.ui.media.mediacontroller` module contains a base class for media components and other widgets related to playing media, such as sliders. """ +import datetime import logging import os -import datetime + from PyQt5 import QtCore, QtWidgets from openlp.core.api.http import register_endpoint @@ -37,14 +38,13 @@ from openlp.core.common.settings import Settings from openlp.core.lib import ItemCapabilities from openlp.core.lib.ui import critical_error_message_box from openlp.core.ui import DisplayControllerType -from openlp.core.ui.media.endpoint import media_endpoint -from openlp.core.ui.media.vendor.mediainfoWrapper import MediaInfoWrapper -from openlp.core.ui.media.mediaplayer import MediaPlayer -from openlp.core.ui.media import MediaState, MediaInfo, MediaType, get_media_players, set_media_players,\ +from openlp.core.ui.media import MediaState, MediaInfo, MediaType, get_media_players, set_media_players, \ parse_optical_path +from openlp.core.ui.media.endpoint import media_endpoint +from openlp.core.ui.media.mediaplayer import MediaPlayer +from openlp.core.ui.media.vendor.mediainfoWrapper import MediaInfoWrapper from openlp.core.widgets.toolbar import OpenLPToolbar - log = logging.getLogger(__name__) TICK_TIME = 200 diff --git a/openlp/core/ui/media/mediaplayer.py b/openlp/core/ui/media/mediaplayer.py index 77d089c89..a8273cdb5 100644 --- a/openlp/core/ui/media/mediaplayer.py +++ b/openlp/core/ui/media/mediaplayer.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/media/playertab.py b/openlp/core/ui/media/playertab.py index 28d7798ee..d6b3aee5a 100644 --- a/openlp/core/ui/media/playertab.py +++ b/openlp/core/ui/media/playertab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/media/systemplayer.py b/openlp/core/ui/media/systemplayer.py index 59245aa89..063c9acea 100644 --- a/openlp/core/ui/media/systemplayer.py +++ b/openlp/core/ui/media/systemplayer.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -33,7 +33,6 @@ from openlp.core.ui.media import MediaState from openlp.core.ui.media.mediaplayer import MediaPlayer from openlp.core.threading import ThreadWorker, run_thread, is_thread_finished - log = logging.getLogger(__name__) ADDITIONAL_EXT = { diff --git a/openlp/core/ui/media/vendor/__init__.py b/openlp/core/ui/media/vendor/__init__.py index 2b8cd2dd2..7d9d02f89 100644 --- a/openlp/core/ui/media/vendor/__init__.py +++ b/openlp/core/ui/media/vendor/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/media/vendor/mediainfoWrapper.py b/openlp/core/ui/media/vendor/mediainfoWrapper.py index 97d936d6b..d28fe1395 100644 --- a/openlp/core/ui/media/vendor/mediainfoWrapper.py +++ b/openlp/core/ui/media/vendor/mediainfoWrapper.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/media/vendor/vlc.py b/openlp/core/ui/media/vendor/vlc.py index 7383621b0..b7c7cfdce 100644 --- a/openlp/core/ui/media/vendor/vlc.py +++ b/openlp/core/ui/media/vendor/vlc.py @@ -40,11 +40,10 @@ C{get_instance} method of L{MediaPlayer} and L{MediaListPlayer}. """ import ctypes -from ctypes.util import find_library +import functools import os import sys -import functools - +from ctypes.util import find_library # Used by EventManager in override.py from inspect import getargspec diff --git a/openlp/core/ui/media/vlcplayer.py b/openlp/core/ui/media/vlcplayer.py index 840471cfe..7f39a70df 100644 --- a/openlp/core/ui/media/vlcplayer.py +++ b/openlp/core/ui/media/vlcplayer.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,13 +22,14 @@ """ The :mod:`~openlp.core.ui.media.vlcplayer` module contains our VLC component wrapper """ -from datetime import datetime -from distutils.version import LooseVersion +import ctypes import logging import os -import threading import sys -import ctypes +import threading +from datetime import datetime +from distutils.version import LooseVersion + from PyQt5 import QtWidgets from openlp.core.common import is_win, is_macosx, is_linux diff --git a/openlp/core/ui/media/webkitplayer.py b/openlp/core/ui/media/webkitplayer.py index e9142463e..5845d655e 100644 --- a/openlp/core/ui/media/webkitplayer.py +++ b/openlp/core/ui/media/webkitplayer.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -26,8 +26,8 @@ import logging from PyQt5 import QtGui, QtWebKitWidgets -from openlp.core.common.settings import Settings from openlp.core.common.i18n import translate +from openlp.core.common.settings import Settings from openlp.core.ui.media import MediaState from openlp.core.ui.media.mediaplayer import MediaPlayer diff --git a/openlp/core/ui/plugindialog.py b/openlp/core/ui/plugindialog.py index 76087a33a..8aabea21d 100644 --- a/openlp/core/ui/plugindialog.py +++ b/openlp/core/ui/plugindialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/pluginform.py b/openlp/core/ui/pluginform.py index 43fa5e68d..6eb296b70 100644 --- a/openlp/core/ui/pluginform.py +++ b/openlp/core/ui/pluginform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/printservicedialog.py b/openlp/core/ui/printservicedialog.py index ee3b07080..769f9f699 100644 --- a/openlp/core/ui/printservicedialog.py +++ b/openlp/core/ui/printservicedialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/printserviceform.py b/openlp/core/ui/printserviceform.py index 07ab24496..ba1b318d7 100644 --- a/openlp/core/ui/printserviceform.py +++ b/openlp/core/ui/printserviceform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -24,8 +24,8 @@ The actual print service dialog """ import datetime import html -import lxml.html +import lxml.html from PyQt5 import QtCore, QtGui, QtWidgets, QtPrintSupport from openlp.core.common.applocation import AppLocation diff --git a/openlp/core/ui/serviceitemeditdialog.py b/openlp/core/ui/serviceitemeditdialog.py index 80be015f8..5206ff136 100644 --- a/openlp/core/ui/serviceitemeditdialog.py +++ b/openlp/core/ui/serviceitemeditdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/serviceitemeditform.py b/openlp/core/ui/serviceitemeditform.py index 0a4b7cab6..dce243f7d 100644 --- a/openlp/core/ui/serviceitemeditform.py +++ b/openlp/core/ui/serviceitemeditform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/servicemanager.py b/openlp/core/ui/servicemanager.py index 875a48fdf..5d355f88a 100644 --- a/openlp/core/ui/servicemanager.py +++ b/openlp/core/ui/servicemanager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/servicenoteform.py b/openlp/core/ui/servicenoteform.py index 179248570..b4e61ce69 100644 --- a/openlp/core/ui/servicenoteform.py +++ b/openlp/core/ui/servicenoteform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/settingsdialog.py b/openlp/core/ui/settingsdialog.py index 0e591e6ad..a6b91368c 100644 --- a/openlp/core/ui/settingsdialog.py +++ b/openlp/core/ui/settingsdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/settingsform.py b/openlp/core/ui/settingsform.py index 4d7c4ff6c..e3190eab6 100644 --- a/openlp/core/ui/settingsform.py +++ b/openlp/core/ui/settingsform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/shortcutlistdialog.py b/openlp/core/ui/shortcutlistdialog.py index 22da4109f..522a30022 100644 --- a/openlp/core/ui/shortcutlistdialog.py +++ b/openlp/core/ui/shortcutlistdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/shortcutlistform.py b/openlp/core/ui/shortcutlistform.py index 92a0e789f..779b86eea 100644 --- a/openlp/core/ui/shortcutlistform.py +++ b/openlp/core/ui/shortcutlistform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/slidecontroller.py b/openlp/core/ui/slidecontroller.py index 5b9872082..c34e2189f 100644 --- a/openlp/core/ui/slidecontroller.py +++ b/openlp/core/ui/slidecontroller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -42,7 +42,6 @@ from openlp.core.ui import HideMode, MainDisplay, Display, DisplayControllerType from openlp.core.widgets.toolbar import OpenLPToolbar from openlp.core.widgets.views import ListPreviewWidget - # Threshold which has to be trespassed to toggle. HIDE_MENU_THRESHOLD = 27 AUDIO_TIME_LABEL_STYLESHEET = 'background-color: palette(background); ' \ diff --git a/openlp/core/ui/splashscreen.py b/openlp/core/ui/splashscreen.py index dd9764a2e..6e6ca4b97 100644 --- a/openlp/core/ui/splashscreen.py +++ b/openlp/core/ui/splashscreen.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/starttimedialog.py b/openlp/core/ui/starttimedialog.py index fd5163593..05118bce6 100644 --- a/openlp/core/ui/starttimedialog.py +++ b/openlp/core/ui/starttimedialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/starttimeform.py b/openlp/core/ui/starttimeform.py index 00d0bff40..9d8bee4cf 100644 --- a/openlp/core/ui/starttimeform.py +++ b/openlp/core/ui/starttimeform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/style.py b/openlp/core/ui/style.py index 764a3bd26..23f22c540 100644 --- a/openlp/core/ui/style.py +++ b/openlp/core/ui/style.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -24,7 +24,7 @@ The :mod:`~openlp.core.ui.dark` module looks for and loads a dark theme """ from PyQt5 import QtGui -from openlp.core.common import is_macosx, is_win +from openlp.core.common import is_win from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings diff --git a/openlp/core/ui/themeform.py b/openlp/core/ui/themeform.py index f8449986a..29b04477c 100644 --- a/openlp/core/ui/themeform.py +++ b/openlp/core/ui/themeform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/themelayoutdialog.py b/openlp/core/ui/themelayoutdialog.py index d9ed9638d..159ac7c9e 100644 --- a/openlp/core/ui/themelayoutdialog.py +++ b/openlp/core/ui/themelayoutdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/themelayoutform.py b/openlp/core/ui/themelayoutform.py index 2b4b114f6..5c676d2d5 100644 --- a/openlp/core/ui/themelayoutform.py +++ b/openlp/core/ui/themelayoutform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/thememanager.py b/openlp/core/ui/thememanager.py index fae75f81d..4a544b11d 100644 --- a/openlp/core/ui/thememanager.py +++ b/openlp/core/ui/thememanager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/themestab.py b/openlp/core/ui/themestab.py index d578e0082..077f59d83 100644 --- a/openlp/core/ui/themestab.py +++ b/openlp/core/ui/themestab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/ui/themewizard.py b/openlp/core/ui/themewizard.py index d7bc5f822..9e75c1e82 100644 --- a/openlp/core/ui/themewizard.py +++ b/openlp/core/ui/themewizard.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/version.py b/openlp/core/version.py index e4d269f81..ff0fe65b3 100644 --- a/openlp/core/version.py +++ b/openlp/core/version.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -74,13 +74,11 @@ class VersionWorker(ThreadWorker): * If a version number's minor version is an even number, it is a stable release. """ log.debug('VersionWorker - Start') - # I'm not entirely sure why this was here, I'm commenting it out until I hit the same scenario - time.sleep(1) - download_url = 'http://www.openlp.org/files/version.txt' + download_url = 'https://www.openlp.org/files/version.txt' if self.current_version['build']: - download_url = 'http://www.openlp.org/files/nightly_version.txt' + download_url = 'https://www.openlp.org/files/nightly_version.txt' elif int(self.current_version['version'].split('.')[1]) % 2 != 0: - download_url = 'http://www.openlp.org/files/dev_version.txt' + download_url = 'https://www.openlp.org/files/dev_version.txt' headers = { 'User-Agent': 'OpenLP/{version} {system}/{release}; '.format(version=self.current_version['full'], system=platform.system(), @@ -91,7 +89,7 @@ class VersionWorker(ThreadWorker): while retries < 3: try: response = requests.get(download_url, headers=headers) - remote_version = response.text + remote_version = response.text.strip() log.debug('New version found: %s', remote_version) break except OSError: diff --git a/openlp/core/widgets/__init__.py b/openlp/core/widgets/__init__.py index ea62548f4..711ded4ae 100644 --- a/openlp/core/widgets/__init__.py +++ b/openlp/core/widgets/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/widgets/buttons.py b/openlp/core/widgets/buttons.py index 6eef707b2..d69c365cd 100644 --- a/openlp/core/widgets/buttons.py +++ b/openlp/core/widgets/buttons.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/widgets/dialogs.py b/openlp/core/widgets/dialogs.py index f1c2bcc24..ee46b5992 100755 --- a/openlp/core/widgets/dialogs.py +++ b/openlp/core/widgets/dialogs.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,7 +22,7 @@ """ Patch the QFileDialog so it accepts and returns Path objects""" from PyQt5 import QtWidgets -from openlp.core.common.path import Path, path_to_str, replace_params, str_to_path +from openlp.core.common.path import path_to_str, replace_params, str_to_path class FileDialog(QtWidgets.QFileDialog): diff --git a/openlp/core/widgets/docks.py b/openlp/core/widgets/docks.py index a1b4e9789..6fac23705 100644 --- a/openlp/core/widgets/docks.py +++ b/openlp/core/widgets/docks.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/widgets/edits.py b/openlp/core/widgets/edits.py index 89310a713..48fc5f853 100644 --- a/openlp/core/widgets/edits.py +++ b/openlp/core/widgets/edits.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/widgets/enums.py b/openlp/core/widgets/enums.py index f79dd775c..630505afa 100644 --- a/openlp/core/widgets/enums.py +++ b/openlp/core/widgets/enums.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/widgets/toolbar.py b/openlp/core/widgets/toolbar.py index 8c76ce50e..758a62605 100644 --- a/openlp/core/widgets/toolbar.py +++ b/openlp/core/widgets/toolbar.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/core/widgets/views.py b/openlp/core/widgets/views.py index 219dd145f..5adec3e27 100644 --- a/openlp/core/widgets/views.py +++ b/openlp/core/widgets/views.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,18 +23,36 @@ The :mod:`listpreviewwidget` is a widget that lists the slides in the slide controller. It is based on a QTableWidget but represents its contents in list form. """ -import os - from PyQt5 import QtCore, QtGui, QtWidgets from openlp.core.common import is_win from openlp.core.common.i18n import UiStrings from openlp.core.common.mixins import RegistryProperties +from openlp.core.common.path import Path from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings from openlp.core.lib import ImageSource, ItemCapabilities, ServiceItem +def handle_mime_data_urls(mime_data): + """ + Process the data from a drag and drop operation. + + :param PyQt5.QtCore.QMimeData mime_data: The mime data from the drag and drop opperation. + :return: A list of file paths that were dropped + :rtype: list[openlp.core.common.path.Path] + """ + file_paths = [] + for url in mime_data.urls(): + local_path = Path(url.toLocalFile()) + if local_path.is_file(): + file_paths.append(local_path) + elif local_path.is_dir(): + for path in local_path.iterdir(): + file_paths.append(path) + return file_paths + + class ListPreviewWidget(QtWidgets.QTableWidget, RegistryProperties): """ A special type of QTableWidget which lists the slides in the slide controller @@ -326,17 +344,9 @@ class ListWidgetWithDnD(QtWidgets.QListWidget): if event.mimeData().hasUrls(): event.setDropAction(QtCore.Qt.CopyAction) event.accept() - files = [] - for url in event.mimeData().urls(): - local_file = os.path.normpath(url.toLocalFile()) - if os.path.isfile(local_file): - files.append(local_file) - elif os.path.isdir(local_file): - listing = os.listdir(local_file) - for file in listing: - files.append(os.path.join(local_file, file)) + file_paths = handle_mime_data_urls(event.mimeData()) Registry().execute('{mime_data}_dnd'.format(mime_data=self.mime_data_text), - {'files': files}) + {'file_paths': file_paths}) else: event.ignore() @@ -454,16 +464,9 @@ class TreeWidgetWithDnD(QtWidgets.QTreeWidget): if event.mimeData().hasUrls(): event.setDropAction(QtCore.Qt.CopyAction) event.accept() - files = [] - for url in event.mimeData().urls(): - local_file = url.toLocalFile() - if os.path.isfile(local_file): - files.append(local_file) - elif os.path.isdir(local_file): - listing = os.listdir(local_file) - for file_name in listing: - files.append(os.path.join(local_file, file_name)) - Registry().execute('%s_dnd' % self.mime_data_text, {'files': files, 'target': self.itemAt(event.pos())}) + file_paths = handle_mime_data_urls(event.mimeData()) + Registry().execute('%s_dnd' % self.mime_data_text, + {'file_paths': file_paths, 'target': self.itemAt(event.pos())}) elif self.allow_internal_dnd: event.setDropAction(QtCore.Qt.CopyAction) event.accept() diff --git a/openlp/core/widgets/wizard.py b/openlp/core/widgets/wizard.py index dc8288bc9..32db6c1ff 100644 --- a/openlp/core/widgets/wizard.py +++ b/openlp/core/widgets/wizard.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/__init__.py b/openlp/plugins/__init__.py index a4aa03078..3b728280b 100644 --- a/openlp/plugins/__init__.py +++ b/openlp/plugins/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/alerts/__init__.py b/openlp/plugins/alerts/__init__.py index 4b28c04f7..a40745253 100644 --- a/openlp/plugins/alerts/__init__.py +++ b/openlp/plugins/alerts/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/alerts/alertsplugin.py b/openlp/plugins/alerts/alertsplugin.py index 992c5c360..429e8dc37 100644 --- a/openlp/plugins/alerts/alertsplugin.py +++ b/openlp/plugins/alerts/alertsplugin.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/alerts/endpoint.py b/openlp/plugins/alerts/endpoint.py index 19449b863..e4b9a64bd 100644 --- a/openlp/plugins/alerts/endpoint.py +++ b/openlp/plugins/alerts/endpoint.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -19,17 +19,16 @@ # with this program; if not, write to the Free Software Foundation, Inc., 59 # # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### -import logging import json +import logging import urllib from urllib.parse import urlparse -from openlp.core.api.http.endpoint import Endpoint from openlp.core.api.http import requires_auth +from openlp.core.api.http.endpoint import Endpoint from openlp.core.common.registry import Registry from openlp.core.lib import PluginStatus - log = logging.getLogger(__name__) alerts_endpoint = Endpoint('alert') diff --git a/openlp/plugins/alerts/forms/__init__.py b/openlp/plugins/alerts/forms/__init__.py index e390edf32..ff297ae8f 100644 --- a/openlp/plugins/alerts/forms/__init__.py +++ b/openlp/plugins/alerts/forms/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/alerts/forms/alertdialog.py b/openlp/plugins/alerts/forms/alertdialog.py index 79dff94c0..5c2ddb920 100644 --- a/openlp/plugins/alerts/forms/alertdialog.py +++ b/openlp/plugins/alerts/forms/alertdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/alerts/forms/alertform.py b/openlp/plugins/alerts/forms/alertform.py index c7f9487c4..481853fa9 100644 --- a/openlp/plugins/alerts/forms/alertform.py +++ b/openlp/plugins/alerts/forms/alertform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,7 +25,6 @@ from PyQt5 import QtCore, QtWidgets from openlp.core.common.i18n import translate from openlp.core.common.registry import Registry from openlp.plugins.alerts.lib.db import AlertItem - from .alertdialog import Ui_AlertDialog diff --git a/openlp/plugins/alerts/lib/__init__.py b/openlp/plugins/alerts/lib/__init__.py index 6add50bd2..4aae58891 100644 --- a/openlp/plugins/alerts/lib/__init__.py +++ b/openlp/plugins/alerts/lib/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/alerts/lib/alertsmanager.py b/openlp/plugins/alerts/lib/alertsmanager.py index e5ae93093..4d843c5c7 100644 --- a/openlp/plugins/alerts/lib/alertsmanager.py +++ b/openlp/plugins/alerts/lib/alertsmanager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/alerts/lib/alertstab.py b/openlp/plugins/alerts/lib/alertstab.py index 51d92cf06..b93f74db4 100644 --- a/openlp/plugins/alerts/lib/alertstab.py +++ b/openlp/plugins/alerts/lib/alertstab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/alerts/lib/db.py b/openlp/plugins/alerts/lib/db.py index ab33f43ee..f0a0afb97 100644 --- a/openlp/plugins/alerts/lib/db.py +++ b/openlp/plugins/alerts/lib/db.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/bibles/__init__.py b/openlp/plugins/bibles/__init__.py index 64fae038b..86b09cd15 100644 --- a/openlp/plugins/bibles/__init__.py +++ b/openlp/plugins/bibles/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/bibles/bibleplugin.py b/openlp/plugins/bibles/bibleplugin.py index 7d5baf859..aecdadfdb 100644 --- a/openlp/plugins/bibles/bibleplugin.py +++ b/openlp/plugins/bibles/bibleplugin.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,11 +23,11 @@ import logging from openlp.core.api.http import register_endpoint -from openlp.core.common.i18n import UiStrings, translate from openlp.core.common.actions import ActionList +from openlp.core.common.i18n import UiStrings, translate from openlp.core.lib import Plugin, StringContent, build_icon -from openlp.plugins.bibles.endpoint import api_bibles_endpoint, bibles_endpoint from openlp.core.lib.ui import create_action +from openlp.plugins.bibles.endpoint import api_bibles_endpoint, bibles_endpoint from openlp.plugins.bibles.lib import BibleManager, BiblesTab, BibleMediaItem, LayoutStyle, DisplayStyle, \ LanguageSelection from openlp.plugins.bibles.lib.mediaitem import BibleSearch diff --git a/openlp/plugins/bibles/endpoint.py b/openlp/plugins/bibles/endpoint.py index 4d34eb966..b3177b146 100644 --- a/openlp/plugins/bibles/endpoint.py +++ b/openlp/plugins/bibles/endpoint.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,11 +21,10 @@ ############################################################################### import logging -from openlp.core.api.http.endpoint import Endpoint -from openlp.core.api.http.errors import NotFound from openlp.core.api.endpoint.pluginhelpers import search, live, service from openlp.core.api.http import requires_auth - +from openlp.core.api.http.endpoint import Endpoint +from openlp.core.api.http.errors import NotFound log = logging.getLogger(__name__) diff --git a/openlp/plugins/bibles/forms/__init__.py b/openlp/plugins/bibles/forms/__init__.py index 1b0055d67..34cdce3cd 100644 --- a/openlp/plugins/bibles/forms/__init__.py +++ b/openlp/plugins/bibles/forms/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -24,9 +24,9 @@ The :mod:`forms` module contains all the ui functionality for the bibles plugin. """ -from .booknameform import BookNameForm -from .languageform import LanguageForm from .bibleimportform import BibleImportForm +from .booknameform import BookNameForm from .editbibleform import EditBibleForm +from .languageform import LanguageForm __all__ = ['BookNameForm', 'LanguageForm', 'BibleImportForm', 'EditBibleForm'] diff --git a/openlp/plugins/bibles/forms/bibleimportform.py b/openlp/plugins/bibles/forms/bibleimportform.py index 857c48f74..d32711b62 100644 --- a/openlp/plugins/bibles/forms/bibleimportform.py +++ b/openlp/plugins/bibles/forms/bibleimportform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -24,9 +24,10 @@ The bible import functions for OpenLP """ import logging import urllib.error -from lxml import etree from PyQt5 import QtWidgets +from lxml import etree + try: from pysword import modules PYSWORD_AVAILABLE = True diff --git a/openlp/plugins/bibles/forms/booknamedialog.py b/openlp/plugins/bibles/forms/booknamedialog.py index 07d749755..05beaff19 100644 --- a/openlp/plugins/bibles/forms/booknamedialog.py +++ b/openlp/plugins/bibles/forms/booknamedialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/bibles/forms/booknameform.py b/openlp/plugins/bibles/forms/booknameform.py index 7c8a2c3cd..b8a3aac20 100644 --- a/openlp/plugins/bibles/forms/booknameform.py +++ b/openlp/plugins/bibles/forms/booknameform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -26,8 +26,8 @@ Module implementing BookNameForm. import logging import re -from PyQt5.QtWidgets import QDialog from PyQt5 import QtCore +from PyQt5.QtWidgets import QDialog from openlp.core.common.i18n import translate from openlp.core.lib.ui import critical_error_message_box diff --git a/openlp/plugins/bibles/forms/editbibledialog.py b/openlp/plugins/bibles/forms/editbibledialog.py index 799c2af7c..f57239da6 100644 --- a/openlp/plugins/bibles/forms/editbibledialog.py +++ b/openlp/plugins/bibles/forms/editbibledialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/bibles/forms/editbibleform.py b/openlp/plugins/bibles/forms/editbibleform.py index 8899087ba..bc89827d2 100644 --- a/openlp/plugins/bibles/forms/editbibleform.py +++ b/openlp/plugins/bibles/forms/editbibleform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -28,9 +28,9 @@ from PyQt5 import QtCore, QtWidgets from openlp.core.common.i18n import UiStrings, translate from openlp.core.common.mixins import RegistryProperties from openlp.core.lib.ui import critical_error_message_box -from .editbibledialog import Ui_EditBibleDialog from openlp.plugins.bibles.lib import BibleStrings from openlp.plugins.bibles.lib.db import BiblesResourcesDB +from .editbibledialog import Ui_EditBibleDialog log = logging.getLogger(__name__) diff --git a/openlp/plugins/bibles/forms/languagedialog.py b/openlp/plugins/bibles/forms/languagedialog.py index fad18bf05..0af3a0393 100644 --- a/openlp/plugins/bibles/forms/languagedialog.py +++ b/openlp/plugins/bibles/forms/languagedialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/bibles/forms/languageform.py b/openlp/plugins/bibles/forms/languageform.py index 80ce9e989..3f9f28780 100644 --- a/openlp/plugins/bibles/forms/languageform.py +++ b/openlp/plugins/bibles/forms/languageform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,14 +25,13 @@ Module implementing LanguageForm. """ import logging -from PyQt5.QtWidgets import QDialog from PyQt5 import QtCore +from PyQt5.QtWidgets import QDialog from openlp.core.common.i18n import LANGUAGES, translate from openlp.core.lib.ui import critical_error_message_box from openlp.plugins.bibles.forms.languagedialog import Ui_LanguageDialog - log = logging.getLogger(__name__) diff --git a/openlp/plugins/bibles/lib/__init__.py b/openlp/plugins/bibles/lib/__init__.py index f9d93a43e..73c1ca68d 100644 --- a/openlp/plugins/bibles/lib/__init__.py +++ b/openlp/plugins/bibles/lib/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,7 +29,6 @@ import re from openlp.core.common.i18n import translate from openlp.core.common.settings import Settings - log = logging.getLogger(__name__) diff --git a/openlp/plugins/bibles/lib/bibleimport.py b/openlp/plugins/bibles/lib/bibleimport.py index 7efb46f5d..4804362c6 100644 --- a/openlp/plugins/bibles/lib/bibleimport.py +++ b/openlp/plugins/bibles/lib/bibleimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -20,12 +20,13 @@ # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### -from lxml import etree, objectify from zipfile import is_zipfile +from lxml import etree, objectify + +from openlp.core.common.i18n import get_language, translate from openlp.core.common.mixins import LogMixin, RegistryProperties from openlp.core.common.registry import Registry -from openlp.core.common.i18n import get_language, translate from openlp.core.lib import ValidationError from openlp.core.lib.ui import critical_error_message_box from openlp.plugins.bibles.lib.db import AlternativeBookNamesDB, BibleDB, BiblesResourcesDB diff --git a/openlp/plugins/bibles/lib/biblestab.py b/openlp/plugins/bibles/lib/biblestab.py index c5e67840a..c98ff2943 100644 --- a/openlp/plugins/bibles/lib/biblestab.py +++ b/openlp/plugins/bibles/lib/biblestab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/bibles/lib/db.py b/openlp/plugins/bibles/lib/db.py index 13aeadfae..040115d56 100644 --- a/openlp/plugins/bibles/lib/db.py +++ b/openlp/plugins/bibles/lib/db.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -19,9 +19,9 @@ # with this program; if not, write to the Free Software Foundation, Inc., 59 # # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### + import chardet import logging -import os import re import sqlite3 import time diff --git a/openlp/plugins/bibles/lib/importers/__init__.py b/openlp/plugins/bibles/lib/importers/__init__.py index f83bbd595..ffd057b71 100644 --- a/openlp/plugins/bibles/lib/importers/__init__.py +++ b/openlp/plugins/bibles/lib/importers/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/bibles/lib/importers/csvbible.py b/openlp/plugins/bibles/lib/importers/csvbible.py index 46124fd5e..29d22ff7d 100644 --- a/openlp/plugins/bibles/lib/importers/csvbible.py +++ b/openlp/plugins/bibles/lib/importers/csvbible.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/bibles/lib/importers/http.py b/openlp/plugins/bibles/lib/importers/http.py index b88dbe7a9..4eee26256 100644 --- a/openlp/plugins/bibles/lib/importers/http.py +++ b/openlp/plugins/bibles/lib/importers/http.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,8 +25,8 @@ The :mod:`http` module enables OpenLP to retrieve scripture from bible websites. import logging import re import socket -import urllib.parse import urllib.error +import urllib.parse from bs4 import BeautifulSoup, NavigableString, Tag diff --git a/openlp/plugins/bibles/lib/importers/opensong.py b/openlp/plugins/bibles/lib/importers/opensong.py index 8400c9bf7..215ea76c5 100644 --- a/openlp/plugins/bibles/lib/importers/opensong.py +++ b/openlp/plugins/bibles/lib/importers/opensong.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/bibles/lib/importers/osis.py b/openlp/plugins/bibles/lib/importers/osis.py index cde57954a..b18a1bea3 100644 --- a/openlp/plugins/bibles/lib/importers/osis.py +++ b/openlp/plugins/bibles/lib/importers/osis.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/bibles/lib/importers/sword.py b/openlp/plugins/bibles/lib/importers/sword.py index dcb392754..08ffaaccc 100644 --- a/openlp/plugins/bibles/lib/importers/sword.py +++ b/openlp/plugins/bibles/lib/importers/sword.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,6 +21,7 @@ ############################################################################### import logging + from pysword import modules from openlp.core.common.i18n import translate @@ -28,7 +29,6 @@ from openlp.core.lib.ui import critical_error_message_box from openlp.plugins.bibles.lib.bibleimport import BibleImport from openlp.plugins.bibles.lib.db import BiblesResourcesDB - log = logging.getLogger(__name__) diff --git a/openlp/plugins/bibles/lib/importers/wordproject.py b/openlp/plugins/bibles/lib/importers/wordproject.py index 90d23a2b5..95a957c80 100644 --- a/openlp/plugins/bibles/lib/importers/wordproject.py +++ b/openlp/plugins/bibles/lib/importers/wordproject.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/bibles/lib/importers/zefania.py b/openlp/plugins/bibles/lib/importers/zefania.py index 2b5eb68b8..e8904d56c 100644 --- a/openlp/plugins/bibles/lib/importers/zefania.py +++ b/openlp/plugins/bibles/lib/importers/zefania.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,7 +27,6 @@ from openlp.core.lib.ui import critical_error_message_box from openlp.plugins.bibles.lib.bibleimport import BibleImport from openlp.plugins.bibles.lib.db import BiblesResourcesDB - log = logging.getLogger(__name__) # Tags we don't use and can remove the content diff --git a/openlp/plugins/bibles/lib/manager.py b/openlp/plugins/bibles/lib/manager.py index 37586b4be..1e1b4243d 100644 --- a/openlp/plugins/bibles/lib/manager.py +++ b/openlp/plugins/bibles/lib/manager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -33,8 +33,9 @@ from .importers.csvbible import CSVBible from .importers.http import HTTPBible from .importers.opensong import OpenSongBible from .importers.osis import OSISBible -from .importers.zefania import ZefaniaBible from .importers.wordproject import WordProjectBible +from .importers.zefania import ZefaniaBible + try: from .importers.sword import SwordBible except: diff --git a/openlp/plugins/bibles/lib/mediaitem.py b/openlp/plugins/bibles/lib/mediaitem.py index fdfc4b51d..dc5792dac 100755 --- a/openlp/plugins/bibles/lib/mediaitem.py +++ b/openlp/plugins/bibles/lib/mediaitem.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/bibles/lib/upgrade.py b/openlp/plugins/bibles/lib/upgrade.py index 24f613b2d..c53f9d324 100644 --- a/openlp/plugins/bibles/lib/upgrade.py +++ b/openlp/plugins/bibles/lib/upgrade.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/bibles/lib/versereferencelist.py b/openlp/plugins/bibles/lib/versereferencelist.py index d41eeadf1..c6a9e7ec2 100644 --- a/openlp/plugins/bibles/lib/versereferencelist.py +++ b/openlp/plugins/bibles/lib/versereferencelist.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/custom/__init__.py b/openlp/plugins/custom/__init__.py index a3cf0b4c1..b0dc776c2 100644 --- a/openlp/plugins/custom/__init__.py +++ b/openlp/plugins/custom/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/custom/customplugin.py b/openlp/plugins/custom/customplugin.py index 8cb02ab17..77022b5f1 100644 --- a/openlp/plugins/custom/customplugin.py +++ b/openlp/plugins/custom/customplugin.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/custom/endpoint.py b/openlp/plugins/custom/endpoint.py index ca5c39088..eb07683c8 100644 --- a/openlp/plugins/custom/endpoint.py +++ b/openlp/plugins/custom/endpoint.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,11 +21,10 @@ ############################################################################### import logging -from openlp.core.api.http.endpoint import Endpoint -from openlp.core.api.http.errors import NotFound from openlp.core.api.endpoint.pluginhelpers import search, live, service from openlp.core.api.http import requires_auth - +from openlp.core.api.http.endpoint import Endpoint +from openlp.core.api.http.errors import NotFound log = logging.getLogger(__name__) diff --git a/openlp/plugins/custom/forms/__init__.py b/openlp/plugins/custom/forms/__init__.py index ea62548f4..711ded4ae 100644 --- a/openlp/plugins/custom/forms/__init__.py +++ b/openlp/plugins/custom/forms/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/custom/forms/editcustomdialog.py b/openlp/plugins/custom/forms/editcustomdialog.py index e0f5646d3..79771e4b2 100644 --- a/openlp/plugins/custom/forms/editcustomdialog.py +++ b/openlp/plugins/custom/forms/editcustomdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/custom/forms/editcustomform.py b/openlp/plugins/custom/forms/editcustomform.py index ee2d7b415..0ab518960 100644 --- a/openlp/plugins/custom/forms/editcustomform.py +++ b/openlp/plugins/custom/forms/editcustomform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/custom/forms/editcustomslidedialog.py b/openlp/plugins/custom/forms/editcustomslidedialog.py index 5ccc94cc6..9d7e50411 100644 --- a/openlp/plugins/custom/forms/editcustomslidedialog.py +++ b/openlp/plugins/custom/forms/editcustomslidedialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/custom/forms/editcustomslideform.py b/openlp/plugins/custom/forms/editcustomslideform.py index 77f086dbb..4619abb82 100644 --- a/openlp/plugins/custom/forms/editcustomslideform.py +++ b/openlp/plugins/custom/forms/editcustomslideform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/custom/lib/__init__.py b/openlp/plugins/custom/lib/__init__.py index 6ecd423b3..da3fe3e02 100644 --- a/openlp/plugins/custom/lib/__init__.py +++ b/openlp/plugins/custom/lib/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -20,6 +20,6 @@ # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### +from .customtab import CustomTab from .customxmlhandler import CustomXMLBuilder, CustomXMLParser from .mediaitem import CustomMediaItem -from .customtab import CustomTab diff --git a/openlp/plugins/custom/lib/customtab.py b/openlp/plugins/custom/lib/customtab.py index 2239ac2ce..40a36f6c7 100644 --- a/openlp/plugins/custom/lib/customtab.py +++ b/openlp/plugins/custom/lib/customtab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/custom/lib/customxmlhandler.py b/openlp/plugins/custom/lib/customxmlhandler.py index a205b1d6a..399d31def 100644 --- a/openlp/plugins/custom/lib/customxmlhandler.py +++ b/openlp/plugins/custom/lib/customxmlhandler.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -36,9 +36,9 @@ The basic XML is of the format:: """ import logging - from xml.dom.minidom import Document from xml.etree.ElementTree import dump + from lxml import etree, objectify log = logging.getLogger(__name__) diff --git a/openlp/plugins/custom/lib/db.py b/openlp/plugins/custom/lib/db.py index 6581ee5ae..ab8daf554 100644 --- a/openlp/plugins/custom/lib/db.py +++ b/openlp/plugins/custom/lib/db.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/custom/lib/mediaitem.py b/openlp/plugins/custom/lib/mediaitem.py index 35eddc117..d4e7f8cfd 100644 --- a/openlp/plugins/custom/lib/mediaitem.py +++ b/openlp/plugins/custom/lib/mediaitem.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/images/__init__.py b/openlp/plugins/images/__init__.py index cf47999d2..d07ab9f04 100644 --- a/openlp/plugins/images/__init__.py +++ b/openlp/plugins/images/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/images/endpoint.py b/openlp/plugins/images/endpoint.py index 05c1e64b4..710cc07a8 100644 --- a/openlp/plugins/images/endpoint.py +++ b/openlp/plugins/images/endpoint.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,11 +21,10 @@ ############################################################################### import logging -from openlp.core.api.http.endpoint import Endpoint -from openlp.core.api.http.errors import NotFound from openlp.core.api.endpoint.pluginhelpers import search, live, service, display_thumbnails from openlp.core.api.http import requires_auth - +from openlp.core.api.http.endpoint import Endpoint +from openlp.core.api.http.errors import NotFound log = logging.getLogger(__name__) diff --git a/openlp/plugins/images/forms/__init__.py b/openlp/plugins/images/forms/__init__.py index babff4678..f7a6b947b 100644 --- a/openlp/plugins/images/forms/__init__.py +++ b/openlp/plugins/images/forms/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/images/forms/addgroupdialog.py b/openlp/plugins/images/forms/addgroupdialog.py index 665fcd824..bd11df702 100644 --- a/openlp/plugins/images/forms/addgroupdialog.py +++ b/openlp/plugins/images/forms/addgroupdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/images/forms/addgroupform.py b/openlp/plugins/images/forms/addgroupform.py index 88f9377f3..bcfa1ad21 100644 --- a/openlp/plugins/images/forms/addgroupform.py +++ b/openlp/plugins/images/forms/addgroupform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/images/forms/choosegroupdialog.py b/openlp/plugins/images/forms/choosegroupdialog.py index 35e959fb5..49e3f5f5b 100644 --- a/openlp/plugins/images/forms/choosegroupdialog.py +++ b/openlp/plugins/images/forms/choosegroupdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/images/forms/choosegroupform.py b/openlp/plugins/images/forms/choosegroupform.py index 5867481b9..2f61bf6db 100644 --- a/openlp/plugins/images/forms/choosegroupform.py +++ b/openlp/plugins/images/forms/choosegroupform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/images/imageplugin.py b/openlp/plugins/images/imageplugin.py index cfa5448f5..d814ec47b 100644 --- a/openlp/plugins/images/imageplugin.py +++ b/openlp/plugins/images/imageplugin.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -20,10 +20,10 @@ # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### -from PyQt5 import QtGui - import logging +from PyQt5 import QtGui + from openlp.core.api.http import register_endpoint from openlp.core.common.i18n import translate from openlp.core.common.settings import Settings diff --git a/openlp/plugins/images/lib/__init__.py b/openlp/plugins/images/lib/__init__.py index aa49ec62e..668d437ce 100644 --- a/openlp/plugins/images/lib/__init__.py +++ b/openlp/plugins/images/lib/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -20,5 +20,5 @@ # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### -from .mediaitem import ImageMediaItem from .imagetab import ImageTab +from .mediaitem import ImageMediaItem diff --git a/openlp/plugins/images/lib/db.py b/openlp/plugins/images/lib/db.py index be7c299b3..6e4656d0e 100644 --- a/openlp/plugins/images/lib/db.py +++ b/openlp/plugins/images/lib/db.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/images/lib/imagetab.py b/openlp/plugins/images/lib/imagetab.py index e2b64a6cc..3f559bb0d 100644 --- a/openlp/plugins/images/lib/imagetab.py +++ b/openlp/plugins/images/lib/imagetab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/images/lib/mediaitem.py b/openlp/plugins/images/lib/mediaitem.py index 25a8d2353..fa1dc6b91 100644 --- a/openlp/plugins/images/lib/mediaitem.py +++ b/openlp/plugins/images/lib/mediaitem.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -37,7 +37,6 @@ from openlp.core.widgets.views import TreeWidgetWithDnD from openlp.plugins.images.forms import AddGroupForm, ChooseGroupForm from openlp.plugins.images.lib.db import ImageFilenames, ImageGroups - log = logging.getLogger(__name__) diff --git a/openlp/plugins/images/lib/upgrade.py b/openlp/plugins/images/lib/upgrade.py index bc1310d79..b2452db89 100644 --- a/openlp/plugins/images/lib/upgrade.py +++ b/openlp/plugins/images/lib/upgrade.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/media/__init__.py b/openlp/plugins/media/__init__.py index 6d87bbe3b..dbc14f050 100644 --- a/openlp/plugins/media/__init__.py +++ b/openlp/plugins/media/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/media/endpoint.py b/openlp/plugins/media/endpoint.py index c7b703358..443401b7a 100644 --- a/openlp/plugins/media/endpoint.py +++ b/openlp/plugins/media/endpoint.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,11 +21,10 @@ ############################################################################### import logging -from openlp.core.api.http.endpoint import Endpoint -from openlp.core.api.http.errors import NotFound from openlp.core.api.endpoint.pluginhelpers import search, live, service from openlp.core.api.http import requires_auth - +from openlp.core.api.http.endpoint import Endpoint +from openlp.core.api.http.errors import NotFound log = logging.getLogger(__name__) diff --git a/openlp/plugins/media/forms/__init__.py b/openlp/plugins/media/forms/__init__.py index ea62548f4..711ded4ae 100644 --- a/openlp/plugins/media/forms/__init__.py +++ b/openlp/plugins/media/forms/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/media/forms/mediaclipselectordialog.py b/openlp/plugins/media/forms/mediaclipselectordialog.py index 38ecda99c..22f239cf5 100644 --- a/openlp/plugins/media/forms/mediaclipselectordialog.py +++ b/openlp/plugins/media/forms/mediaclipselectordialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/media/forms/mediaclipselectorform.py b/openlp/plugins/media/forms/mediaclipselectorform.py index be9e69fbd..7c0db8db7 100644 --- a/openlp/plugins/media/forms/mediaclipselectorform.py +++ b/openlp/plugins/media/forms/mediaclipselectorform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -19,21 +19,21 @@ # with this program; if not, write to the Free Software Foundation, Inc., 59 # # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### -import os import logging +import os import re -from time import sleep from datetime import datetime +from time import sleep from PyQt5 import QtCore, QtGui, QtWidgets from openlp.core.common import is_win, is_linux, is_macosx -from openlp.core.common.path import Path from openlp.core.common.i18n import translate from openlp.core.common.mixins import RegistryProperties -from openlp.plugins.media.forms.mediaclipselectordialog import Ui_MediaClipSelector +from openlp.core.common.path import Path from openlp.core.lib.ui import critical_error_message_box from openlp.core.ui.media.vlcplayer import get_vlc +from openlp.plugins.media.forms.mediaclipselectordialog import Ui_MediaClipSelector if is_win(): from win32com.client import Dispatch diff --git a/openlp/plugins/media/lib/__init__.py b/openlp/plugins/media/lib/__init__.py index 4b5b36f57..c6c0f31ae 100644 --- a/openlp/plugins/media/lib/__init__.py +++ b/openlp/plugins/media/lib/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/media/lib/mediaitem.py b/openlp/plugins/media/lib/mediaitem.py index 1c7556aa9..0ed7643bc 100644 --- a/openlp/plugins/media/lib/mediaitem.py +++ b/openlp/plugins/media/lib/mediaitem.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,8 +27,8 @@ from PyQt5 import QtCore, QtWidgets from openlp.core.common.applocation import AppLocation from openlp.core.common.i18n import UiStrings, translate, get_natural_key -from openlp.core.common.path import Path, path_to_str, create_paths from openlp.core.common.mixins import RegistryProperties +from openlp.core.common.path import Path, path_to_str, create_paths from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings from openlp.core.lib import ItemCapabilities, MediaManagerItem, MediaType, ServiceItem, ServiceItemContext, \ @@ -302,7 +302,7 @@ class MediaMediaItem(MediaManagerItem, RegistryProperties): Initialize media item. """ self.list_view.clear() - self.service_path = os.path.join(str(AppLocation.get_section_data_path(self.settings_section)), 'thumbnails') + self.service_path = str(AppLocation.get_section_data_path(self.settings_section) / 'thumbnails') create_paths(Path(self.service_path)) self.load_list([path_to_str(file) for file in Settings().value(self.settings_section + '/media files')]) self.rebuild_players() diff --git a/openlp/plugins/media/lib/mediatab.py b/openlp/plugins/media/lib/mediatab.py index 84c339a27..9842be5b6 100644 --- a/openlp/plugins/media/lib/mediatab.py +++ b/openlp/plugins/media/lib/mediatab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/media/mediaplugin.py b/openlp/plugins/media/mediaplugin.py index 461e78746..3800f3978 100644 --- a/openlp/plugins/media/mediaplugin.py +++ b/openlp/plugins/media/mediaplugin.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,7 +23,6 @@ The Media plugin """ import logging -import os import re from PyQt5 import QtCore @@ -37,7 +36,6 @@ from openlp.core.lib import Plugin, StringContent, build_icon from openlp.plugins.media.endpoint import api_media_endpoint, media_endpoint from openlp.plugins.media.lib import MediaMediaItem, MediaTab - log = logging.getLogger(__name__) diff --git a/openlp/plugins/presentations/__init__.py b/openlp/plugins/presentations/__init__.py index 5de863e21..07940b983 100644 --- a/openlp/plugins/presentations/__init__.py +++ b/openlp/plugins/presentations/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/presentations/endpoint.py b/openlp/plugins/presentations/endpoint.py index 99c828b4b..b5839283b 100644 --- a/openlp/plugins/presentations/endpoint.py +++ b/openlp/plugins/presentations/endpoint.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,11 +21,10 @@ ############################################################################### import logging -from openlp.core.api.http.endpoint import Endpoint -from openlp.core.api.http.errors import NotFound from openlp.core.api.endpoint.pluginhelpers import search, live, service, display_thumbnails from openlp.core.api.http import requires_auth - +from openlp.core.api.http.endpoint import Endpoint +from openlp.core.api.http.errors import NotFound log = logging.getLogger(__name__) diff --git a/openlp/plugins/presentations/lib/__init__.py b/openlp/plugins/presentations/lib/__init__.py index 40565539c..8cc7c1942 100644 --- a/openlp/plugins/presentations/lib/__init__.py +++ b/openlp/plugins/presentations/lib/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/presentations/lib/impresscontroller.py b/openlp/plugins/presentations/lib/impresscontroller.py index befa93601..6bd05e2b1 100644 --- a/openlp/plugins/presentations/lib/impresscontroller.py +++ b/openlp/plugins/presentations/lib/impresscontroller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/presentations/lib/mediaitem.py b/openlp/plugins/presentations/lib/mediaitem.py index 923953040..c0915378f 100644 --- a/openlp/plugins/presentations/lib/mediaitem.py +++ b/openlp/plugins/presentations/lib/mediaitem.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -24,10 +24,10 @@ import logging from PyQt5 import QtCore, QtGui, QtWidgets from openlp.core.common.i18n import UiStrings, translate, get_natural_key -from openlp.core.common.path import Path, path_to_str, str_to_path +from openlp.core.common.path import path_to_str, str_to_path from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings -from openlp.core.lib import MediaManagerItem, ItemCapabilities, ServiceItemContext,\ +from openlp.core.lib import MediaManagerItem, ItemCapabilities, ServiceItemContext, \ build_icon, check_item_selected, create_thumb, validate_thumb from openlp.core.lib.ui import critical_error_message_box, create_horizontal_adjusting_combo_box from openlp.plugins.presentations.lib import MessageListener diff --git a/openlp/plugins/presentations/lib/messagelistener.py b/openlp/plugins/presentations/lib/messagelistener.py index 33f5e0693..361c77ae9 100644 --- a/openlp/plugins/presentations/lib/messagelistener.py +++ b/openlp/plugins/presentations/lib/messagelistener.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -24,9 +24,9 @@ import logging from PyQt5 import QtCore +from openlp.core.common.path import Path from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings -from openlp.core.common.path import Path from openlp.core.lib import ServiceItemContext from openlp.core.ui import HideMode from openlp.plugins.presentations.lib.pdfcontroller import PDF_CONTROLLER_FILETYPES diff --git a/openlp/plugins/presentations/lib/pdfcontroller.py b/openlp/plugins/presentations/lib/pdfcontroller.py index 715e4e3e7..126442af3 100644 --- a/openlp/plugins/presentations/lib/pdfcontroller.py +++ b/openlp/plugins/presentations/lib/pdfcontroller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/presentations/lib/powerpointcontroller.py b/openlp/plugins/presentations/lib/powerpointcontroller.py index df46dc7d5..582afa69f 100644 --- a/openlp/plugins/presentations/lib/powerpointcontroller.py +++ b/openlp/plugins/presentations/lib/powerpointcontroller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/presentations/lib/pptviewcontroller.py b/openlp/plugins/presentations/lib/pptviewcontroller.py index ddabe07e1..18fad273a 100644 --- a/openlp/plugins/presentations/lib/pptviewcontroller.py +++ b/openlp/plugins/presentations/lib/pptviewcontroller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -20,8 +20,8 @@ # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### import logging -import zipfile import re +import zipfile from xml.etree import ElementTree from openlp.core.common import is_win diff --git a/openlp/plugins/presentations/lib/pptviewlib/README.TXT b/openlp/plugins/presentations/lib/pptviewlib/README.TXT index fe5b4669d..85bbf7954 100644 --- a/openlp/plugins/presentations/lib/pptviewlib/README.TXT +++ b/openlp/plugins/presentations/lib/pptviewlib/README.TXT @@ -1,6 +1,6 @@ PPTVIEWLIB - Control PowerPoint Viewer 2003/2007 (for openlp.org) -Copyright (C) 2008-2017 Jonathan Corwin (j@corwin.co.uk) +Copyright (C) 2008-2018 Jonathan Corwin (j@corwin.co.uk) This library wrappers the free Microsoft PowerPoint Viewer (2003/2007) program, allowing it to be more easily controlled from another program. diff --git a/openlp/plugins/presentations/lib/pptviewlib/ppttest.py b/openlp/plugins/presentations/lib/pptviewlib/ppttest.py index bea341a49..008e66164 100644 --- a/openlp/plugins/presentations/lib/pptviewlib/ppttest.py +++ b/openlp/plugins/presentations/lib/pptviewlib/ppttest.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,10 +21,11 @@ ############################################################################### import sys -from PyQt5 import QtWidgets from ctypes import * from ctypes.wintypes import RECT +from PyQt5 import QtWidgets + class PPTViewer(QtWidgets.QWidget): """ diff --git a/openlp/plugins/presentations/lib/pptviewlib/pptviewlib.cpp b/openlp/plugins/presentations/lib/pptviewlib/pptviewlib.cpp index c357303cf..8a7da02a2 100644 --- a/openlp/plugins/presentations/lib/pptviewlib/pptviewlib.cpp +++ b/openlp/plugins/presentations/lib/pptviewlib/pptviewlib.cpp @@ -1,7 +1,7 @@ /****************************************************************************** * OpenLP - Open Source Lyrics Projection * * --------------------------------------------------------------------------- * -* Copyright (c) 2008-2017 OpenLP Developers * +* Copyright (c) 2008-2018 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 * diff --git a/openlp/plugins/presentations/lib/pptviewlib/pptviewlib.h b/openlp/plugins/presentations/lib/pptviewlib/pptviewlib.h index 1854ab06a..6411ae828 100644 --- a/openlp/plugins/presentations/lib/pptviewlib/pptviewlib.h +++ b/openlp/plugins/presentations/lib/pptviewlib/pptviewlib.h @@ -1,7 +1,7 @@ /****************************************************************************** * OpenLP - Open Source Lyrics Projection * * --------------------------------------------------------------------------- * -* Copyright (c) 2008-2017 OpenLP Developers * +* Copyright (c) 2008-2018 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 * diff --git a/openlp/plugins/presentations/lib/presentationcontroller.py b/openlp/plugins/presentations/lib/presentationcontroller.py index b54d8afa9..a7b9a7d7d 100644 --- a/openlp/plugins/presentations/lib/presentationcontroller.py +++ b/openlp/plugins/presentations/lib/presentationcontroller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/presentations/lib/presentationtab.py b/openlp/plugins/presentations/lib/presentationtab.py index d6a4f5190..d2856d143 100644 --- a/openlp/plugins/presentations/lib/presentationtab.py +++ b/openlp/plugins/presentations/lib/presentationtab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/presentations/presentationplugin.py b/openlp/plugins/presentations/presentationplugin.py index c65971f11..b0fd8d7cf 100644 --- a/openlp/plugins/presentations/presentationplugin.py +++ b/openlp/plugins/presentations/presentationplugin.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,8 +23,8 @@ The :mod:`openlp.plugins.presentations.presentationplugin` module provides the ability for OpenLP to display presentations from a variety of document formats. """ -import os import logging +import os from PyQt5 import QtCore diff --git a/openlp/plugins/songs/__init__.py b/openlp/plugins/songs/__init__.py index fe3be1376..867b4703a 100644 --- a/openlp/plugins/songs/__init__.py +++ b/openlp/plugins/songs/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/endpoint.py b/openlp/plugins/songs/endpoint.py index c8af62764..c56c78826 100644 --- a/openlp/plugins/songs/endpoint.py +++ b/openlp/plugins/songs/endpoint.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,11 +21,10 @@ ############################################################################### import logging -from openlp.core.api.http.endpoint import Endpoint -from openlp.core.api.http.errors import NotFound from openlp.core.api.endpoint.pluginhelpers import search, live, service from openlp.core.api.http import requires_auth - +from openlp.core.api.http.endpoint import Endpoint +from openlp.core.api.http.errors import NotFound log = logging.getLogger(__name__) diff --git a/openlp/plugins/songs/forms/__init__.py b/openlp/plugins/songs/forms/__init__.py index 066c8780d..b95871295 100644 --- a/openlp/plugins/songs/forms/__init__.py +++ b/openlp/plugins/songs/forms/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/forms/authorsdialog.py b/openlp/plugins/songs/forms/authorsdialog.py index d4f560e9b..a65789277 100644 --- a/openlp/plugins/songs/forms/authorsdialog.py +++ b/openlp/plugins/songs/forms/authorsdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/forms/authorsform.py b/openlp/plugins/songs/forms/authorsform.py index 75ae61035..9ef42131d 100644 --- a/openlp/plugins/songs/forms/authorsform.py +++ b/openlp/plugins/songs/forms/authorsform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/forms/duplicatesongremovalform.py b/openlp/plugins/songs/forms/duplicatesongremovalform.py index 8e7724808..548d16c78 100644 --- a/openlp/plugins/songs/forms/duplicatesongremovalform.py +++ b/openlp/plugins/songs/forms/duplicatesongremovalform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -32,9 +32,9 @@ from openlp.core.common.i18n import translate from openlp.core.common.mixins import RegistryProperties from openlp.core.common.registry import Registry from openlp.core.widgets.wizard import OpenLPWizard, WizardStrings +from openlp.plugins.songs.forms.songreviewwidget import SongReviewWidget from openlp.plugins.songs.lib import delete_song from openlp.plugins.songs.lib.db import Song -from openlp.plugins.songs.forms.songreviewwidget import SongReviewWidget from openlp.plugins.songs.lib.songcompare import songs_probably_equal log = logging.getLogger(__name__) diff --git a/openlp/plugins/songs/forms/editsongdialog.py b/openlp/plugins/songs/forms/editsongdialog.py index 9cf133f06..79001d323 100644 --- a/openlp/plugins/songs/forms/editsongdialog.py +++ b/openlp/plugins/songs/forms/editsongdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/forms/editsongform.py b/openlp/plugins/songs/forms/editsongform.py index 6e0772418..36b144aef 100644 --- a/openlp/plugins/songs/forms/editsongform.py +++ b/openlp/plugins/songs/forms/editsongform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -30,8 +30,8 @@ from PyQt5 import QtCore, QtWidgets from openlp.core.common.applocation import AppLocation from openlp.core.common.i18n import UiStrings, translate, get_natural_key -from openlp.core.common.path import create_paths, copyfile from openlp.core.common.mixins import RegistryProperties +from openlp.core.common.path import create_paths, copyfile from openlp.core.common.registry import Registry from openlp.core.lib import PluginStatus, MediaType, create_separated_list from openlp.core.lib.ui import set_case_insensitive_completer, critical_error_message_box, find_and_set_in_combo_box diff --git a/openlp/plugins/songs/forms/editversedialog.py b/openlp/plugins/songs/forms/editversedialog.py index 76dc70c17..fb4f4fd68 100644 --- a/openlp/plugins/songs/forms/editversedialog.py +++ b/openlp/plugins/songs/forms/editversedialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,8 +22,8 @@ from PyQt5 import QtWidgets -from openlp.core.common.settings import Settings from openlp.core.common.i18n import UiStrings, translate +from openlp.core.common.settings import Settings from openlp.core.lib import build_icon from openlp.core.lib.ui import create_button_box from openlp.core.widgets.edits import SpellTextEdit diff --git a/openlp/plugins/songs/forms/editverseform.py b/openlp/plugins/songs/forms/editverseform.py index 09ba1e300..436c5039f 100644 --- a/openlp/plugins/songs/forms/editverseform.py +++ b/openlp/plugins/songs/forms/editverseform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -20,14 +20,14 @@ # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### -import re import logging +import re from PyQt5 import QtCore, QtGui, QtWidgets -from openlp.core.lib.ui import critical_error_message_box from openlp.core.common.i18n import translate from openlp.core.common.settings import Settings +from openlp.core.lib.ui import critical_error_message_box from openlp.plugins.songs.forms.editversedialog import Ui_EditVerseDialog from openlp.plugins.songs.lib import VerseType, transpose_lyrics diff --git a/openlp/plugins/songs/forms/mediafilesdialog.py b/openlp/plugins/songs/forms/mediafilesdialog.py index 41a6862d3..93987b82a 100644 --- a/openlp/plugins/songs/forms/mediafilesdialog.py +++ b/openlp/plugins/songs/forms/mediafilesdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/forms/mediafilesform.py b/openlp/plugins/songs/forms/mediafilesform.py index 8718471ea..29a0603cf 100644 --- a/openlp/plugins/songs/forms/mediafilesform.py +++ b/openlp/plugins/songs/forms/mediafilesform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,7 +21,6 @@ ############################################################################### import logging -import os from PyQt5 import QtCore, QtWidgets diff --git a/openlp/plugins/songs/forms/songbookdialog.py b/openlp/plugins/songs/forms/songbookdialog.py index 4a248cb48..b9c2019af 100644 --- a/openlp/plugins/songs/forms/songbookdialog.py +++ b/openlp/plugins/songs/forms/songbookdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/forms/songbookform.py b/openlp/plugins/songs/forms/songbookform.py index 594768aaf..1976d866d 100644 --- a/openlp/plugins/songs/forms/songbookform.py +++ b/openlp/plugins/songs/forms/songbookform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/forms/songexportform.py b/openlp/plugins/songs/forms/songexportform.py index c6446d74c..f67eae94b 100644 --- a/openlp/plugins/songs/forms/songexportform.py +++ b/openlp/plugins/songs/forms/songexportform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/forms/songimportform.py b/openlp/plugins/songs/forms/songimportform.py index af88bfb35..6941cbea2 100644 --- a/openlp/plugins/songs/forms/songimportform.py +++ b/openlp/plugins/songs/forms/songimportform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/forms/songmaintenancedialog.py b/openlp/plugins/songs/forms/songmaintenancedialog.py index 728861f26..a8da63723 100644 --- a/openlp/plugins/songs/forms/songmaintenancedialog.py +++ b/openlp/plugins/songs/forms/songmaintenancedialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/forms/songmaintenanceform.py b/openlp/plugins/songs/forms/songmaintenanceform.py index 7f0236d24..4bdb12a57 100644 --- a/openlp/plugins/songs/forms/songmaintenanceform.py +++ b/openlp/plugins/songs/forms/songmaintenanceform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,8 +29,8 @@ from openlp.core.common.mixins import RegistryProperties from openlp.core.common.registry import Registry from openlp.core.lib.ui import critical_error_message_box from openlp.plugins.songs.forms.authorsform import AuthorsForm -from openlp.plugins.songs.forms.topicsform import TopicsForm from openlp.plugins.songs.forms.songbookform import SongBookForm +from openlp.plugins.songs.forms.topicsform import TopicsForm from openlp.plugins.songs.lib.db import Author, Book, Topic, Song from .songmaintenancedialog import Ui_SongMaintenanceDialog diff --git a/openlp/plugins/songs/forms/songreviewwidget.py b/openlp/plugins/songs/forms/songreviewwidget.py index 960e8ebec..9d98af6e9 100644 --- a/openlp/plugins/songs/forms/songreviewwidget.py +++ b/openlp/plugins/songs/forms/songreviewwidget.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/forms/songselectdialog.py b/openlp/plugins/songs/forms/songselectdialog.py index bc0bd7415..66bb9b29f 100644 --- a/openlp/plugins/songs/forms/songselectdialog.py +++ b/openlp/plugins/songs/forms/songselectdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/forms/songselectform.py b/openlp/plugins/songs/forms/songselectform.py index cb7bf5c06..4c37bf390 100644 --- a/openlp/plugins/songs/forms/songselectform.py +++ b/openlp/plugins/songs/forms/songselectform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/forms/topicsdialog.py b/openlp/plugins/songs/forms/topicsdialog.py index fe5020941..bd80548b9 100644 --- a/openlp/plugins/songs/forms/topicsdialog.py +++ b/openlp/plugins/songs/forms/topicsdialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/forms/topicsform.py b/openlp/plugins/songs/forms/topicsform.py index 2956c7e26..101a8e705 100644 --- a/openlp/plugins/songs/forms/topicsform.py +++ b/openlp/plugins/songs/forms/topicsform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/__init__.py b/openlp/plugins/songs/lib/__init__.py index 74334ef0d..2578d0f92 100644 --- a/openlp/plugins/songs/lib/__init__.py +++ b/openlp/plugins/songs/lib/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/db.py b/openlp/plugins/songs/lib/db.py index 0963fd084..bf78d8d55 100644 --- a/openlp/plugins/songs/lib/db.py +++ b/openlp/plugins/songs/lib/db.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/importer.py b/openlp/plugins/songs/lib/importer.py index e306dae87..43628a87b 100644 --- a/openlp/plugins/songs/lib/importer.py +++ b/openlp/plugins/songs/lib/importer.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,28 +27,28 @@ import logging from openlp.core.common import is_win from openlp.core.common.i18n import UiStrings, translate from openlp.core.widgets.wizard import WizardStrings -from .importers.opensong import OpenSongImport +from .importers.cclifile import CCLIFileImport +from .importers.chordpro import ChordProImport +from .importers.dreambeam import DreamBeamImport from .importers.easyslides import EasySlidesImport +from .importers.easyworship import EasyWorshipSongImport +from .importers.foilpresenter import FoilPresenterImport +from .importers.lyrix import LyrixImport from .importers.openlp import OpenLPSongImport from .importers.openlyrics import OpenLyricsImport -from .importers.wordsofworship import WordsOfWorshipImport -from .importers.cclifile import CCLIFileImport -from .importers.dreambeam import DreamBeamImport -from .importers.powersong import PowerSongImport -from .importers.easyworship import EasyWorshipSongImport -from .importers.songbeamer import SongBeamerImport -from .importers.songshowplus import SongShowPlusImport -from .importers.songpro import SongProImport -from .importers.sundayplus import SundayPlusImport -from .importers.foilpresenter import FoilPresenterImport -from .importers.zionworx import ZionWorxImport -from .importers.propresenter import ProPresenterImport -from .importers.worshipassistant import WorshipAssistantImport +from .importers.opensong import OpenSongImport from .importers.powerpraise import PowerPraiseImport +from .importers.powersong import PowerSongImport from .importers.presentationmanager import PresentationManagerImport -from .importers.lyrix import LyrixImport +from .importers.propresenter import ProPresenterImport +from .importers.songbeamer import SongBeamerImport +from .importers.songpro import SongProImport +from .importers.songshowplus import SongShowPlusImport +from .importers.sundayplus import SundayPlusImport from .importers.videopsalm import VideoPsalmImport -from .importers.chordpro import ChordProImport +from .importers.wordsofworship import WordsOfWorshipImport +from .importers.worshipassistant import WorshipAssistantImport +from .importers.zionworx import ZionWorxImport log = logging.getLogger(__name__) diff --git a/openlp/plugins/songs/lib/importers/__init__.py b/openlp/plugins/songs/lib/importers/__init__.py index 42de076d0..d73429473 100644 --- a/openlp/plugins/songs/lib/importers/__init__.py +++ b/openlp/plugins/songs/lib/importers/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/importers/cclifile.py b/openlp/plugins/songs/lib/importers/cclifile.py index 10a8b09e1..1389918c1 100644 --- a/openlp/plugins/songs/lib/importers/cclifile.py +++ b/openlp/plugins/songs/lib/importers/cclifile.py @@ -1,10 +1,13 @@ # -*- coding: utf-8 -*- # vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4 +import codecs +import logging + ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -20,8 +23,6 @@ # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### import chardet -import codecs -import logging from openlp.core.common.i18n import translate from openlp.plugins.songs.lib import VerseType diff --git a/openlp/plugins/songs/lib/importers/dreambeam.py b/openlp/plugins/songs/lib/importers/dreambeam.py index eb2ec1ded..532bd865d 100644 --- a/openlp/plugins/songs/lib/importers/dreambeam.py +++ b/openlp/plugins/songs/lib/importers/dreambeam.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/importers/easyslides.py b/openlp/plugins/songs/lib/importers/easyslides.py index 6d717bdb4..8f847c5f3 100644 --- a/openlp/plugins/songs/lib/importers/easyslides.py +++ b/openlp/plugins/songs/lib/importers/easyslides.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/importers/easyworship.py b/openlp/plugins/songs/lib/importers/easyworship.py index 8f096099f..b2c216de2 100644 --- a/openlp/plugins/songs/lib/importers/easyworship.py +++ b/openlp/plugins/songs/lib/importers/easyworship.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,11 +25,10 @@ The :mod:`easyworship` module provides the functionality for importing EasyWorsh import logging import os import re +import sqlite3 import struct import zlib -import sqlite3 - from openlp.core.common.i18n import translate from openlp.core.common.path import Path from openlp.plugins.songs.lib import VerseType diff --git a/openlp/plugins/songs/lib/importers/foilpresenter.py b/openlp/plugins/songs/lib/importers/foilpresenter.py index f164dfda2..82601f18b 100644 --- a/openlp/plugins/songs/lib/importers/foilpresenter.py +++ b/openlp/plugins/songs/lib/importers/foilpresenter.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -90,10 +90,10 @@ from lxml import etree, objectify from openlp.core.common.i18n import translate from openlp.core.widgets.wizard import WizardStrings from openlp.plugins.songs.lib import clean_song, VerseType -from openlp.plugins.songs.lib.importers.songimport import SongImport from openlp.plugins.songs.lib.db import Author, Book, Song, Topic -from openlp.plugins.songs.lib.ui import SongStrings +from openlp.plugins.songs.lib.importers.songimport import SongImport from openlp.plugins.songs.lib.openlyricsxml import SongXML +from openlp.plugins.songs.lib.ui import SongStrings log = logging.getLogger(__name__) diff --git a/openlp/plugins/songs/lib/importers/lyrix.py b/openlp/plugins/songs/lib/importers/lyrix.py index c8dbac24b..386fe43e2 100644 --- a/openlp/plugins/songs/lib/importers/lyrix.py +++ b/openlp/plugins/songs/lib/importers/lyrix.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/importers/mediashout.py b/openlp/plugins/songs/lib/importers/mediashout.py index 9df9baa0f..5ecd53bd3 100644 --- a/openlp/plugins/songs/lib/importers/mediashout.py +++ b/openlp/plugins/songs/lib/importers/mediashout.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,9 +27,10 @@ a MediaShout database into the OpenLP database. # WARNING: See https://docs.python.org/3/library/sqlite3.html for value substitution # in SQL statements -import pyodbc import logging +import pyodbc + from openlp.core.common.i18n import translate from openlp.plugins.songs.lib.importers.songimport import SongImport diff --git a/openlp/plugins/songs/lib/importers/openlp.py b/openlp/plugins/songs/lib/importers/openlp.py index 80a981d02..8800f568d 100644 --- a/openlp/plugins/songs/lib/importers/openlp.py +++ b/openlp/plugins/songs/lib/importers/openlp.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/importers/openlyrics.py b/openlp/plugins/songs/lib/importers/openlyrics.py index f443cfb34..62bb91414 100644 --- a/openlp/plugins/songs/lib/importers/openlyrics.py +++ b/openlp/plugins/songs/lib/importers/openlyrics.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,8 +29,8 @@ from lxml import etree from openlp.core.widgets.wizard import WizardStrings from openlp.plugins.songs.lib.importers.songimport import SongImport -from openlp.plugins.songs.lib.ui import SongStrings from openlp.plugins.songs.lib.openlyricsxml import OpenLyrics, OpenLyricsError +from openlp.plugins.songs.lib.ui import SongStrings log = logging.getLogger(__name__) diff --git a/openlp/plugins/songs/lib/importers/openoffice.py b/openlp/plugins/songs/lib/importers/openoffice.py index f2a8b2147..e1862c936 100644 --- a/openlp/plugins/songs/lib/importers/openoffice.py +++ b/openlp/plugins/songs/lib/importers/openoffice.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/importers/opensong.py b/openlp/plugins/songs/lib/importers/opensong.py index 6cd690562..25e52777a 100644 --- a/openlp/plugins/songs/lib/importers/opensong.py +++ b/openlp/plugins/songs/lib/importers/opensong.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/importers/opspro.py b/openlp/plugins/songs/lib/importers/opspro.py index f7dba83b8..5edcfdd39 100644 --- a/openlp/plugins/songs/lib/importers/opspro.py +++ b/openlp/plugins/songs/lib/importers/opspro.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,9 +29,10 @@ a OPS Pro database into the OpenLP database. import logging import re -import pyodbc import struct +import pyodbc + from openlp.core.common.i18n import translate from openlp.plugins.songs.lib.importers.songimport import SongImport diff --git a/openlp/plugins/songs/lib/importers/powerpraise.py b/openlp/plugins/songs/lib/importers/powerpraise.py index fd6f64360..dfe545d64 100644 --- a/openlp/plugins/songs/lib/importers/powerpraise.py +++ b/openlp/plugins/songs/lib/importers/powerpraise.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/importers/powersong.py b/openlp/plugins/songs/lib/importers/powersong.py index 7fac4ef75..d73e3ed9c 100644 --- a/openlp/plugins/songs/lib/importers/powersong.py +++ b/openlp/plugins/songs/lib/importers/powersong.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -24,10 +24,9 @@ The :mod:`powersong` module provides the functionality for importing PowerSong songs into the OpenLP database. """ import logging -import fnmatch -import os from openlp.core.common.i18n import translate +from openlp.core.common.path import Path from openlp.plugins.songs.lib.importers.songimport import SongImport log = logging.getLogger(__name__) @@ -89,26 +88,25 @@ class PowerSongImport(SongImport): """ from openlp.plugins.songs.lib.importer import SongFormat ps_string = SongFormat.get(SongFormat.PowerSong, 'name') - if isinstance(self.import_source, str): - if os.path.isdir(self.import_source): + if isinstance(self.import_source, Path): + if self.import_source.is_dir(): dir = self.import_source self.import_source = [] - for file in os.listdir(dir): - if fnmatch.fnmatch(file, '*.song'): - self.import_source.append(os.path.join(dir, file)) + for path in dir.glob('*.song'): + self.import_source.append(path) else: - self.import_source = '' + self.import_source = None if not self.import_source or not isinstance(self.import_source, list): self.log_error(translate('SongsPlugin.PowerSongImport', 'No songs to import.'), translate('SongsPlugin.PowerSongImport', 'No {text} files found.').format(text=ps_string)) return self.import_wizard.progress_bar.setMaximum(len(self.import_source)) - for file in self.import_source: + for file_path in self.import_source: if self.stop_import_flag: return self.set_defaults() parse_error = False - with open(file, 'rb') as song_data: + with file_path.open('rb') as song_data: while True: try: label = self._read_string(song_data) @@ -117,7 +115,7 @@ class PowerSongImport(SongImport): field = self._read_string(song_data) except ValueError: parse_error = True - self.log_error(os.path.basename(file), + self.log_error(file_path.name, translate('SongsPlugin.PowerSongImport', 'Invalid {text} file. Unexpected byte value.').format(text=ps_string)) break @@ -135,7 +133,7 @@ class PowerSongImport(SongImport): continue # Check that file had TITLE field if not self.title: - self.log_error(os.path.basename(file), + self.log_error(file_path.name, translate('SongsPlugin.PowerSongImport', 'Invalid {text} file. Missing "TITLE" header.').format(text=ps_string)) continue diff --git a/openlp/plugins/songs/lib/importers/presentationmanager.py b/openlp/plugins/songs/lib/importers/presentationmanager.py index c8f9a16f9..9b16f24a6 100644 --- a/openlp/plugins/songs/lib/importers/presentationmanager.py +++ b/openlp/plugins/songs/lib/importers/presentationmanager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,8 +27,8 @@ import re from lxml import objectify, etree -from openlp.core.common.i18n import translate from openlp.core.common import get_file_encoding +from openlp.core.common.i18n import translate from openlp.core.widgets.wizard import WizardStrings from openlp.plugins.songs.lib.importers.songimport import SongImport diff --git a/openlp/plugins/songs/lib/importers/propresenter.py b/openlp/plugins/songs/lib/importers/propresenter.py index 0de0e5300..f5e0058db 100644 --- a/openlp/plugins/songs/lib/importers/propresenter.py +++ b/openlp/plugins/songs/lib/importers/propresenter.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,6 +25,7 @@ ProPresenter song files into the current installation database. """ import base64 import logging + from lxml import objectify from openlp.core.widgets.wizard import WizardStrings diff --git a/openlp/plugins/songs/lib/importers/songbeamer.py b/openlp/plugins/songs/lib/importers/songbeamer.py index adc364325..e4276dd20 100644 --- a/openlp/plugins/songs/lib/importers/songbeamer.py +++ b/openlp/plugins/songs/lib/importers/songbeamer.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,15 +22,15 @@ """ The :mod:`songbeamer` module provides the functionality for importing SongBeamer songs into the OpenLP database. """ +import base64 import logging +import math import os import re -import base64 -import math from openlp.core.common import is_win, is_macosx, get_file_encoding -from openlp.core.common.settings import Settings from openlp.core.common.path import Path +from openlp.core.common.settings import Settings from openlp.plugins.songs.lib import VerseType from openlp.plugins.songs.lib.importers.songimport import SongImport diff --git a/openlp/plugins/songs/lib/importers/songimport.py b/openlp/plugins/songs/lib/importers/songimport.py index 2bd8c0e56..aab98e00d 100644 --- a/openlp/plugins/songs/lib/importers/songimport.py +++ b/openlp/plugins/songs/lib/importers/songimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -33,8 +33,8 @@ from openlp.core.common.registry import Registry from openlp.core.widgets.wizard import WizardStrings from openlp.plugins.songs.lib import clean_song, VerseType from openlp.plugins.songs.lib.db import Song, Author, Topic, Book, MediaFile -from openlp.plugins.songs.lib.ui import SongStrings from openlp.plugins.songs.lib.openlyricsxml import SongXML +from openlp.plugins.songs.lib.ui import SongStrings log = logging.getLogger(__name__) diff --git a/openlp/plugins/songs/lib/importers/songpro.py b/openlp/plugins/songs/lib/importers/songpro.py index 261c2c728..9f52e62dc 100644 --- a/openlp/plugins/songs/lib/importers/songpro.py +++ b/openlp/plugins/songs/lib/importers/songpro.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/importers/songshowplus.py b/openlp/plugins/songs/lib/importers/songshowplus.py index 3109fae1d..ceadbdf8f 100644 --- a/openlp/plugins/songs/lib/importers/songshowplus.py +++ b/openlp/plugins/songs/lib/importers/songshowplus.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/importers/songsoffellowship.py b/openlp/plugins/songs/lib/importers/songsoffellowship.py index bbba654c9..d0c0a6720 100644 --- a/openlp/plugins/songs/lib/importers/songsoffellowship.py +++ b/openlp/plugins/songs/lib/importers/songsoffellowship.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,13 +27,11 @@ # http://wiki.services.openoffice.org/wiki/Python import logging -import os import re from openlp.core.common import is_win from .openoffice import OpenOfficeImport - log = logging.getLogger(__name__) if is_win(): diff --git a/openlp/plugins/songs/lib/importers/sundayplus.py b/openlp/plugins/songs/lib/importers/sundayplus.py index e0ce16aa1..180c76e19 100644 --- a/openlp/plugins/songs/lib/importers/sundayplus.py +++ b/openlp/plugins/songs/lib/importers/sundayplus.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -19,7 +19,6 @@ # with this program; if not, write to the Free Software Foundation, Inc., 59 # # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### -import os import re from openlp.plugins.songs.lib import VerseType, retrieve_windows_encoding @@ -60,21 +59,24 @@ class SundayPlusImport(SongImport): for file_path in self.import_source: if self.stop_import_flag: return - with file_path.open('rb') as song_file: - self.do_import_file(song_file) + self.do_import_file(file_path) - def do_import_file(self, file): + def do_import_file(self, file_path): """ - Process the Sunday Plus file object. + Process the Sunday Plus song file + + :param openlp.core.common.path.Path file_path: The song file to import + :rtype: None """ - self.set_defaults() - if not self.parse(file.read()): - self.log_error(file.name) - return - if self.title == '': - self.title = self.title_from_filename(file.name) - if not self.finish(): - self.log_error(file.name) + with file_path.open('rb') as song_file: + self.set_defaults() + if not self.parse(song_file.read()): + self.log_error(file_path.name) + return + if self.title == '': + self.title = self.title_from_file_path(file_path) + if not self.finish(): + self.log_error(file_path.name) def parse(self, data, cell=False): """ @@ -174,16 +176,15 @@ class SundayPlusImport(SongImport): i += 1 return True - def title_from_filename(self, filename): + def title_from_file_path(self, file_path): """ Extract the title from the filename - :param filename: File name - :return: + :param openlp.core.common.path.Path file_path: File being imported + :return: The song title + :rtype: str """ - title = os.path.split(filename)[1] - if title.endswith('.ptf'): - title = title[:-4] + title = file_path.stem # For some strange reason all example files names ended with 1-7. if title.endswith('1-7'): title = title[:-3] diff --git a/openlp/plugins/songs/lib/importers/videopsalm.py b/openlp/plugins/songs/lib/importers/videopsalm.py index 180dbd333..156d98f69 100644 --- a/openlp/plugins/songs/lib/importers/videopsalm.py +++ b/openlp/plugins/songs/lib/importers/videopsalm.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,10 +27,10 @@ import logging import re from openlp.core.common.i18n import translate -from openlp.core.common.settings import Settings from openlp.core.common.path import Path -from openlp.plugins.songs.lib.importers.songimport import SongImport +from openlp.core.common.settings import Settings from openlp.plugins.songs.lib.db import AuthorType +from openlp.plugins.songs.lib.importers.songimport import SongImport log = logging.getLogger(__name__) diff --git a/openlp/plugins/songs/lib/importers/wordsofworship.py b/openlp/plugins/songs/lib/importers/wordsofworship.py index e1c561361..dff14efe4 100644 --- a/openlp/plugins/songs/lib/importers/wordsofworship.py +++ b/openlp/plugins/songs/lib/importers/wordsofworship.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,9 +23,8 @@ The :mod:`wordsofworship` module provides the functionality for importing Words of Worship songs into the OpenLP database. """ -import os import logging -from openlp.core.common.path import Path +import os from openlp.core.common.i18n import translate from openlp.plugins.songs.lib.importers.songimport import SongImport diff --git a/openlp/plugins/songs/lib/importers/worshipassistant.py b/openlp/plugins/songs/lib/importers/worshipassistant.py index f9354427d..02df16b4a 100644 --- a/openlp/plugins/songs/lib/importers/worshipassistant.py +++ b/openlp/plugins/songs/lib/importers/worshipassistant.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/importers/worshipcenterpro.py b/openlp/plugins/songs/lib/importers/worshipcenterpro.py index 6bba00682..6ae24f7bc 100644 --- a/openlp/plugins/songs/lib/importers/worshipcenterpro.py +++ b/openlp/plugins/songs/lib/importers/worshipcenterpro.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,6 +25,7 @@ a WorshipCenter Pro database into the OpenLP database. """ import logging import re + import pyodbc from openlp.core.common.i18n import translate diff --git a/openlp/plugins/songs/lib/importers/zionworx.py b/openlp/plugins/songs/lib/importers/zionworx.py index 23817c31a..345f3ac44 100644 --- a/openlp/plugins/songs/lib/importers/zionworx.py +++ b/openlp/plugins/songs/lib/importers/zionworx.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/mediaitem.py b/openlp/plugins/songs/lib/mediaitem.py index c6ad9c927..3d46311df 100644 --- a/openlp/plugins/songs/lib/mediaitem.py +++ b/openlp/plugins/songs/lib/mediaitem.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/openlyricsexport.py b/openlp/plugins/songs/lib/openlyricsexport.py index b07298253..ff3e4fe3e 100644 --- a/openlp/plugins/songs/lib/openlyricsexport.py +++ b/openlp/plugins/songs/lib/openlyricsexport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,8 +29,8 @@ from lxml import etree from openlp.core.common import clean_filename from openlp.core.common.i18n import translate -from openlp.core.common.path import create_paths from openlp.core.common.mixins import RegistryProperties +from openlp.core.common.path import create_paths from openlp.plugins.songs.lib.openlyricsxml import OpenLyrics log = logging.getLogger(__name__) diff --git a/openlp/plugins/songs/lib/openlyricsxml.py b/openlp/plugins/songs/lib/openlyricsxml.py index ef47fa77b..63a528cfe 100644 --- a/openlp/plugins/songs/lib/openlyricsxml.py +++ b/openlp/plugins/songs/lib/openlyricsxml.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -63,8 +63,8 @@ from lxml import etree, objectify from openlp.core.common.i18n import translate from openlp.core.common.settings import Settings -from openlp.core.version import get_version from openlp.core.lib import FormattingTags +from openlp.core.version import get_version from openlp.plugins.songs.lib import VerseType, clean_song from openlp.plugins.songs.lib.db import Author, AuthorType, Book, Song, Topic diff --git a/openlp/plugins/songs/lib/songcompare.py b/openlp/plugins/songs/lib/songcompare.py index 06314cac0..09c55f877 100644 --- a/openlp/plugins/songs/lib/songcompare.py +++ b/openlp/plugins/songs/lib/songcompare.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/songselect.py b/openlp/plugins/songs/lib/songselect.py index 85ada339f..61de5b574 100644 --- a/openlp/plugins/songs/lib/songselect.py +++ b/openlp/plugins/songs/lib/songselect.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,11 +25,11 @@ The :mod:`~openlp.plugins.songs.lib.songselect` module contains the SongSelect i import logging import random import re +from html import unescape +from html.parser import HTMLParser from http.cookiejar import CookieJar from urllib.parse import urlencode from urllib.request import HTTPCookieProcessor, URLError, build_opener -from html.parser import HTMLParser -from html import unescape from bs4 import BeautifulSoup, NavigableString diff --git a/openlp/plugins/songs/lib/songstab.py b/openlp/plugins/songs/lib/songstab.py index 69f9bb1cd..173957b82 100644 --- a/openlp/plugins/songs/lib/songstab.py +++ b/openlp/plugins/songs/lib/songstab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/ui.py b/openlp/plugins/songs/lib/ui.py index e318577a0..71ce32b99 100644 --- a/openlp/plugins/songs/lib/ui.py +++ b/openlp/plugins/songs/lib/ui.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/lib/upgrade.py b/openlp/plugins/songs/lib/upgrade.py index eca18876b..cfa7f2730 100644 --- a/openlp/plugins/songs/lib/upgrade.py +++ b/openlp/plugins/songs/lib/upgrade.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/reporting.py b/openlp/plugins/songs/reporting.py index 808c05b57..afbb2559d 100644 --- a/openlp/plugins/songs/reporting.py +++ b/openlp/plugins/songs/reporting.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songs/songsplugin.py b/openlp/plugins/songs/songsplugin.py index b35cbe2c9..e8fff3f2a 100644 --- a/openlp/plugins/songs/songsplugin.py +++ b/openlp/plugins/songs/songsplugin.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,8 +25,8 @@ for the Songs plugin. """ import logging -import os import sqlite3 +from pathlib import Path from tempfile import gettempdir from PyQt5 import QtCore, QtWidgets @@ -316,17 +316,16 @@ class SongsPlugin(Plugin): self.application.process_events() self.on_tools_reindex_item_triggered() self.application.process_events() - db_dir = os.path.join(gettempdir(), 'openlp') - if not os.path.exists(db_dir): + db_dir_path = Path(gettempdir(), 'openlp') + if not db_dir_path.exists(): return - song_dbs = [] + song_db_paths = [] song_count = 0 - for sfile in os.listdir(db_dir): - if sfile.startswith('songs_') and sfile.endswith('.sqlite'): - self.application.process_events() - song_dbs.append(os.path.join(db_dir, sfile)) - song_count += SongsPlugin._count_songs(os.path.join(db_dir, sfile)) - if not song_dbs: + for db_file_path in db_dir_path.glob('songs_*.sqlite'): + self.application.process_events() + song_db_paths.append(db_file_path) + song_count += SongsPlugin._count_songs(db_file_path) + if not song_db_paths: return self.application.process_events() progress = QtWidgets.QProgressDialog(self.main_window) @@ -338,8 +337,8 @@ class SongsPlugin(Plugin): progress.setMinimumDuration(0) progress.forceShow() self.application.process_events() - for db in song_dbs: - importer = OpenLPSongImport(self.manager, file_path=db) + for db_path in song_db_paths: + importer = OpenLPSongImport(self.manager, file_path=db_path) importer.do_import(progress) self.application.process_events() progress.setValue(song_count) @@ -373,13 +372,15 @@ class SongsPlugin(Plugin): self.manager.delete_object(Song, song.id) @staticmethod - def _count_songs(db_file): + def _count_songs(db_path): """ Provide a count of the songs in the database - :param db_file: the database name to count + :param openlp.core.common.path.Path db_path: The database to use + :return: The number of songs in the db. + :rtype: int """ - connection = sqlite3.connect(db_file) + connection = sqlite3.connect(str(db_path)) cursor = connection.cursor() cursor.execute('SELECT COUNT(id) AS song_count FROM songs') song_count = cursor.fetchone()[0] diff --git a/openlp/plugins/songusage/__init__.py b/openlp/plugins/songusage/__init__.py index 3847c7d97..87358b136 100644 --- a/openlp/plugins/songusage/__init__.py +++ b/openlp/plugins/songusage/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songusage/forms/__init__.py b/openlp/plugins/songusage/forms/__init__.py index 17252dcf5..1ab5ed70c 100644 --- a/openlp/plugins/songusage/forms/__init__.py +++ b/openlp/plugins/songusage/forms/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songusage/forms/songusagedeletedialog.py b/openlp/plugins/songusage/forms/songusagedeletedialog.py index fe199009b..59f2ef042 100644 --- a/openlp/plugins/songusage/forms/songusagedeletedialog.py +++ b/openlp/plugins/songusage/forms/songusagedeletedialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songusage/forms/songusagedeleteform.py b/openlp/plugins/songusage/forms/songusagedeleteform.py index 9042756d6..23a994ff5 100644 --- a/openlp/plugins/songusage/forms/songusagedeleteform.py +++ b/openlp/plugins/songusage/forms/songusagedeleteform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -24,8 +24,8 @@ from PyQt5 import QtCore, QtWidgets from openlp.core.common.i18n import translate from openlp.core.common.mixins import RegistryProperties -from openlp.plugins.songusage.lib.db import SongUsageItem from openlp.plugins.songusage.forms.songusagedeletedialog import Ui_SongUsageDeleteDialog +from openlp.plugins.songusage.lib.db import SongUsageItem class SongUsageDeleteForm(QtWidgets.QDialog, Ui_SongUsageDeleteDialog, RegistryProperties): diff --git a/openlp/plugins/songusage/forms/songusagedetaildialog.py b/openlp/plugins/songusage/forms/songusagedetaildialog.py index 7f6d1c16b..ead4d7b3d 100644 --- a/openlp/plugins/songusage/forms/songusagedetaildialog.py +++ b/openlp/plugins/songusage/forms/songusagedetaildialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songusage/forms/songusagedetailform.py b/openlp/plugins/songusage/forms/songusagedetailform.py index dc3393c8d..f25f56bee 100644 --- a/openlp/plugins/songusage/forms/songusagedetailform.py +++ b/openlp/plugins/songusage/forms/songusagedetailform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -26,8 +26,8 @@ from sqlalchemy.sql import and_ from openlp.core.common.i18n import translate from openlp.core.common.mixins import RegistryProperties -from openlp.core.common.settings import Settings from openlp.core.common.path import create_paths +from openlp.core.common.settings import Settings from openlp.core.lib.ui import critical_error_message_box from openlp.plugins.songusage.lib.db import SongUsageItem from .songusagedetaildialog import Ui_SongUsageDetailDialog diff --git a/openlp/plugins/songusage/lib/__init__.py b/openlp/plugins/songusage/lib/__init__.py index a3365baed..2136c10a8 100644 --- a/openlp/plugins/songusage/lib/__init__.py +++ b/openlp/plugins/songusage/lib/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songusage/lib/db.py b/openlp/plugins/songusage/lib/db.py index 0a06f640a..9ef223d3f 100644 --- a/openlp/plugins/songusage/lib/db.py +++ b/openlp/plugins/songusage/lib/db.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songusage/lib/upgrade.py b/openlp/plugins/songusage/lib/upgrade.py index f83022d84..8f30d986a 100644 --- a/openlp/plugins/songusage/lib/upgrade.py +++ b/openlp/plugins/songusage/lib/upgrade.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/openlp/plugins/songusage/songusageplugin.py b/openlp/plugins/songusage/songusageplugin.py index 79f21a8cf..455ab3713 100644 --- a/openlp/plugins/songusage/songusageplugin.py +++ b/openlp/plugins/songusage/songusageplugin.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/scripts/appveyor-webhook.py b/scripts/appveyor-webhook.py index 630c404d7..f969b0e70 100755 --- a/scripts/appveyor-webhook.py +++ b/scripts/appveyor-webhook.py @@ -5,7 +5,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/scripts/check_dependencies.py b/scripts/check_dependencies.py index 1d8ffff3e..9eaa8fe25 100755 --- a/scripts/check_dependencies.py +++ b/scripts/check_dependencies.py @@ -5,7 +5,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/scripts/clean_up_resources.py b/scripts/clean_up_resources.py index 77fddc47a..baad3e1f6 100755 --- a/scripts/clean_up_resources.py +++ b/scripts/clean_up_resources.py @@ -5,7 +5,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/scripts/generate_resources.sh b/scripts/generate_resources.sh index 84d345756..231a9bdca 100755 --- a/scripts/generate_resources.sh +++ b/scripts/generate_resources.sh @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/scripts/jenkins_script.py b/scripts/jenkins_script.py index f365f2b55..5a1e67c45 100755 --- a/scripts/jenkins_script.py +++ b/scripts/jenkins_script.py @@ -5,7 +5,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -158,11 +158,12 @@ class JenkinsTrigger(object): """ queue_info = self.server.get_queue_info() tries = 0 - while queue_info and tries < 50: + loop_count = 100 + while queue_info and tries < loop_count: tries += 1 - time.sleep(0.5) + time.sleep(1) queue_info = self.server.get_queue_info() - if tries >= 50: + if tries >= loop_count: raise Exception('Build has not started yet, it may be stuck in the queue.') return self.server.get_build_info(job_name, build_number) diff --git a/scripts/lp-merge.py b/scripts/lp-merge.py index c59e03705..393cf7e9f 100755 --- a/scripts/lp-merge.py +++ b/scripts/lp-merge.py @@ -5,7 +5,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/scripts/resources.patch b/scripts/resources.patch index 11fa85531..6be6ac514 100644 --- a/scripts/resources.patch +++ b/scripts/resources.patch @@ -14,7 +14,7 @@ +############################################################################### +# OpenLP - Open Source Lyrics Projection # +# --------------------------------------------------------------------------- # -+# Copyright (c) 2008-2017 OpenLP Developers # ++# Copyright (c) 2008-2018 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 # diff --git a/scripts/translation_utils.py b/scripts/translation_utils.py index 0489eec23..44f2476f5 100755 --- a/scripts/translation_utils.py +++ b/scripts/translation_utils.py @@ -5,7 +5,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/scripts/websocket_client.py b/scripts/websocket_client.py index bf1aa5e0f..03a208a6f 100755 --- a/scripts/websocket_client.py +++ b/scripts/websocket_client.py @@ -5,7 +5,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/setup.py b/setup.py index 24a4d15db..fdbcdaea5 100755 --- a/setup.py +++ b/setup.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/__init__.py b/tests/__init__.py index 051801ce1..0980890eb 100644 --- a/tests/__init__.py +++ b/tests/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/__init__.py b/tests/functional/__init__.py index bb8d97f15..3acbe4f00 100644 --- a/tests/functional/__init__.py +++ b/tests/functional/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,7 +22,6 @@ """ Base directory for tests """ -import sys from PyQt5 import QtWidgets # Only one QApplication can be created. Use QtWidgets.QApplication.instance() when you need to "create" a QApplication. diff --git a/tests/functional/openlp_core/__init__.py b/tests/functional/openlp_core/__init__.py index e69de29bb..711ded4ae 100644 --- a/tests/functional/openlp_core/__init__.py +++ b/tests/functional/openlp_core/__init__.py @@ -0,0 +1,21 @@ +# -*- coding: utf-8 -*- +# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4 + +############################################################################### +# OpenLP - Open Source Lyrics Projection # +# --------------------------------------------------------------------------- # +# Copyright (c) 2008-2018 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 # +############################################################################### diff --git a/tests/functional/openlp_core/api/__init__.py b/tests/functional/openlp_core/api/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/functional/openlp_core/api/__init__.py +++ b/tests/functional/openlp_core/api/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/api/http/__init__.py b/tests/functional/openlp_core/api/http/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/functional/openlp_core/api/http/__init__.py +++ b/tests/functional/openlp_core/api/http/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/api/http/test_error.py b/tests/functional/openlp_core/api/http/test_error.py index 599ecfc03..376cdef8b 100644 --- a/tests/functional/openlp_core/api/http/test_error.py +++ b/tests/functional/openlp_core/api/http/test_error.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/api/http/test_http.py b/tests/functional/openlp_core/api/http/test_http.py index b8b30cc25..4feb95526 100644 --- a/tests/functional/openlp_core/api/http/test_http.py +++ b/tests/functional/openlp_core/api/http/test_http.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,8 +25,8 @@ Functional tests to test the Http Server Class. from unittest import TestCase from unittest.mock import MagicMock, patch -from openlp.core.common.registry import Registry from openlp.core.api.http.server import HttpServer +from openlp.core.common.registry import Registry class TestHttpServer(TestCase): diff --git a/tests/functional/openlp_core/api/http/test_wsgiapp.py b/tests/functional/openlp_core/api/http/test_wsgiapp.py index 17b3ae8c5..a7cf331b5 100644 --- a/tests/functional/openlp_core/api/http/test_wsgiapp.py +++ b/tests/functional/openlp_core/api/http/test_wsgiapp.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,12 +23,11 @@ Functional test the routing code. """ import os - from unittest import TestCase from unittest.mock import MagicMock -from openlp.core.api.http.endpoint import Endpoint from openlp.core.api.http import register_endpoint, application, NotFound +from openlp.core.api.http.endpoint import Endpoint ROOT_DIR = os.path.dirname(os.path.realpath(__file__)) diff --git a/tests/functional/openlp_core/api/test_deploy.py b/tests/functional/openlp_core/api/test_deploy.py index 0aaf1308b..2b544702c 100644 --- a/tests/functional/openlp_core/api/test_deploy.py +++ b/tests/functional/openlp_core/api/test_deploy.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/api/test_tab.py b/tests/functional/openlp_core/api/test_tab.py index bd701784d..0de0b6d94 100644 --- a/tests/functional/openlp_core/api/test_tab.py +++ b/tests/functional/openlp_core/api/test_tab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,16 +22,15 @@ """ This module contains tests for the lib submodule of the Remotes plugin. """ -import os import re from unittest import TestCase from unittest.mock import patch from PyQt5 import QtWidgets +from openlp.core.api.tab import ApiTab from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings -from openlp.core.api.tab import ApiTab from tests.helpers.testmixin import TestMixin __default_settings__ = { @@ -45,7 +44,6 @@ __default_settings__ = { 'remotes/download version': '0000_00_00' } ZERO_URL = '0.0.0.0' -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources')) class TestApiTab(TestCase, TestMixin): diff --git a/tests/functional/openlp_core/api/test_websockets.py b/tests/functional/openlp_core/api/test_websockets.py index 4b1917c36..9e4ec381b 100644 --- a/tests/functional/openlp_core/api/test_websockets.py +++ b/tests/functional/openlp_core/api/test_websockets.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,10 +25,10 @@ Functional tests to test the Http Server Class. from unittest import TestCase from unittest.mock import MagicMock, patch +from openlp.core.api.poll import Poller +from openlp.core.api.websockets import WebSocketServer from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings -from openlp.core.api.websockets import WebSocketServer -from openlp.core.api.poll import Poller from tests.helpers.testmixin import TestMixin __default_settings__ = { diff --git a/tests/functional/openlp_core/common/__init__.py b/tests/functional/openlp_core/common/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/functional/openlp_core/common/__init__.py +++ b/tests/functional/openlp_core/common/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/common/test_actions.py b/tests/functional/openlp_core/common/test_actions.py index 7d5ac6fca..517d76fab 100644 --- a/tests/functional/openlp_core/common/test_actions.py +++ b/tests/functional/openlp_core/common/test_actions.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,7 +29,6 @@ from PyQt5 import QtGui, QtCore, QtWidgets from openlp.core.common.actions import CategoryActionList, ActionList from openlp.core.common.settings import Settings - from tests.helpers.testmixin import TestMixin diff --git a/tests/functional/openlp_core/common/test_applocation.py b/tests/functional/openlp_core/common/test_applocation.py index 551287476..5d54deba3 100644 --- a/tests/functional/openlp_core/common/test_applocation.py +++ b/tests/functional/openlp_core/common/test_applocation.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/common/test_common.py b/tests/functional/openlp_core/common/test_common.py index 368705821..b4554d198 100644 --- a/tests/functional/openlp_core/common/test_common.py +++ b/tests/functional/openlp_core/common/test_common.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/common/test_db.py b/tests/functional/openlp_core/common/test_db.py index 75bdde228..7fe59b35f 100644 --- a/tests/functional/openlp_core/common/test_db.py +++ b/tests/functional/openlp_core/common/test_db.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/common/test_httputils.py b/tests/functional/openlp_core/common/test_httputils.py index 7cc75c0e4..7d3966279 100644 --- a/tests/functional/openlp_core/common/test_httputils.py +++ b/tests/functional/openlp_core/common/test_httputils.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,7 +29,6 @@ from unittest.mock import MagicMock, patch from openlp.core.common.httputils import get_user_agent, get_web_page, get_url_file_size, download_file from openlp.core.common.path import Path - from tests.helpers.testmixin import TestMixin diff --git a/tests/functional/openlp_core/common/test_i18n.py b/tests/functional/openlp_core/common/test_i18n.py index 4f4ca2aec..16d321f4f 100644 --- a/tests/functional/openlp_core/common/test_i18n.py +++ b/tests/functional/openlp_core/common/test_i18n.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/common/test_init.py b/tests/functional/openlp_core/common/test_init.py index 9965a07ee..83f0c1c7c 100644 --- a/tests/functional/openlp_core/common/test_init.py +++ b/tests/functional/openlp_core/common/test_init.py @@ -22,15 +22,13 @@ """ Functional tests to test the AppLocation class and related methods. """ -import os from io import BytesIO from unittest import TestCase from unittest.mock import MagicMock, PropertyMock, call, patch -from openlp.core.common import add_actions, clean_filename, delete_file, get_file_encoding, get_filesystem_encoding, \ +from openlp.core.common import add_actions, clean_filename, delete_file, get_file_encoding, get_filesystem_encoding, \ get_uno_command, get_uno_instance from openlp.core.common.path import Path - from tests.helpers.testmixin import TestMixin diff --git a/tests/functional/openlp_core/common/test_json.py b/tests/functional/openlp_core/common/test_json.py index 18cba3b4e..31392c70d 100644 --- a/tests/functional/openlp_core/common/test_json.py +++ b/tests/functional/openlp_core/common/test_json.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -26,8 +26,8 @@ import json from unittest import TestCase from unittest.mock import patch -from openlp.core.common.path import Path from openlp.core.common.json import OpenLPJsonDecoder, OpenLPJsonEncoder +from openlp.core.common.path import Path class TestOpenLPJsonDecoder(TestCase): diff --git a/tests/functional/openlp_core/common/test_mixins.py b/tests/functional/openlp_core/common/test_mixins.py index f49c2b797..ba202a2ab 100644 --- a/tests/functional/openlp_core/common/test_mixins.py +++ b/tests/functional/openlp_core/common/test_mixins.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/common/test_path.py b/tests/functional/openlp_core/common/test_path.py index b069c251d..305713bc3 100644 --- a/tests/functional/openlp_core/common/test_path.py +++ b/tests/functional/openlp_core/common/test_path.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/common/test_projector_utilities.py b/tests/functional/openlp_core/common/test_projector_utilities.py index 5a3f886cf..ecdb5a240 100644 --- a/tests/functional/openlp_core/common/test_projector_utilities.py +++ b/tests/functional/openlp_core/common/test_projector_utilities.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -26,7 +26,6 @@ Package to test the openlp.core.ui.projector.networkutils package. from unittest import TestCase from openlp.core.common import verify_ip_address, md5_hash, qmd5_hash - from tests.resources.projector.data import TEST_PIN, TEST_SALT, TEST_HASH salt = TEST_SALT diff --git a/tests/functional/openlp_core/common/test_registry.py b/tests/functional/openlp_core/common/test_registry.py index 6f3cc5752..b5cf106b2 100644 --- a/tests/functional/openlp_core/common/test_registry.py +++ b/tests/functional/openlp_core/common/test_registry.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,14 +22,11 @@ """ Package to test the openlp.core.lib package. """ -import os from unittest import TestCase from unittest.mock import MagicMock from openlp.core.common.registry import Registry, RegistryBase -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), '../', '..', 'resources')) - class TestRegistry(TestCase): diff --git a/tests/functional/openlp_core/common/test_settings.py b/tests/functional/openlp_core/common/test_settings.py index 4cad58af0..d39b0adf8 100644 --- a/tests/functional/openlp_core/common/test_settings.py +++ b/tests/functional/openlp_core/common/test_settings.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -28,7 +28,6 @@ from unittest.mock import call, patch from openlp.core.common import settings from openlp.core.common.settings import Settings, media_players_conv - from tests.helpers.testmixin import TestMixin diff --git a/tests/functional/openlp_core/display/__init__.py b/tests/functional/openlp_core/display/__init__.py index 96d55e7e8..a1a7979b5 100644 --- a/tests/functional/openlp_core/display/__init__.py +++ b/tests/functional/openlp_core/display/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/display/test_renderer.py b/tests/functional/openlp_core/display/test_renderer.py index b1478c7b9..c1d03a1e1 100644 --- a/tests/functional/openlp_core/display/test_renderer.py +++ b/tests/functional/openlp_core/display/test_renderer.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -28,12 +28,11 @@ from unittest.mock import MagicMock, patch from PyQt5 import QtCore from openlp.core.common.registry import Registry -from openlp.core.display.screens import ScreenList from openlp.core.display.renderer import Renderer, words_split, get_start_tags +from openlp.core.display.screens import ScreenList from openlp.core.lib import ServiceItem from openlp.core.lib.theme import Theme - SCREEN = { 'primary': False, 'number': 1, diff --git a/tests/functional/openlp_core/display/test_screens.py b/tests/functional/openlp_core/display/test_screens.py index 960f9d0a8..0d36b7ceb 100644 --- a/tests/functional/openlp_core/display/test_screens.py +++ b/tests/functional/openlp_core/display/test_screens.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/lib/test_db.py b/tests/functional/openlp_core/lib/test_db.py index 033508965..cc928ac56 100644 --- a/tests/functional/openlp_core/lib/test_db.py +++ b/tests/functional/openlp_core/lib/test_db.py @@ -23,14 +23,13 @@ Package to test the openlp.core.lib package. """ import shutil - from tempfile import mkdtemp from unittest import TestCase from unittest.mock import patch, MagicMock -from sqlalchemy.pool import NullPool -from sqlalchemy.orm.scoping import ScopedSession from sqlalchemy import MetaData +from sqlalchemy.orm.scoping import ScopedSession +from sqlalchemy.pool import NullPool from openlp.core.common.path import Path from openlp.core.lib.db import init_db, get_upgrade_op, delete_database, upgrade_db diff --git a/tests/functional/openlp_core/lib/test_htmlbuilder.py b/tests/functional/openlp_core/lib/test_htmlbuilder.py index ffd796ecb..11bfde2b6 100644 --- a/tests/functional/openlp_core/lib/test_htmlbuilder.py +++ b/tests/functional/openlp_core/lib/test_htmlbuilder.py @@ -10,7 +10,6 @@ from openlp.core.common.settings import Settings from openlp.core.lib.htmlbuilder import build_html, build_background_css, build_lyrics_css, build_lyrics_outline_css, \ build_lyrics_format_css, build_footer_css, webkit_version, build_chords_css from openlp.core.lib.theme import HorizontalType, VerticalType - from tests.helpers.testmixin import TestMixin HTML = """ diff --git a/tests/functional/openlp_core/lib/test_image_manager.py b/tests/functional/openlp_core/lib/test_image_manager.py index 2a0e61c9a..9cee73739 100644 --- a/tests/functional/openlp_core/lib/test_image_manager.py +++ b/tests/functional/openlp_core/lib/test_image_manager.py @@ -33,10 +33,10 @@ from PyQt5 import QtGui from openlp.core.common.registry import Registry from openlp.core.display.screens import ScreenList from openlp.core.lib.imagemanager import ImageWorker, ImageManager, Priority, PriorityQueue - from tests.helpers.testmixin import TestMixin +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources')) +TEST_PATH = str(RESOURCE_PATH) class TestImageWorker(TestCase, TestMixin): @@ -165,13 +165,13 @@ class TestImageManager(TestCase, TestMixin): image = self.image_manager.get_image(full_path, 'church.jpg') # THEN returned record is a type of image - self.assertEqual(isinstance(image, QtGui.QImage), True, 'The returned object should be a QImage') + assert isinstance(image, QtGui.QImage), 'The returned object should be a QImage' # WHEN: The image bytes are requested. byte_array = self.image_manager.get_image_bytes(full_path, 'church.jpg') # THEN: Type should be a str. - self.assertEqual(isinstance(byte_array, str), True, 'The returned object should be a str') + assert isinstance(byte_array, str), 'The returned object should be a str' # WHEN the image is retrieved has not been loaded # THEN a KeyError is thrown @@ -198,14 +198,14 @@ class TestImageManager(TestCase, TestMixin): self.image_manager.add_image(full_path, 'church.jpg', None, 100, 100) # THEN: the cache should contain two pictures - self.assertEqual(len(self.image_manager._cache), 2, - 'Image manager should consider two dimensions of the same picture as different') + assert len(self.image_manager._cache) == 2, \ + 'Image manager should consider two dimensions of the same picture as different' # WHEN: adding the same image with first dimensions self.image_manager.add_image(full_path, 'church.jpg', None, 80, 80) # THEN: the cache should still contain only two pictures - self.assertEqual(len(self.image_manager._cache), 2, 'Same dimensions should not be added again') + assert len(self.image_manager._cache) == 2, 'Same dimensions should not be added again' # WHEN: calling with correct image, but wrong dimensions with self.assertRaises(KeyError) as context: diff --git a/tests/functional/openlp_core/lib/test_lib.py b/tests/functional/openlp_core/lib/test_lib.py index 7cc44ec4e..b771d0da0 100644 --- a/tests/functional/openlp_core/lib/test_lib.py +++ b/tests/functional/openlp_core/lib/test_lib.py @@ -22,7 +22,6 @@ """ Package to test the openlp.core.lib package. """ -import os from unittest import TestCase from unittest.mock import MagicMock, patch @@ -32,8 +31,7 @@ from openlp.core.common.path import Path from openlp.core.lib import FormattingTags, build_icon, check_item_selected, clean_tags, compare_chord_lyric, \ create_separated_list, create_thumb, expand_chords, expand_chords_for_printing, expand_tags, find_formatting_tags, \ get_text_file_string, image_to_byte, resize_image, str_to_bool, validate_thumb - -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources')) +from tests.utils.constants import RESOURCE_PATH class TestLib(TestCase): @@ -273,8 +271,8 @@ class TestLib(TestCase): Test the create_thumb() function with a given size. """ # GIVEN: An image to create a thumb of. - image_path = Path(TEST_PATH, 'church.jpg') - thumb_path = Path(TEST_PATH, 'church_thumb.jpg') + image_path = RESOURCE_PATH / 'church.jpg' + thumb_path = RESOURCE_PATH / 'church_thumb.jpg' thumb_size = QtCore.QSize(10, 20) # Remove the thumb so that the test actually tests if the thumb will be created. Maybe it was not deleted in the @@ -291,7 +289,7 @@ class TestLib(TestCase): icon = create_thumb(image_path, thumb_path, size=thumb_size) # THEN: Check if the thumb was created and scaled to the given size. - self.assertTrue(thumb_path.exists(), 'Test was not ran, because the thumb already exists') + assert thumb_path.exists() is True, 'Test was not ran, because the thumb already exists' assert isinstance(icon, QtGui.QIcon), 'The icon should be a QIcon' assert icon.isNull() is False, 'The icon should not be null' assert thumb_size == QtGui.QImageReader(str(thumb_path)).size(), 'The thumb should have the given size' @@ -307,8 +305,8 @@ class TestLib(TestCase): Test the create_thumb() function with no size specified. """ # GIVEN: An image to create a thumb of. - image_path = Path(TEST_PATH, 'church.jpg') - thumb_path = Path(TEST_PATH, 'church_thumb.jpg') + image_path = RESOURCE_PATH / 'church.jpg' + thumb_path = RESOURCE_PATH / 'church_thumb.jpg' expected_size = QtCore.QSize(63, 88) # Remove the thumb so that the test actually tests if the thumb will be created. Maybe it was not deleted in the @@ -325,7 +323,7 @@ class TestLib(TestCase): icon = create_thumb(image_path, thumb_path) # THEN: Check if the thumb was created, retaining its aspect ratio. - self.assertTrue(thumb_path.exists(), 'Test was not ran, because the thumb already exists') + assert thumb_path.exists() is True, 'Test was not ran, because the thumb already exists' assert isinstance(icon, QtGui.QIcon), 'The icon should be a QIcon' assert icon.isNull() is False, 'The icon should not be null' assert expected_size == QtGui.QImageReader(str(thumb_path)).size(), 'The thumb should have the given size' @@ -341,8 +339,8 @@ class TestLib(TestCase): Test the create_thumb() function with invalid size specified. """ # GIVEN: An image to create a thumb of. - image_path = Path(TEST_PATH, 'church.jpg') - thumb_path = Path(TEST_PATH, 'church_thumb.jpg') + image_path = RESOURCE_PATH / 'church.jpg' + thumb_path = RESOURCE_PATH / 'church_thumb.jpg' thumb_size = QtCore.QSize(-1, -1) expected_size = QtCore.QSize(63, 88) @@ -376,8 +374,8 @@ class TestLib(TestCase): Test the create_thumb() function with a size of only width specified. """ # GIVEN: An image to create a thumb of. - image_path = Path(TEST_PATH, 'church.jpg') - thumb_path = Path(TEST_PATH, 'church_thumb.jpg') + image_path = RESOURCE_PATH / 'church.jpg' + thumb_path = RESOURCE_PATH / 'church_thumb.jpg' thumb_size = QtCore.QSize(100, -1) expected_size = QtCore.QSize(100, 137) @@ -411,8 +409,8 @@ class TestLib(TestCase): Test the create_thumb() function with a size of only height specified. """ # GIVEN: An image to create a thumb of. - image_path = Path(TEST_PATH, 'church.jpg') - thumb_path = Path(TEST_PATH, 'church_thumb.jpg') + image_path = RESOURCE_PATH / 'church.jpg' + thumb_path = RESOURCE_PATH / 'church_thumb.jpg' thumb_size = QtCore.QSize(-1, 100) expected_size = QtCore.QSize(72, 100) @@ -430,7 +428,7 @@ class TestLib(TestCase): icon = create_thumb(image_path, thumb_path, size=thumb_size) # THEN: Check if the thumb was created, retaining its aspect ratio. - self.assertTrue(thumb_path.exists(), 'Test was not ran, because the thumb already exists') + assert thumb_path.exists() is True, 'Test was not ran, because the thumb already exists' assert isinstance(icon, QtGui.QIcon), 'The icon should be a QIcon' assert icon.isNull() is False, 'The icon should not be null' assert expected_size == QtGui.QImageReader(str(thumb_path)).size(), 'The thumb should have the given size' @@ -446,8 +444,8 @@ class TestLib(TestCase): Test the create_thumb() function with a size of only height specified. """ # GIVEN: An image to create a thumb of. - image_path = Path(TEST_PATH, 'church.jpg') - thumb_path = Path(TEST_PATH, 'church_thumb.jpg') + image_path = RESOURCE_PATH / 'church.jpg' + thumb_path = RESOURCE_PATH / 'church_thumb.jpg' thumb_size = QtCore.QSize(-1, 100) expected_size_1 = QtCore.QSize(88, 88) expected_size_2 = QtCore.QSize(100, 100) @@ -468,7 +466,7 @@ class TestLib(TestCase): icon = create_thumb(image_path, thumb_path, size=None) # THEN: Check if the thumb was created with aspect ratio of 1. - self.assertTrue(thumb_path.exists(), 'Test was not ran, because the thumb already exists') + assert thumb_path.exists() is True, 'Test was not ran, because the thumb already exists' assert isinstance(icon, QtGui.QIcon), 'The icon should be a QIcon' assert icon.isNull() is False, 'The icon should not be null' assert expected_size_1 == QtGui.QImageReader(str(thumb_path)).size(), 'The thumb should have the given size' @@ -639,7 +637,7 @@ class TestLib(TestCase): Test the resize_thumb() function """ # GIVEN: A path to an image. - image_path = os.path.join(TEST_PATH, 'church.jpg') + image_path = str(RESOURCE_PATH / 'church.jpg') wanted_width = 777 wanted_height = 72 # We want the background to be white. @@ -660,7 +658,7 @@ class TestLib(TestCase): Test the resize_thumb() function ignoring aspect ratio """ # GIVEN: A path to an image. - image_path = os.path.join(TEST_PATH, 'church.jpg') + image_path = str(RESOURCE_PATH / 'church.jpg') wanted_width = 1000 wanted_height = 1000 # We want the background to be white. @@ -789,7 +787,7 @@ class TestLib(TestCase): ret = compare_chord_lyric(chord, lyrics) # THEN: The returned value should 0 because the lyric is longer than the chord - self.assertEquals(0, ret, 'The returned value should 0 because the lyric is longer than the chord') + assert 0 == ret, 'The returned value should 0 because the lyric is longer than the chord' def test_compare_chord_lyric_long_chord(self): """ diff --git a/tests/functional/openlp_core/lib/test_mediamanageritem.py b/tests/functional/openlp_core/lib/test_mediamanageritem.py index 6c659a5bc..aba4d4c06 100644 --- a/tests/functional/openlp_core/lib/test_mediamanageritem.py +++ b/tests/functional/openlp_core/lib/test_mediamanageritem.py @@ -26,7 +26,6 @@ from unittest import TestCase from unittest.mock import MagicMock, patch from openlp.core.lib import MediaManagerItem - from tests.helpers.testmixin import TestMixin diff --git a/tests/functional/openlp_core/lib/test_path.py b/tests/functional/openlp_core/lib/test_path.py index f59a1ce08..ce6f655df 100644 --- a/tests/functional/openlp_core/lib/test_path.py +++ b/tests/functional/openlp_core/lib/test_path.py @@ -52,7 +52,7 @@ class TestPath(TestCase): result = path_to_str(None) # THEN: `path_to_str` should return an empty string - self.assertEqual(result, '') + assert result == '' def test_path_to_str_path_object(self): """ @@ -63,7 +63,7 @@ class TestPath(TestCase): result = path_to_str(Path('test/path')) # THEN: `path_to_str` should return a string representation of the Path object - self.assertEqual(result, os.path.join('test', 'path')) + assert result == os.path.join('test', 'path') def test_str_to_path_type_error(self): """ @@ -84,4 +84,4 @@ class TestPath(TestCase): result = str_to_path('') # THEN: `path_to_str` should return None - self.assertEqual(result, None) + assert result is None diff --git a/tests/functional/openlp_core/lib/test_pluginmanager.py b/tests/functional/openlp_core/lib/test_pluginmanager.py index 163f52877..553221ff2 100644 --- a/tests/functional/openlp_core/lib/test_pluginmanager.py +++ b/tests/functional/openlp_core/lib/test_pluginmanager.py @@ -27,8 +27,8 @@ from unittest.mock import MagicMock from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings -from openlp.core.lib.pluginmanager import PluginManager from openlp.core.lib import PluginStatus +from openlp.core.lib.pluginmanager import PluginManager class TestPluginManager(TestCase): diff --git a/tests/functional/openlp_core/lib/test_serviceitem.py b/tests/functional/openlp_core/lib/test_serviceitem.py index d069f18bf..63544458a 100644 --- a/tests/functional/openlp_core/lib/test_serviceitem.py +++ b/tests/functional/openlp_core/lib/test_serviceitem.py @@ -31,8 +31,8 @@ from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings from openlp.core.lib import ItemCapabilities, ServiceItem, ServiceItemType, FormattingTags from tests.helpers.testmixin import TestMixin - from tests.utils import assert_length, convert_file_service_item +from tests.utils.constants import RESOURCE_PATH VERSE = 'The Lord said to {r}Noah{/r}: \n'\ 'There\'s gonna be a {su}floody{/su}, {sb}floody{/sb}\n'\ @@ -59,7 +59,7 @@ RENDERED_VERSE = 'The Lord said to Noa 'e'\ 'n of the Lord\n' FOOTER = ['Arky Arky (Unknown)', 'Public Domain', 'CCLI 123456'] -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'service')) +TEST_PATH = str(RESOURCE_PATH / 'service') __default_settings__ = { 'songs/enable chords': True, diff --git a/tests/functional/openlp_core/lib/test_theme.py b/tests/functional/openlp_core/lib/test_theme.py index 4e6407d1c..bdafa3ea8 100644 --- a/tests/functional/openlp_core/lib/test_theme.py +++ b/tests/functional/openlp_core/lib/test_theme.py @@ -22,7 +22,6 @@ """ Package to test the openlp.core.lib.theme package. """ -import os from pathlib import Path from unittest import TestCase diff --git a/tests/functional/openlp_core/projectors/test_projector_bugfixes_01.py b/tests/functional/openlp_core/projectors/test_projector_bugfixes_01.py index da0aae47f..8cceb6ef6 100644 --- a/tests/functional/openlp_core/projectors/test_projector_bugfixes_01.py +++ b/tests/functional/openlp_core/projectors/test_projector_bugfixes_01.py @@ -26,7 +26,6 @@ from unittest import TestCase from openlp.core.projectors.db import Projector from openlp.core.projectors.pjlink import PJLink - from tests.resources.projector.data import TEST1_DATA diff --git a/tests/functional/openlp_core/projectors/test_projector_constants.py b/tests/functional/openlp_core/projectors/test_projector_constants.py index ed1afa677..6ef4d2118 100644 --- a/tests/functional/openlp_core/projectors/test_projector_constants.py +++ b/tests/functional/openlp_core/projectors/test_projector_constants.py @@ -23,12 +23,51 @@ Package to test the openlp.core.projectors.constants module. """ from unittest import TestCase +from openlp.core.projectors import constants +from openlp.core.projectors.constants import STATUS_CODE, STATUS_MSG class TestProjectorConstants(TestCase): """ Test specific functions in the projector constants module. """ + def test_defined_codes_in_status_code(self): + """ + Test defined status/error codes have equivalent strings + """ + check = [] + missing_str = [] + + # GIVEN: List of defined E_* and S_* items defined in constants + for item in constants.__dict__: + if item.startswith('E_') or item.startswith('S_'): + check.append(item) + + # WHEN: Verify defined list against STATUS_STR + for item in check: + if constants.__dict__[item] not in STATUS_CODE: + missing_str.append(item) + + # THEN: There should be no missing items + assert 0 == len(missing_str), 'Status string missing: {msg}'.format(msg=missing_str) + + def test_status_code_in_status_message(self): + """ + Test if entries in STATUS_CODE have equivalent descriptions in STATUS_MSG + """ + missing_msg = [] + + # GIVEN: Test items + check = STATUS_CODE + + # WHEN: Verify each entry in STATUS_MSG against STATUS_CODE + for item in check: + if item not in STATUS_MSG: + missing_msg.append(item) + + # THEN: There should be no missing items + assert 0 == len(missing_msg), 'Status message missing: {msg}'.format(msg=missing_msg) + def test_build_pjlink_video_label(self): """ Test building PJLINK_DEFAULT_CODES dictionary diff --git a/tests/functional/openlp_core/projectors/test_projector_db.py b/tests/functional/openlp_core/projectors/test_projector_db.py index 1dfe47a54..619f16bf2 100644 --- a/tests/functional/openlp_core/projectors/test_projector_db.py +++ b/tests/functional/openlp_core/projectors/test_projector_db.py @@ -28,7 +28,6 @@ PREREQUISITE: add_record() and get_all() functions validated. import os import shutil from tempfile import mkdtemp - from unittest import TestCase from unittest.mock import patch @@ -36,7 +35,6 @@ from openlp.core.lib.db import upgrade_db from openlp.core.projectors import upgrade from openlp.core.projectors.constants import PJLINK_PORT from openlp.core.projectors.db import Manufacturer, Model, Projector, ProjectorDB, ProjectorSource, Source - from tests.resources.projector.data import TEST_DB_PJLINK1, TEST_DB, TEST1_DATA, TEST2_DATA, TEST3_DATA from tests.utils.constants import TEST_RESOURCES_PATH diff --git a/tests/functional/openlp_core/projectors/test_projector_pjlink_base.py b/tests/functional/openlp_core/projectors/test_projector_pjlink_base.py index c86904bad..ca699e4eb 100644 --- a/tests/functional/openlp_core/projectors/test_projector_pjlink_base.py +++ b/tests/functional/openlp_core/projectors/test_projector_pjlink_base.py @@ -25,10 +25,9 @@ Package to test the openlp.core.projectors.pjlink base package. from unittest import TestCase from unittest.mock import call, patch, MagicMock -from openlp.core.projectors.constants import E_PARAMETER, ERROR_STRING, S_ON, S_CONNECTED, S_QSOCKET_STATE +from openlp.core.projectors.constants import E_PARAMETER, STATUS_CODE, S_ON, S_CONNECTED, QSOCKET_STATE from openlp.core.projectors.db import Projector from openlp.core.projectors.pjlink import PJLink - from tests.resources.projector.data import TEST1_DATA pjlink_test = PJLink(Projector(**TEST1_DATA), no_poll=True) @@ -65,7 +64,7 @@ class TestPJLinkBase(TestCase): # as first parameter mock_change_status.called_with(E_PARAMETER, 'change_status should have been called with "{}"'.format( - ERROR_STRING[E_PARAMETER])) + STATUS_CODE[E_PARAMETER])) @patch.object(pjlink_test, 'disconnect_from_host') def test_socket_abort(self, mock_disconnect): @@ -104,7 +103,7 @@ class TestPJLinkBase(TestCase): """ # GIVEN: Mocks and test data mock_state = patch.object(self.pjlink_test, 'state').start() - mock_state.return_value = S_QSOCKET_STATE['ConnectedState'] + mock_state.return_value = QSOCKET_STATE[S_CONNECTED] mock_timer = patch.object(self.pjlink_test, 'timer').start() mock_timer.interval.return_value = 10 mock_send_command = patch.object(self.pjlink_test, 'send_command').start() @@ -117,7 +116,6 @@ class TestPJLinkBase(TestCase): pjlink.manufacturer = None pjlink.model = None pjlink.pjlink_name = None - pjlink.ConnectedState = S_CONNECTED call_list = [ call('POWR'), call('ERST'), diff --git a/tests/functional/openlp_core/projectors/test_projector_pjlink_cmd_routing.py b/tests/functional/openlp_core/projectors/test_projector_pjlink_cmd_routing.py index 4ff133061..74623b9c3 100644 --- a/tests/functional/openlp_core/projectors/test_projector_pjlink_cmd_routing.py +++ b/tests/functional/openlp_core/projectors/test_projector_pjlink_cmd_routing.py @@ -24,209 +24,222 @@ Package to test the openlp.core.projectors.pjlink command routing. """ from unittest import TestCase -from unittest.mock import patch, MagicMock +from unittest.mock import MagicMock, call, patch import openlp.core.projectors.pjlink -from openlp.core.projectors.constants import PJLINK_ERRORS, \ +from openlp.core.projectors.constants import PJLINK_ERRORS, PJLINK_PREFIX, STATUS_MSG, \ E_AUTHENTICATION, E_PARAMETER, E_PROJECTOR, E_UNAVAILABLE, E_UNDEFINED from openlp.core.projectors.db import Projector from openlp.core.projectors.pjlink import PJLink -''' -from openlp.core.projectors.constants import ERROR_STRING, PJLINK_ERST_DATA, PJLINK_ERST_STATUS, \ - PJLINK_POWR_STATUS, PJLINK_VALID_CMD, E_WARN, E_ERROR, S_OFF, S_STANDBY, S_ON -''' -from tests.resources.projector.data import TEST_PIN, TEST1_DATA - -pjlink_test = PJLink(Projector(**TEST1_DATA), pin=TEST_PIN, no_poll=True) -pjlink_test.ip = '127.0.0.1' +from tests.resources.projector.data import TEST1_DATA class TestPJLinkRouting(TestCase): """ Tests for the PJLink module command routing """ - def setUp(self): - ''' - TestPJLinkCommands part 2 initialization - ''' - self.pjlink_test = PJLink(Projector(**TEST1_DATA), no_poll=True) + def test_get_data_unknown_command(self): + """ + Test not a valid command + """ + # GIVEN: Test object + log_warning_text = [call('(111.111.111.111) get_data(): Invalid packet - unknown command "UNK"')] + log_debug_text = [call('(111.111.111.111) get_data(ip="111.111.111.111" buffer="b\'%1UNK=Huh?\'"'), + call('(111.111.111.111) get_data(): Checking new data "%1UNK=Huh?"')] - def tearDown(self): - ''' - TestPJLinkCommands part 2 cleanups - ''' - self.pjlink_test = None + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, '_trash_buffer') as mock_buffer: - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_process_command_call_clss(self, mock_log): + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.pjlink_functions = MagicMock() + + # WHEN: get_data called with an unknown command + pjlink.get_data(buff='{prefix}1UNK=Huh?'.format(prefix=PJLINK_PREFIX).encode('utf-8')) + + # THEN: Appropriate log entries should have been made and methods called/not called + mock_log.debug.assert_has_calls(log_debug_text) + mock_log.warning.assert_has_calls(log_warning_text) + assert pjlink.pjlink_functions.called is False, 'Should not have accessed pjlink_functions' + assert mock_buffer.called is True, 'Should have called _trash_buffer' + + def test_process_command_call_clss(self): """ Test process_command calls proper function """ - # GIVEN: Test object - pjlink = pjlink_test - log_text = '(127.0.0.1) Calling function for CLSS' - mock_log.reset_mock() - mock_process_clss = MagicMock() - pjlink.pjlink_functions['CLSS'] = mock_process_clss + # GIVEN: Test object and mocks + log_debug_calls = [call('(111.111.111.111) Processing command "CLSS" with data "1"'), + call('(111.111.111.111) Calling function for CLSS')] - # WHEN: process_command is called with valid function and data - pjlink.process_command(cmd='CLSS', data='1') + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'process_clss') as mock_process_clss: - # THEN: Process method should have been called properly - mock_log.debug.assert_called_with(log_text) - mock_process_clss.assert_called_with('1') + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - @patch.object(pjlink_test, 'change_status') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_process_command_err1(self, mock_log, mock_change_status): - """ - Test ERR1 - Undefined projector function - """ - # GIVEN: Test object - pjlink = pjlink_test - log_text = '(127.0.0.1) Projector returned error "ERR1"' - mock_change_status.reset_mock() - mock_log.reset_mock() + # WHEN: process_command is called with valid function and data + pjlink.process_command(cmd='CLSS', data='1') - # WHEN: process_command called with ERR1 - pjlink.process_command(cmd='CLSS', data=PJLINK_ERRORS[E_UNDEFINED]) + # THEN: Appropriate log entries should have been made and methods called + mock_log.debug.assert_has_calls(log_debug_calls) + mock_process_clss.assert_called_once_with(data='1') - # THEN: Error should be logged and status_change should be called - mock_change_status.assert_called_once_with(E_UNDEFINED, 'Undefined Command: "CLSS"') - mock_log.error.assert_called_with(log_text) - - @patch.object(pjlink_test, 'change_status') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_process_command_err2(self, mock_log, mock_change_status): - """ - Test ERR2 - Parameter Error - """ - # GIVEN: Test object - pjlink = pjlink_test - log_text = '(127.0.0.1) Projector returned error "ERR2"' - mock_change_status.reset_mock() - mock_log.reset_mock() - - # WHEN: process_command called with ERR2 - pjlink.process_command(cmd='CLSS', data=PJLINK_ERRORS[E_PARAMETER]) - - # THEN: Error should be logged and status_change should be called - mock_change_status.assert_called_once_with(E_PARAMETER) - mock_log.error.assert_called_with(log_text) - - @patch.object(pjlink_test, 'change_status') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_process_command_err3(self, mock_log, mock_change_status): - """ - Test ERR3 - Unavailable error - """ - # GIVEN: Test object - pjlink = pjlink_test - log_text = '(127.0.0.1) Projector returned error "ERR3"' - mock_change_status.reset_mock() - mock_log.reset_mock() - - # WHEN: process_command called with ERR3 - pjlink.process_command(cmd='CLSS', data=PJLINK_ERRORS[E_UNAVAILABLE]) - - # THEN: Error should be logged and status_change should be called - mock_change_status.assert_called_once_with(E_UNAVAILABLE) - mock_log.error.assert_called_with(log_text) - - @patch.object(pjlink_test, 'change_status') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_process_command_err4(self, mock_log, mock_change_status): - """ - Test ERR3 - Unavailable error - """ - # GIVEN: Test object - pjlink = pjlink_test - log_text = '(127.0.0.1) Projector returned error "ERR4"' - mock_change_status.reset_mock() - mock_log.reset_mock() - - # WHEN: process_command called with ERR3 - pjlink.process_command(cmd='CLSS', data=PJLINK_ERRORS[E_PROJECTOR]) - - # THEN: Error should be logged and status_change should be called - mock_change_status.assert_called_once_with(E_PROJECTOR) - mock_log.error.assert_called_with(log_text) - - @patch.object(pjlink_test, 'projectorAuthentication') - @patch.object(pjlink_test, 'change_status') - @patch.object(pjlink_test, 'disconnect_from_host') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_process_command_erra(self, mock_log, mock_disconnect, mock_change_status, mock_err_authenticate): + def test_process_command_erra(self): """ Test ERRA - Authentication Error """ # GIVEN: Test object - pjlink = pjlink_test - log_text = '(127.0.0.1) Projector returned error "ERRA"' - mock_change_status.reset_mock() - mock_log.reset_mock() + log_error_calls = [call('(111.111.111.111) PJLINK: {msg}'.format(msg=STATUS_MSG[E_AUTHENTICATION]))] + log_debug_calls = [call('(111.111.111.111) Processing command "PJLINK" with data "ERRA"')] - # WHEN: process_command called with ERRA - pjlink.process_command(cmd='CLSS', data=PJLINK_ERRORS[E_AUTHENTICATION]) + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'process_pjlink') as mock_process_pjlink, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'change_status') as mock_change_status, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'disconnect_from_host') as mock_disconnect, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorAuthentication') as mock_authentication: - # THEN: Error should be logged and several methods should be called - self.assertTrue(mock_disconnect.called, 'disconnect_from_host should have been called') - mock_change_status.assert_called_once_with(E_AUTHENTICATION) - mock_log.error.assert_called_with(log_text) + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + + # WHEN: process_command called with ERRA + pjlink.process_command(cmd='PJLINK', data=PJLINK_ERRORS[E_AUTHENTICATION]) + + # THEN: Appropriate log entries should have been made and methods called/not called + assert mock_disconnect.called is True, 'disconnect_from_host should have been called' + mock_log.error.assert_has_calls(log_error_calls) + mock_log.debug.assert_has_calls(log_debug_calls) + mock_change_status.assert_called_once_with(status=E_AUTHENTICATION) + mock_authentication.emit.assert_called_once_with(pjlink.name) + mock_process_pjlink.assert_not_called() + + def test_process_command_err1(self): + """ + Test ERR1 - Undefined projector function + """ + # GIVEN: Test object + log_error_text = [call('(111.111.111.111) CLSS: {msg}'.format(msg=STATUS_MSG[E_UNDEFINED]))] + log_debug_text = [call('(111.111.111.111) Processing command "CLSS" with data "ERR1"'), + call('(111.111.111.111) Calling function for CLSS')] + + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'process_clss') as mock_process_clss: + + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + + # WHEN: process_command called with ERR1 + pjlink.process_command(cmd='CLSS', data=PJLINK_ERRORS[E_UNDEFINED]) + + # THEN: Appropriate log entries should have been made and methods called + mock_log.error.assert_has_calls(log_error_text) + mock_log.debug.assert_has_calls(log_debug_text) + mock_process_clss.assert_called_once_with(data=PJLINK_ERRORS[E_UNDEFINED]) + + def test_process_command_err2(self): + """ + Test ERR2 - Parameter Error + """ + # GIVEN: Test object + log_error_text = [call('(111.111.111.111) CLSS: {msg}'.format(msg=STATUS_MSG[E_PARAMETER]))] + log_debug_text = [call('(111.111.111.111) Processing command "CLSS" with data "ERR2"'), + call('(111.111.111.111) Calling function for CLSS')] + + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'process_clss') as mock_process_clss: + + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + + # WHEN: process_command called with ERR2 + pjlink.process_command(cmd='CLSS', data=PJLINK_ERRORS[E_PARAMETER]) + + # THEN: Appropriate log entries should have been made and methods called/not called + mock_log.error.assert_has_calls(log_error_text) + mock_log.debug.assert_has_calls(log_debug_text) + mock_process_clss.assert_called_once_with(data=PJLINK_ERRORS[E_PARAMETER]) + + def test_process_command_err3(self): + """ + Test ERR3 - Unavailable error + """ + # GIVEN: Test object + log_error_text = [call('(111.111.111.111) CLSS: {msg}'.format(msg=STATUS_MSG[E_UNAVAILABLE]))] + log_debug_text = [call('(111.111.111.111) Processing command "CLSS" with data "ERR3"'), + call('(111.111.111.111) Calling function for CLSS')] + + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'process_clss') as mock_process_clss: + + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + + # WHEN: process_command called with ERR3 + pjlink.process_command(cmd='CLSS', data=PJLINK_ERRORS[E_UNAVAILABLE]) + + # THEN: Appropriate log entries should have been made and methods called + mock_log.error.assert_has_calls(log_error_text) + mock_log.debug.assert_has_calls(log_debug_text) + mock_process_clss.assert_called_once_with(data=PJLINK_ERRORS[E_UNAVAILABLE]) + + def test_process_command_err4(self): + """ + Test ERR3 - Unavailable error + """ + # GIVEN: Test object + log_error_text = [call('(111.111.111.111) CLSS: {msg}'.format(msg=STATUS_MSG[E_PROJECTOR]))] + log_debug_text = [call('(111.111.111.111) Processing command "CLSS" with data "ERR4"'), + call('(111.111.111.111) Calling function for CLSS')] + + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'process_clss') as mock_process_clss: + + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + + # WHEN: process_command called with ERR4 + pjlink.process_command(cmd='CLSS', data=PJLINK_ERRORS[E_PROJECTOR]) + + # THEN: Appropriate log entries should have been made and methods called + mock_log.error.assert_has_calls(log_error_text) + mock_log.debug.assert_has_calls(log_debug_text) + mock_process_clss.assert_called_once_with(data=PJLINK_ERRORS[E_PROJECTOR]) def test_process_command_future(self): """ Test command valid but no method to process yet """ - # GIVEN: Initial mocks and data - mock_log = patch.object(openlp.core.projectors.pjlink, 'log').start() - mock_functions = patch.object(self.pjlink_test, 'pjlink_functions').start() - mock_functions.return_value = [] - - pjlink = self.pjlink_test - log_text = '(111.111.111.111) Unable to process command="CLSS" (Future option?)' - - # WHEN: process_command called with an unknown command - pjlink.process_command(cmd='CLSS', data='DONT CARE') - - # THEN: Error should be logged and no command called - self.assertFalse(mock_functions.called, 'Should not have gotten to the end of the method') - mock_log.warning.assert_called_once_with(log_text) - - @patch.object(pjlink_test, 'pjlink_functions') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_process_command_invalid(self, mock_log, mock_functions): - """ - Test not a valid command - """ # GIVEN: Test object - pjlink = pjlink_test - mock_functions.reset_mock() - mock_log.reset_mock() + log_warning_text = [call('(111.111.111.111) Unable to process command="CLSS" (Future option?)')] + log_debug_text = [call('(111.111.111.111) Processing command "CLSS" with data "Huh?"')] - # WHEN: process_command called with an unknown command - pjlink.process_command(cmd='Unknown', data='Dont Care') - log_text = '(127.0.0.1) Ignoring command="Unknown" (Invalid/Unknown)' + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'process_clss') as mock_process_clss: - # THEN: Error should be logged and no command called - self.assertFalse(mock_functions.called, 'Should not have gotten to the end of the method') - mock_log.error.assert_called_once_with(log_text) + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.pjlink_functions = MagicMock() + + # WHEN: Processing a possible future command + pjlink.process_command(cmd='CLSS', data="Huh?") + + # THEN: Appropriate log entries should have been made and methods called/not called + mock_log.debug.assert_has_calls(log_debug_text) + mock_log.warning.assert_has_calls(log_warning_text) + assert pjlink.pjlink_functions.called is False, 'Should not have accessed pjlink_functions' + assert mock_process_clss.called is False, 'Should not have called process_clss' def test_process_command_ok(self): """ Test command returned success """ # GIVEN: Initial mocks and data - mock_log = patch.object(openlp.core.projectors.pjlink, 'log').start() - mock_send_command = patch.object(self.pjlink_test, 'send_command').start() + # GIVEN: Test object and mocks + log_debug_calls = [call('(111.111.111.111) Processing command "CLSS" with data "OK"'), + call('(111.111.111.111) Command "CLSS" returned OK')] - pjlink = self.pjlink_test - log_text = '(111.111.111.111) Command "POWR" returned OK' + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'process_clss') as mock_process_clss: - # WHEN: process_command called with a command that returns OK - pjlink.process_command(cmd='POWR', data='OK') + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - # THEN: Appropriate calls should have been made - mock_log.debug.assert_called_with(log_text) - mock_send_command.assert_called_once_with(cmd='POWR') + # WHEN: process_command is called with valid function and data + pjlink.process_command(cmd='CLSS', data='OK') + + # THEN: Appropriate log entries should have been made and methods called + mock_log.debug.assert_has_calls(log_debug_calls) + mock_send_command.assert_called_once_with(cmd='CLSS') + mock_process_clss.assert_not_called() diff --git a/tests/functional/openlp_core/projectors/test_projector_pjlink_commands_01.py b/tests/functional/openlp_core/projectors/test_projector_pjlink_commands_01.py index 8340a0fd0..c8551b594 100644 --- a/tests/functional/openlp_core/projectors/test_projector_pjlink_commands_01.py +++ b/tests/functional/openlp_core/projectors/test_projector_pjlink_commands_01.py @@ -23,938 +23,1017 @@ Package to test the openlp.core.projectors.pjlink commands package. """ from unittest import TestCase -from unittest.mock import patch +from unittest.mock import call, patch import openlp.core.projectors.pjlink -from openlp.core.projectors.constants import ERROR_STRING, PJLINK_ERST_DATA, PJLINK_ERST_STATUS, \ - PJLINK_POWR_STATUS, \ - E_ERROR, E_NOT_CONNECTED, E_SOCKET_ADDRESS_NOT_AVAILABLE, E_UNKNOWN_SOCKET_ERROR, E_WARN, \ - S_CONNECTED, S_OFF, S_ON, S_NOT_CONNECTED, S_CONNECTING, S_STANDBY +from openlp.core.projectors.constants import PJLINK_ERST_DATA, PJLINK_ERST_STATUS, PJLINK_POWR_STATUS, \ + STATUS_CODE, STATUS_MSG, E_ERROR, E_NOT_CONNECTED, E_UNKNOWN_SOCKET_ERROR, E_WARN, \ + S_CONNECTED, S_CONNECTING, S_OFF, S_OK, S_ON, S_NOT_CONNECTED, S_STANDBY from openlp.core.projectors.db import Projector from openlp.core.projectors.pjlink import PJLink -from tests.resources.projector.data import TEST_PIN, TEST1_DATA - -pjlink_test = PJLink(Projector(**TEST1_DATA), pin=TEST_PIN, no_poll=True) -pjlink_test.ip = '127.0.0.1' - -# Create a list of ERST positional data so we don't have to redo the same buildup multiple times -PJLINK_ERST_POSITIONS = [] -for pos in range(0, len(PJLINK_ERST_DATA)): - if pos in PJLINK_ERST_DATA: - PJLINK_ERST_POSITIONS.append(PJLINK_ERST_DATA[pos]) +from tests.resources.projector.data import TEST1_DATA class TestPJLinkCommands(TestCase): """ Tests for the PJLinkCommands class part 1 """ - @patch.object(pjlink_test, 'changeStatus') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_change_status_connection_error(self, mock_log, mock_change_status): + def test_projector_change_status_unknown_socket_error(self): """ Test change_status with connection error """ - # GIVEN: Test object - pjlink = pjlink_test - pjlink.projector_status = 0 - pjlink.status_connect = 0 - test_code = E_UNKNOWN_SOCKET_ERROR - mock_change_status.reset_mock() - mock_log.reset_mock() + log_debug_calls = [ + call('(111.111.111.111) Changing status to ' + '{status} "{msg}"'.format(status=STATUS_CODE[E_UNKNOWN_SOCKET_ERROR], + msg=STATUS_MSG[E_UNKNOWN_SOCKET_ERROR])), + call('(111.111.111.111) status_connect: ' + '{code}: "{msg}"'.format(code=STATUS_CODE[E_NOT_CONNECTED], + msg=STATUS_MSG[E_NOT_CONNECTED])), + call('(111.111.111.111) projector_status: ' + '{code}: "{msg}"'.format(code=STATUS_CODE[S_OK], + msg=STATUS_MSG[S_OK])), + call('(111.111.111.111) error_status: ' + '{code}: "{msg}"'.format(code=STATUS_CODE[E_UNKNOWN_SOCKET_ERROR], + msg=STATUS_MSG[E_UNKNOWN_SOCKET_ERROR]))] - # WHEN: change_status called with unknown socket error - pjlink.change_status(status=test_code, msg=None) + # GIVEN: Test object and mocks + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'changeStatus') as mock_changeStatus, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons: - # THEN: Proper settings should change and signals sent - self.assertEqual(pjlink.projector_status, E_NOT_CONNECTED, 'Projector status should be NOT CONNECTED') - self.assertEqual(pjlink.status_connect, E_NOT_CONNECTED, 'Status connect should be NOT CONNECTED') - mock_change_status.emit.assert_called_once_with(pjlink.ip, E_UNKNOWN_SOCKET_ERROR, - 'An unidentified error occurred') - self.assertEqual(mock_log.debug.call_count, 3, 'Debug log should have been called 3 times') + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.projector_status = 0 + pjlink.status_connect = 0 - @patch.object(pjlink_test, 'changeStatus') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_change_status_connection_status_connecting(self, mock_log, mock_change_status): + # WHEN: change_status called with unknown socket error + pjlink.change_status(status=E_UNKNOWN_SOCKET_ERROR) + + # THEN: Proper settings should change and signals sent + mock_log.debug.assert_has_calls(log_debug_calls) + assert pjlink.projector_status == S_OK, 'Projector status should not have changed' + assert pjlink.status_connect == E_NOT_CONNECTED, 'Status connect should be NOT CONNECTED' + assert mock_UpdateIcons.emit.called is True, 'Should have called UpdateIcons' + mock_changeStatus.emit.assert_called_once_with(pjlink.ip, E_UNKNOWN_SOCKET_ERROR, + STATUS_MSG[E_UNKNOWN_SOCKET_ERROR]) + + def test_projector_change_status_connection_status_connecting(self): + """ + Test change_status with connecting status + """ + log_debug_calls = [ + call('(111.111.111.111) Changing status to ' + '{status} "{msg}"'.format(status=STATUS_CODE[S_CONNECTING], + msg=STATUS_MSG[S_CONNECTING])), + call('(111.111.111.111) status_connect: ' + '{code}: "{msg}"'.format(code=STATUS_CODE[S_CONNECTING], + msg=STATUS_MSG[S_CONNECTING])), + call('(111.111.111.111) projector_status: ' + '{code}: "{msg}"'.format(code=STATUS_CODE[S_OK], + msg=STATUS_MSG[S_OK])), + call('(111.111.111.111) error_status: ' + '{code}: "{msg}"'.format(code=STATUS_CODE[S_OK], + msg=STATUS_MSG[S_OK]))] + + # GIVEN: Test object and mocks + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'changeStatus') as mock_changeStatus, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons: + + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.projector_status = 0 + pjlink.status_connect = 0 + + # WHEN: change_status called with CONNECTING + pjlink.change_status(status=S_CONNECTING) + + # THEN: Proper settings should change and signals sent + mock_log.debug.assert_has_calls(log_debug_calls) + mock_changeStatus.emit.assert_called_once_with(pjlink.ip, S_CONNECTING, STATUS_MSG[S_CONNECTING]) + assert pjlink.projector_status == S_OK, 'Projector status should not have changed' + assert pjlink.status_connect == S_CONNECTING, 'Status connect should be CONNECTING' + assert mock_UpdateIcons.emit.called is True, 'Should have called UpdateIcons' + + def test_projector_change_status_connection_status_connected(self): + """ + Test change_status with connected status + """ + log_debug_calls = [ + call('(111.111.111.111) Changing status to ' + '{status} "{msg}"'.format(status=STATUS_CODE[S_CONNECTED], + msg=STATUS_MSG[S_CONNECTED])), + call('(111.111.111.111) status_connect: ' + '{code}: "{msg}"'.format(code=STATUS_CODE[S_CONNECTED], + msg=STATUS_MSG[S_CONNECTED])), + call('(111.111.111.111) projector_status: ' + '{code}: "{msg}"'.format(code=STATUS_CODE[S_OK], + msg=STATUS_MSG[S_OK])), + call('(111.111.111.111) error_status: ' + '{code}: "{msg}"'.format(code=STATUS_CODE[S_OK], + msg=STATUS_MSG[S_OK]))] + + # GIVEN: Test object and mocks + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'changeStatus') as mock_changeStatus: + + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.projector_status = 0 + pjlink.status_connect = 0 + + # WHEN: change_status called with CONNECTED + pjlink.change_status(status=S_CONNECTED) + + # THEN: Proper settings should change and signals sent + mock_log.debug.assert_has_calls(log_debug_calls) + mock_changeStatus.emit.assert_called_once_with(pjlink.ip, S_CONNECTED, 'Connected') + assert pjlink.projector_status == S_OK, 'Projector status should not have changed' + assert pjlink.status_connect == S_CONNECTED, 'Status connect should be CONNECTED' + + def test_projector_change_status_connection_status_with_message(self): """ Test change_status with connection status """ - # GIVEN: Test object - pjlink = pjlink_test - pjlink.projector_status = 0 - pjlink.status_connect = 0 - test_code = S_CONNECTING - mock_change_status.reset_mock() - mock_log.reset_mock() - - # WHEN: change_status called with unknown socket error - pjlink.change_status(status=test_code, msg=None) - - # THEN: Proper settings should change and signals sent - self.assertEqual(pjlink.projector_status, S_NOT_CONNECTED, 'Projector status should be NOT CONNECTED') - self.assertEqual(pjlink.status_connect, S_CONNECTING, 'Status connect should be CONNECTING') - mock_change_status.emit.assert_called_once_with(pjlink.ip, S_CONNECTING, 'Connecting') - self.assertEqual(mock_log.debug.call_count, 3, 'Debug log should have been called 3 times') - - @patch.object(pjlink_test, 'changeStatus') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_change_status_connection_status_connected(self, mock_log, mock_change_status): - """ - Test change_status with connection status - """ - # GIVEN: Test object - pjlink = pjlink_test - pjlink.projector_status = 0 - pjlink.status_connect = 0 - test_code = S_ON - mock_change_status.reset_mock() - mock_log.reset_mock() - - # WHEN: change_status called with unknown socket error - pjlink.change_status(status=test_code, msg=None) - - # THEN: Proper settings should change and signals sent - self.assertEqual(pjlink.projector_status, S_ON, 'Projector status should be ON') - self.assertEqual(pjlink.status_connect, S_CONNECTED, 'Status connect should be CONNECTED') - mock_change_status.emit.assert_called_once_with(pjlink.ip, S_ON, 'Power is on') - self.assertEqual(mock_log.debug.call_count, 3, 'Debug log should have been called 3 times') - - @patch.object(pjlink_test, 'changeStatus') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_change_status_connection_status_with_message(self, mock_log, mock_change_status): - """ - Test change_status with connection status - """ - # GIVEN: Test object - pjlink = pjlink_test - pjlink.projector_status = 0 - pjlink.status_connect = 0 test_message = 'Different Status Message than default' - test_code = S_ON - mock_change_status.reset_mock() - mock_log.reset_mock() + log_debug_calls = [ + call('(111.111.111.111) Changing status to {status} "{msg}"'.format(status=STATUS_CODE[S_ON], + msg=test_message)), + call('(111.111.111.111) status_connect: {code}: "{msg}"'.format(code=STATUS_CODE[S_OK], + msg=test_message)), + call('(111.111.111.111) projector_status: {code}: "{msg}"'.format(code=STATUS_CODE[S_ON], + msg=test_message)), + call('(111.111.111.111) error_status: {code}: "{msg}"'.format(code=STATUS_CODE[S_OK], + msg=test_message))] - # WHEN: change_status called with unknown socket error - pjlink.change_status(status=test_code, msg=test_message) + # GIVEN: Test object and mocks + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'changeStatus') as mock_changeStatus: - # THEN: Proper settings should change and signals sent - self.assertEqual(pjlink.projector_status, S_ON, 'Projector status should be ON') - self.assertEqual(pjlink.status_connect, S_CONNECTED, 'Status connect should be CONNECTED') - mock_change_status.emit.assert_called_once_with(pjlink.ip, S_ON, test_message) - self.assertEqual(mock_log.debug.call_count, 3, 'Debug log should have been called 3 times') + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.projector_status = 0 + pjlink.status_connect = 0 - @patch.object(pjlink_test, 'send_command') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_get_av_mute_status(self, mock_log, mock_send_command): + # WHEN: change_status called with projector ON status + pjlink.change_status(status=S_ON, msg=test_message) + + # THEN: Proper settings should change and signals sent + mock_log.debug.assert_has_calls(log_debug_calls) + mock_changeStatus.emit.assert_called_once_with(pjlink.ip, S_ON, test_message) + assert pjlink.projector_status == S_ON, 'Projector status should be ON' + assert pjlink.status_connect == S_OK, 'Status connect should not have changed' + + def test_projector_get_av_mute_status(self): """ Test sending command to retrieve shutter/audio state """ - # GIVEN: Test object - pjlink = pjlink_test - mock_log.reset_mock() - mock_send_command.reset_mock() test_data = 'AVMT' - test_log = '(127.0.0.1) Sending AVMT command' + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is ' + '{state}'.format(state=STATUS_CODE[S_NOT_CONNECTED])), + call('(111.111.111.111) Sending {cmd} command'.format(cmd=test_data))] - # WHEN: get_av_mute_status is called - pjlink.get_av_mute_status() + # GIVEN: Test object and mocks + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - # THEN: log data and send_command should have been called - mock_log.debug.assert_called_once_with(test_log) - mock_send_command.assert_called_once_with(cmd=test_data) + # WHEN: get_av_mute_status is called + pjlink.get_av_mute_status() - @patch.object(pjlink_test, 'send_command') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_get_available_inputs(self, mock_log, mock_send_command): + # THEN: log data and send_command should have been called + mock_log.debug.assert_has_calls(log_debug_calls) + mock_send_command.assert_called_once_with(cmd=test_data) + + def test_projector_get_available_inputs(self): """ Test sending command to retrieve avaliable inputs """ - # GIVEN: Test object - pjlink = pjlink_test - mock_log.reset_mock() - mock_send_command.reset_mock() test_data = 'INST' - test_log = '(127.0.0.1) Sending INST command' + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is ' + '{state}'.format(state=STATUS_CODE[S_NOT_CONNECTED])), + call('(111.111.111.111) Sending {cmd} command'.format(cmd=test_data))] - # WHEN: get_available_inputs is called - pjlink.get_available_inputs() + # GIVEN: Test object and mocks + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - # THEN: log data and send_command should have been called - mock_log.debug.assert_called_once_with(test_log) - mock_send_command.assert_called_once_with(cmd=test_data) + # WHEN: get_available_inputs is called + pjlink.get_available_inputs() - @patch.object(pjlink_test, 'send_command') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_get_error_status(self, mock_log, mock_send_command): + # THEN: log data and send_command should have been called + mock_log.debug.assert_has_calls(log_debug_calls) + mock_send_command.assert_called_once_with(cmd=test_data) + + def test_projector_get_error_status(self): """ Test sending command to retrieve projector error status """ - # GIVEN: Test object - pjlink = pjlink_test - mock_log.reset_mock() - mock_send_command.reset_mock() test_data = 'ERST' - test_log = '(127.0.0.1) Sending ERST command' + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is ' + '{state}'.format(state=STATUS_CODE[S_NOT_CONNECTED])), + call('(111.111.111.111) Sending {cmd} command'.format(cmd=test_data))] + # GIVEN: Test object and mocks + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - # WHEN: get_error_status is called - pjlink.get_error_status() + # WHEN: get_error_status is called + pjlink.get_error_status() - # THEN: log data and send_command should have been called - mock_log.debug.assert_called_once_with(test_log) - mock_send_command.assert_called_once_with(cmd=test_data) + # THEN: log data and send_command should have been called + mock_log.debug.assert_has_calls(log_debug_calls) + mock_send_command.assert_called_once_with(cmd=test_data) - @patch.object(pjlink_test, 'send_command') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_get_input_source(self, mock_log, mock_send_command): + def test_projector_get_input_source(self): """ Test sending command to retrieve current input """ - # GIVEN: Test object - pjlink = pjlink_test - mock_log.reset_mock() - mock_send_command.reset_mock() test_data = 'INPT' - test_log = '(127.0.0.1) Sending INPT command' + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is ' + '{state}'.format(state=STATUS_CODE[S_NOT_CONNECTED])), + call('(111.111.111.111) Sending {cmd} command'.format(cmd=test_data))] - # WHEN: get_input_source is called - pjlink.get_input_source() + # GIVEN: Test object and mocks + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - # THEN: log data and send_command should have been called - mock_log.debug.assert_called_once_with(test_log) - mock_send_command.assert_called_once_with(cmd=test_data) + # WHEN: get_input_source is called + pjlink.get_input_source() - @patch.object(pjlink_test, 'send_command') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_get_lamp_status(self, mock_log, mock_send_command): + # THEN: log data and send_command should have been called + mock_log.debug.assert_has_calls(log_debug_calls) + mock_send_command.assert_called_once_with(cmd=test_data) + + def test_projector_get_lamp_status(self): """ Test sending command to retrieve lamp(s) status """ - # GIVEN: Test object - pjlink = pjlink_test - mock_log.reset_mock() - mock_send_command.reset_mock() test_data = 'LAMP' - test_log = '(127.0.0.1) Sending LAMP command' + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is ' + '{state}'.format(state=STATUS_CODE[S_NOT_CONNECTED])), + call('(111.111.111.111) Sending {cmd} command'.format(cmd=test_data))] - # WHEN: get_lamp_status is called - pjlink.get_lamp_status() + # GIVEN: Test object and mocks + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - # THEN: log data and send_command should have been called - mock_log.debug.assert_called_once_with(test_log) - mock_send_command.assert_called_once_with(cmd=test_data) + # WHEN: get_input_source is called + pjlink.get_lamp_status() - @patch.object(pjlink_test, 'send_command') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_get_manufacturer(self, mock_log, mock_send_command): + # THEN: log data and send_command should have been called + mock_log.debug.assert_has_calls(log_debug_calls) + mock_send_command.assert_called_once_with(cmd=test_data) + + def test_projector_get_manufacturer(self): """ Test sending command to retrieve manufacturer name """ - # GIVEN: Test object - pjlink = pjlink_test - mock_log.reset_mock() - mock_send_command.reset_mock() test_data = 'INF1' - test_log = '(127.0.0.1) Sending INF1 command' + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is ' + '{state}'.format(state=STATUS_CODE[S_NOT_CONNECTED])), + call('(111.111.111.111) Sending {cmd} command'.format(cmd=test_data))] - # WHEN: get_manufacturer is called - pjlink.get_manufacturer() + # GIVEN: Test object and mocks + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - # THEN: log data and send_command should have been called - mock_log.debug.assert_called_once_with(test_log) - mock_send_command.assert_called_once_with(cmd=test_data) + # WHEN: get_input_source is called + pjlink.get_manufacturer() - @patch.object(pjlink_test, 'send_command') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_get_model(self, mock_log, mock_send_command): + # THEN: log data and send_command should have been called + mock_log.debug.assert_has_calls(log_debug_calls) + mock_send_command.assert_called_once_with(cmd=test_data) + + def test_projector_get_model(self): """ Test sending command to get model information """ - # GIVEN: Test object - pjlink = pjlink_test - mock_log.reset_mock() - mock_send_command.reset_mock() test_data = 'INF2' - test_log = '(127.0.0.1) Sending INF2 command' + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is ' + '{state}'.format(state=STATUS_CODE[S_NOT_CONNECTED])), + call('(111.111.111.111) Sending {cmd} command'.format(cmd=test_data))] - # WHEN: get_model is called - pjlink.get_model() + # GIVEN: Test object and mocks + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - # THEN: log data and send_command should have been called - mock_log.debug.assert_called_once_with(test_log) - mock_send_command.assert_called_once_with(cmd=test_data) + # WHEN: get_input_source is called + pjlink.get_model() - @patch.object(pjlink_test, 'send_command') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_get_name(self, mock_log, mock_send_command): + # THEN: log data and send_command should have been called + mock_log.debug.assert_has_calls(log_debug_calls) + mock_send_command.assert_called_once_with(cmd=test_data) + + def test_projector_get_name(self): """ Test sending command to get user-assigned name """ - # GIVEN: Test object - pjlink = pjlink_test - mock_log.reset_mock() - mock_send_command.reset_mock() test_data = 'NAME' - test_log = '(127.0.0.1) Sending NAME command' + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is ' + '{state}'.format(state=STATUS_CODE[S_NOT_CONNECTED])), + call('(111.111.111.111) Sending {cmd} command'.format(cmd=test_data))] - # WHEN: get_name is called - pjlink.get_name() + # GIVEN: Test object and mocks + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - # THEN: log data and send_command should have been called - mock_log.debug.assert_called_once_with(test_log) - mock_send_command.assert_called_once_with(cmd=test_data) + # WHEN: get_input_source is called + pjlink.get_name() - @patch.object(pjlink_test, 'send_command') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_get_other_info(self, mock_log, mock_send_command): + # THEN: log data and send_command should have been called + mock_log.debug.assert_has_calls(log_debug_calls) + mock_send_command.assert_called_once_with(cmd=test_data) + + def test_projector_get_other_info(self): """ Test sending command to retrieve other information """ - # GIVEN: Test object - pjlink = pjlink_test - mock_log.reset_mock() - mock_send_command.reset_mock() test_data = 'INFO' - test_log = '(127.0.0.1) Sending INFO command' + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is ' + '{state}'.format(state=STATUS_CODE[S_NOT_CONNECTED])), + call('(111.111.111.111) Sending {cmd} command'.format(cmd=test_data))] - # WHEN: get_other_info is called - pjlink.get_other_info() + # GIVEN: Test object and mocks + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - # THEN: log data and send_command should have been called - mock_log.debug.assert_called_once_with(test_log) - mock_send_command.assert_called_once_with(cmd=test_data) + # WHEN: get_input_source is called + pjlink.get_other_info() - @patch.object(pjlink_test, 'send_command') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_get_power_status(self, mock_log, mock_send_command): + # THEN: log data and send_command should have been called + mock_log.debug.assert_has_calls(log_debug_calls) + mock_send_command.assert_called_once_with(cmd=test_data) + + def test_projector_get_power_status(self): """ Test sending command to retrieve current power state """ - # GIVEN: Test object - pjlink = pjlink_test - mock_log.reset_mock() - mock_send_command.reset_mock() test_data = 'POWR' - test_log = '(127.0.0.1) Sending POWR command' + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is ' + '{state}'.format(state=STATUS_CODE[S_NOT_CONNECTED])), + call('(111.111.111.111) Sending {cmd} command'.format(cmd=test_data))] - # WHEN: get_power_status called - pjlink.get_power_status() + # GIVEN: Test object and mocks + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - # THEN: log data and send_command should have been called - mock_log.debug.assert_called_once_with(test_log) - mock_send_command.assert_called_once_with(cmd=test_data) + # WHEN: get_input_source is called + pjlink.get_power_status() - def test_projector_get_status_error(self): - """ - Test to check returned information for error code - """ - # GIVEN: Test object - pjlink = pjlink_test - test_string = 'E_SOCKET_ADDRESS_NOT_AVAILABLE' - test_message = 'The address specified to socket.bind() does not belong to the host' - - # WHEN: get_status called - string, message = pjlink._get_status(status=E_SOCKET_ADDRESS_NOT_AVAILABLE) - - # THEN: Proper strings should have been returned - self.assertEqual(string, test_string, 'Code as string should have been returned') - self.assertEqual(message, test_message, 'Description of code should have been returned') + # THEN: log data and send_command should have been called + mock_log.debug.assert_has_calls(log_debug_calls) + mock_send_command.assert_called_once_with(cmd=test_data) def test_projector_get_status_invalid(self): """ Test to check returned information for error code """ # GIVEN: Test object - pjlink = pjlink_test - test_string = 'Test string since get_status will only work with int' - test_message = 'Invalid status code' + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + test_string = 'NaN test' # WHEN: get_status called - string, message = pjlink._get_status(status=test_string) + code, message = pjlink._get_status(status=test_string) - # THEN: Proper strings should have been returned - self.assertEqual(string, -1, 'Should have returned -1 as a bad status check') - self.assertEqual(message, test_message, 'Error message should have been returned') + # THEN: Proper data should have been returned + assert code == -1, 'Should have returned -1 as a bad status check' + assert message is None, 'Invalid code type should have returned None for message' - def test_projector_get_status_status(self): + def test_projector_get_status_valid(self): """ Test to check returned information for status codes """ # GIVEN: Test object - pjlink = pjlink_test - test_string = 'S_NOT_CONNECTED' - test_message = 'Not connected' + test_message = 'Not Connected' + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) # WHEN: get_status called - string, message = pjlink._get_status(status=S_NOT_CONNECTED) + code, message = pjlink._get_status(status=S_NOT_CONNECTED) # THEN: Proper strings should have been returned - self.assertEqual(string, test_string, 'Code as string should have been returned') - self.assertEqual(message, test_message, 'Description of code should have been returned') + assert code == 'S_NOT_CONNECTED', 'Code returned should have been the same code that was sent' + assert message == test_message, 'Description of code should have been returned' def test_projector_get_status_unknown(self): """ Test to check returned information for unknown code """ # GIVEN: Test object - pjlink = pjlink_test - test_string = 999999 - test_message = 'Unknown status' + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) # WHEN: get_status called - string, message = pjlink._get_status(status=test_string) + code, message = pjlink._get_status(status=9999) # THEN: Proper strings should have been returned - self.assertEqual(string, test_string, 'Received code should have been returned') - self.assertEqual(message, test_message, 'Unknown status string should have been returned') + assert code is None, 'Code returned should have been the same code that was sent' + assert message is None, 'Should have returned None as message' def test_projector_process_inf1(self): """ Test saving INF1 data (manufacturer) """ - # GIVEN: Test object - pjlink = pjlink_test - pjlink.manufacturer = None test_data = 'TEst INformation MultiCase' + # GIVEN: Test object + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.manufacturer = None + # WHEN: process_inf called with test data pjlink.process_inf1(data=test_data) # THEN: Data should be saved - self.assertEqual(pjlink.manufacturer, test_data, 'Test data should have been saved') + assert pjlink.manufacturer == test_data, 'Test data should have been saved' def test_projector_process_inf2(self): """ Test saving INF2 data (model) """ - # GIVEN: Test object - pjlink = pjlink_test - pjlink.model = None test_data = 'TEst moDEl MultiCase' + # GIVEN: Test object + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.model = None + # WHEN: process_inf called with test data pjlink.process_inf2(data=test_data) # THEN: Data should be saved - self.assertEqual(pjlink.model, test_data, 'Test data should have been saved') + assert pjlink.model == test_data, 'Test data should have been saved' def test_projector_process_info(self): """ Test saving INFO data (other information) """ - # GIVEN: Test object - pjlink = pjlink_test - pjlink.other_info = None test_data = 'TEst ExtrANEous MultiCase INformatoin that MFGR might Set' + # GIVEN: Test object + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.other_info = None + # WHEN: process_inf called with test data pjlink.process_info(data=test_data) # THEN: Data should be saved - self.assertEqual(pjlink.other_info, test_data, 'Test data should have been saved') + assert pjlink.other_info == test_data, 'Test data should have been saved' - @patch.object(pjlink_test, 'projectorUpdateIcons') - def test_projector_process_avmt_bad_data(self, mock_UpdateIcons): + def test_projector_process_avmt_bad_data(self): """ Test avmt bad data fail """ # GIVEN: Test object - pjlink = pjlink_test - pjlink.shutter = True - pjlink.mute = True + with patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.shutter = True + pjlink.mute = True - # WHEN: Called with an invalid setting - pjlink.process_avmt('36') + # WHEN: Called with an invalid setting + pjlink.process_avmt('36') - # THEN: Shutter should be closed and mute should be True - self.assertTrue(pjlink.shutter, 'Shutter should changed') - self.assertTrue(pjlink.mute, 'Audio should not have changed') - self.assertFalse(mock_UpdateIcons.emit.called, 'Update icons should NOT have been called') + # THEN: Shutter should be closed and mute should be True + assert pjlink.shutter is True, 'Shutter should changed' + assert pjlink.mute is True, 'Audio should not have changed' + assert mock_UpdateIcons.emit.called is False, 'Update icons should NOT have been called' - @patch.object(pjlink_test, 'projectorUpdateIcons') - def test_projector_process_avmt_closed_muted(self, mock_UpdateIcons): + def test_projector_process_avmt_closed_muted(self): """ Test avmt status shutter closed and mute off """ # GIVEN: Test object - pjlink = pjlink_test - pjlink.shutter = False - pjlink.mute = False + with patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.shutter = False + pjlink.mute = False - # WHEN: Called with setting shutter to closed and mute on - pjlink.process_avmt('31') + # WHEN: Called with setting shutter to closed and mute on + pjlink.process_avmt('31') - # THEN: Shutter should be closed and mute should be True - self.assertTrue(pjlink.shutter, 'Shutter should have been set to closed') - self.assertTrue(pjlink.mute, 'Audio should be muted') - self.assertTrue(mock_UpdateIcons.emit.called, 'Update icons should have been called') + # THEN: Shutter should be closed and mute should be True + assert pjlink.shutter is True, 'Shutter should have been set to closed' + assert pjlink.mute is True, 'Audio should be muted' + assert mock_UpdateIcons.emit.called is True, 'Update icons should have been called' - @patch.object(pjlink_test, 'projectorUpdateIcons') - def test_projector_process_avmt_shutter_closed(self, mock_UpdateIcons): + def test_projector_process_avmt_shutter_closed(self): """ Test avmt status shutter closed and audio unchanged """ # GIVEN: Test object - pjlink = pjlink_test - pjlink.shutter = False - pjlink.mute = True + with patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.shutter = False + pjlink.mute = True - # WHEN: Called with setting shutter closed and mute off - pjlink.process_avmt('11') + # WHEN: Called with setting shutter closed and mute off + pjlink.process_avmt('11') - # THEN: Shutter should be True and mute should be False - self.assertTrue(pjlink.shutter, 'Shutter should have been set to closed') - self.assertTrue(pjlink.mute, 'Audio should not have changed') - self.assertTrue(mock_UpdateIcons.emit.called, 'Update icons should have been called') + # THEN: Shutter should be True and mute should be False + assert pjlink.shutter is True, 'Shutter should have been set to closed' + assert pjlink.mute is True, 'Audio should not have changed' + assert mock_UpdateIcons.emit.called is True, 'Update icons should have been called' - @patch.object(pjlink_test, 'projectorUpdateIcons') - def test_projector_process_avmt_audio_muted(self, mock_UpdateIcons): + def test_projector_process_avmt_audio_muted(self): """ Test avmt status shutter unchanged and mute on """ # GIVEN: Test object - pjlink = pjlink_test - pjlink.shutter = True - pjlink.mute = False + with patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.shutter = True + pjlink.mute = False - # WHEN: Called with setting shutter closed and mute on - pjlink.process_avmt('21') + # WHEN: Called with setting shutter closed and mute on + pjlink.process_avmt('21') - # THEN: Shutter should be closed and mute should be True - self.assertTrue(pjlink.shutter, 'Shutter should not have changed') - self.assertTrue(pjlink.mute, 'Audio should be off') - self.assertTrue(mock_UpdateIcons.emit.called, 'Update icons should have been called') + # THEN: Shutter should be closed and mute should be True + assert pjlink.shutter is True, 'Shutter should not have changed' + assert pjlink.mute is True, 'Audio should be off' + assert mock_UpdateIcons.emit.called is True, 'Update icons should have been called' - @patch.object(pjlink_test, 'projectorUpdateIcons') - def test_projector_process_avmt_open_unmuted(self, mock_UpdateIcons): + def test_projector_process_avmt_open_unmuted(self): """ Test avmt status shutter open and mute off """ # GIVEN: Test object - pjlink = pjlink_test - pjlink.shutter = True - pjlink.mute = True + with patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.shutter = True + pjlink.mute = True - # WHEN: Called with setting shutter to closed and mute on - pjlink.process_avmt('30') + # WHEN: Called with setting shutter to closed and mute on + pjlink.process_avmt('30') - # THEN: Shutter should be closed and mute should be True - self.assertFalse(pjlink.shutter, 'Shutter should have been set to open') - self.assertFalse(pjlink.mute, 'Audio should be on') - self.assertTrue(mock_UpdateIcons.emit.called, 'Update icons should have been called') + # THEN: Shutter should be closed and mute should be True + assert pjlink.shutter is False, 'Shutter should have been set to open' + assert pjlink.mute is False, 'Audio should be on' + assert mock_UpdateIcons.emit.called is True, 'Update icons should have been called' def test_projector_process_clss_one(self): """ Test class 1 sent from projector """ # GIVEN: Test object - pjlink = pjlink_test + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) # WHEN: Process class response pjlink.process_clss('1') # THEN: Projector class should be set to 1 - self.assertEqual(pjlink.pjlink_class, '1', - 'Projector should have set class=1') + assert pjlink.pjlink_class == '1', 'Projector should have set class=1' def test_projector_process_clss_two(self): """ Test class 2 sent from projector """ # GIVEN: Test object - pjlink = pjlink_test + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) # WHEN: Process class response pjlink.process_clss('2') # THEN: Projector class should be set to 1 - self.assertEqual(pjlink.pjlink_class, '2', - 'Projector should have set class=2') + assert pjlink.pjlink_class == '2', 'Projector should have set class=2' - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_process_clss_invalid_nan(self, mock_log): + def test_projector_process_clss_invalid_nan(self): """ Test CLSS reply has no class number """ + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is ' + '{state}'.format(state=STATUS_CODE[S_NOT_CONNECTED])), + call('(111.111.111.111) Setting pjlink_class for this projector to "1"')] + log_error_calls = [call('(111.111.111.111) NAN CLSS version reply "Z" - defaulting to class "1"')] + # GIVEN: Test object - pjlink = pjlink_test + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - # WHEN: Process invalid reply - pjlink.process_clss('Z') - log_text = '(127.0.0.1) NAN CLSS version reply "Z" - defaulting to class "1"' + # WHEN: Process invalid reply + pjlink.process_clss('Z') - # THEN: Projector class should be set with default value - self.assertEqual(pjlink.pjlink_class, '1', - 'Non-standard class reply should have set class=1') - mock_log.error.assert_called_once_with(log_text) + # THEN: Projector class should be set with default value + assert pjlink.pjlink_class == '1', 'Invalid NaN class reply should have set class=1' + mock_log.error.assert_has_calls(log_error_calls) + mock_log.debug.assert_has_calls(log_debug_calls) - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_process_clss_invalid_no_version(self, mock_log): + def test_projector_process_clss_invalid_no_version(self): """ Test CLSS reply has no class number """ + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is ' + '{state}'.format(state=STATUS_CODE[S_NOT_CONNECTED])), + call('(111.111.111.111) Setting pjlink_class for this projector to "1"')] + log_error_calls = [call('(111.111.111.111) No numbers found in class version reply "Invalid" ' + '- defaulting to class "1"')] + # GIVEN: Test object - pjlink = pjlink_test + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - # WHEN: Process invalid reply - pjlink.process_clss('Invalid') - log_text = '(127.0.0.1) No numbers found in class version reply "Invalid" - defaulting to class "1"' + # WHEN: Process invalid reply + pjlink.process_clss('Invalid') - # THEN: Projector class should be set with default value - self.assertEqual(pjlink.pjlink_class, '1', - 'Non-standard class reply should have set class=1') - mock_log.error.assert_called_once_with(log_text) + # THEN: Projector class should be set with default value + assert pjlink.pjlink_class == '1', 'Invalid class reply should have set class=1' + mock_log.error.assert_has_calls(log_error_calls) + mock_log.debug.assert_has_calls(log_debug_calls) def test_projector_process_erst_all_ok(self): """ - Test test_projector_process_erst_all_ok + Test to verify pjlink.projector_errors is set to None when no errors """ + chk_data = '0' * PJLINK_ERST_DATA['DATA_LENGTH'] + # GIVEN: Test object - pjlink = pjlink_test - chk_test = PJLINK_ERST_STATUS['OK'] - chk_param = chk_test * len(PJLINK_ERST_POSITIONS) + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) # WHEN: process_erst with no errors - pjlink.process_erst(chk_param) + pjlink.process_erst(chk_data) # THEN: PJLink instance errors should be None - self.assertIsNone(pjlink.projector_errors, 'projector_errors should have been set to None') + assert pjlink.projector_errors is None, 'projector_errors should have been set to None' - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_process_erst_data_invalid_length(self, mock_log): + def test_projector_process_erst_data_invalid_length(self): """ Test test_projector_process_erst_data_invalid_length """ + chk_data = '0' * (PJLINK_ERST_DATA['DATA_LENGTH'] + 1) + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is ' + '{state}'.format(state=STATUS_CODE[S_NOT_CONNECTED]))] + log_warn_calls = [call('111.111.111.111) Invalid error status response "0000000": ' + 'length != {chk}'.format(chk=PJLINK_ERST_DATA['DATA_LENGTH']))] + # GIVEN: Test object - pjlink = pjlink_test - pjlink.projector_errors = None - log_text = '127.0.0.1) Invalid error status response "11111111": length != 6' + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.projector_errors = None - # WHEN: process_erst called with invalid data (too many values - pjlink.process_erst('11111111') + # WHEN: process_erst called with invalid data (too many values + pjlink.process_erst(chk_data) - # THEN: pjlink.projector_errors should be empty and warning logged - self.assertIsNone(pjlink.projector_errors, 'There should be no errors') - self.assertTrue(mock_log.warning.called, 'Warning should have been logged') - mock_log.warning.assert_called_once_with(log_text) + # THEN: pjlink.projector_errors should be empty and warning logged + assert pjlink.projector_errors is None, 'There should be no errors' + mock_log.debug.assert_has_calls(log_debug_calls) + mock_log.warning.assert_has_calls(log_warn_calls) - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_process_erst_data_invalid_nan(self, mock_log): + def test_projector_process_erst_data_invalid_nan(self): """ Test test_projector_process_erst_data_invalid_nan """ + chk_data = 'Z' + ('0' * (PJLINK_ERST_DATA['DATA_LENGTH'] - 1)) + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is ' + '{state}'.format(state=STATUS_CODE[S_NOT_CONNECTED]))] + log_warn_calls = [call('(111.111.111.111) Invalid error status response "Z00000"')] + # GIVEN: Test object - pjlink = pjlink_test - pjlink.projector_errors = None - log_text = '(127.0.0.1) Invalid error status response "1111Z1"' + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.projector_errors = None - # WHEN: process_erst called with invalid data (too many values - pjlink.process_erst('1111Z1') + # WHEN: process_erst called with invalid data (too many values + pjlink.process_erst(chk_data) - # THEN: pjlink.projector_errors should be empty and warning logged - self.assertIsNone(pjlink.projector_errors, 'There should be no errors') - self.assertTrue(mock_log.warning.called, 'Warning should have been logged') - mock_log.warning.assert_called_once_with(log_text) + # THEN: pjlink.projector_errors should be empty and warning logged + assert pjlink.projector_errors is None, 'There should be no errors' + mock_log.debug.assert_has_calls(log_debug_calls) + mock_log.warning.assert_has_calls(log_warn_calls) def test_projector_process_erst_all_warn(self): """ Test test_projector_process_erst_all_warn """ + chk_data = '{fan}{lamp}{temp}{cover}{filt}{other}'.format(fan=PJLINK_ERST_STATUS[E_WARN], + lamp=PJLINK_ERST_STATUS[E_WARN], + temp=PJLINK_ERST_STATUS[E_WARN], + cover=PJLINK_ERST_STATUS[E_WARN], + filt=PJLINK_ERST_STATUS[E_WARN], + other=PJLINK_ERST_STATUS[E_WARN]) + chk_test = {'Fan': E_WARN, + 'Lamp': E_WARN, + 'Temperature': E_WARN, + 'Cover': E_WARN, + 'Filter': E_WARN, + 'Other': E_WARN} + # GIVEN: Test object - pjlink = pjlink_test - chk_test = PJLINK_ERST_STATUS[E_WARN] - chk_string = ERROR_STRING[E_WARN] - chk_param = chk_test * len(PJLINK_ERST_POSITIONS) + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.projector_errors = None # WHEN: process_erst with status set to WARN - pjlink.process_erst(chk_param) + pjlink.process_erst(chk_data) # THEN: PJLink instance errors should match chk_value - for chk in pjlink.projector_errors: - self.assertEqual(pjlink.projector_errors[chk], chk_string, - 'projector_errors["{chk}"] should have been set to "{err}"'.format(chk=chk, - err=chk_string)) + assert pjlink.projector_errors == chk_test, 'Projector errors should be all E_WARN' def test_projector_process_erst_all_error(self): """ Test test_projector_process_erst_all_error """ + chk_data = '{fan}{lamp}{temp}{cover}{filt}{other}'.format(fan=PJLINK_ERST_STATUS[E_ERROR], + lamp=PJLINK_ERST_STATUS[E_ERROR], + temp=PJLINK_ERST_STATUS[E_ERROR], + cover=PJLINK_ERST_STATUS[E_ERROR], + filt=PJLINK_ERST_STATUS[E_ERROR], + other=PJLINK_ERST_STATUS[E_ERROR]) + chk_test = {'Fan': E_ERROR, + 'Lamp': E_ERROR, + 'Temperature': E_ERROR, + 'Cover': E_ERROR, + 'Filter': E_ERROR, + 'Other': E_ERROR} + # GIVEN: Test object - pjlink = pjlink_test - chk_test = PJLINK_ERST_STATUS[E_ERROR] - chk_string = ERROR_STRING[E_ERROR] - chk_param = chk_test * len(PJLINK_ERST_POSITIONS) + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.projector_errors = None # WHEN: process_erst with status set to WARN - pjlink.process_erst(chk_param) + pjlink.process_erst(chk_data) # THEN: PJLink instance errors should match chk_value - for chk in pjlink.projector_errors: - self.assertEqual(pjlink.projector_errors[chk], chk_string, - 'projector_errors["{chk}"] should have been set to "{err}"'.format(chk=chk, - err=chk_string)) + assert pjlink.projector_errors == chk_test, 'Projector errors should be all E_ERROR' def test_projector_process_erst_warn_cover_only(self): """ Test test_projector_process_erst_warn_cover_only """ + chk_data = '{fan}{lamp}{temp}{cover}{filt}{other}'.format(fan=PJLINK_ERST_STATUS[S_OK], + lamp=PJLINK_ERST_STATUS[S_OK], + temp=PJLINK_ERST_STATUS[S_OK], + cover=PJLINK_ERST_STATUS[E_WARN], + filt=PJLINK_ERST_STATUS[S_OK], + other=PJLINK_ERST_STATUS[S_OK]) + chk_test = {'Cover': E_WARN} + # GIVEN: Test object - pjlink = pjlink_test - chk_test = PJLINK_ERST_STATUS[E_WARN] - chk_string = ERROR_STRING[E_WARN] - pos = PJLINK_ERST_DATA['COVER'] - build_chk = [] - for check in range(0, len(PJLINK_ERST_POSITIONS)): - if check == pos: - build_chk.append(chk_test) - else: - build_chk.append(PJLINK_ERST_STATUS['OK']) - chk_param = ''.join(build_chk) + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.projector_errors = None - # WHEN: process_erst with cover only set to WARN and all others set to OK - pjlink.process_erst(chk_param) + # WHEN: process_erst with status set to WARN + pjlink.process_erst(chk_data) - # THEN: Only COVER should have an error - self.assertEqual(len(pjlink.projector_errors), 1, 'projector_errors should only have 1 error') - self.assertTrue(('Cover' in pjlink.projector_errors), 'projector_errors should have an error for "Cover"') - self.assertEqual(pjlink.projector_errors['Cover'], - chk_string, - 'projector_errors["Cover"] should have error "{err}"'.format(err=chk_string)) + # THEN: PJLink instance errors should match only cover warning + assert 1 == len(pjlink.projector_errors), 'There should only be 1 error listed in projector_errors' + assert 'Cover' in pjlink.projector_errors, '"Cover" should be the only error listed' + assert pjlink.projector_errors['Cover'] == E_WARN, '"Cover" should have E_WARN listed as error' + assert chk_test == pjlink.projector_errors, 'projector_errors should match test errors' - def test_projector_process_inpt(self): + def test_projector_process_inpt_valid(self): """ Test input source status shows current input """ + log_debug_calls = [call('(111.111.111.111) reset_information() connect status is S_NOT_CONNECTED')] + chk_source_available = ['11', '12', '21', '22', '31', '32'] + # GIVEN: Test object - pjlink = pjlink_test - pjlink.source = '0' + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.source_available = chk_source_available + pjlink.source = '11' - # WHEN: Called with input source - pjlink.process_inpt('1') + # WHEN: Called with input source + pjlink.process_inpt('21') - # THEN: Input selected should reflect current input - self.assertEqual(pjlink.source, '1', 'Input source should be set to "1"') + # THEN: Input selected should reflect current input + assert pjlink.source == '21', 'Input source should be set to "21"' + mock_log.debug.assert_has_calls(log_debug_calls) - @patch.object(pjlink_test, 'projectorUpdateIcons') - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_process_inst(self, mock_log, mock_UpdateIcons): + def test_projector_process_input_not_in_list(self): + """ + Test setting input outside of available inputs + + TODO: Future test + """ + pass + + def test_projector_process_input_not_in_default(self): + """ + Test setting input with no sources available + TODO: Future test + """ + pass + + def test_projector_process_input_invalid(self): + """ + Test setting input with an invalid value + + TODO: Future test + """ + + def test_projector_process_inst_class_1(self): """ Test saving video source available information """ + log_debug_calls = [call('(111.111.111.111) Setting projector sources_available to ' + '"[\'11\', \'12\', \'21\', \'22\', \'31\', \'32\']"')] + chk_data = '21 12 11 22 32 31' # Although they should already be sorted, use unsorted to verify method + chk_test = ['11', '12', '21', '22', '31', '32'] + # GIVEN: Test object - pjlink = pjlink_test - pjlink.source_available = [] - test_data = '21 10 30 31 11 20' - test_saved = ["10", "11", "20", "21", "30", "31"] - log_data = "(127.0.0.1) Setting projector sources_available to " \ - "\"['10', '11', '20', '21', '30', '31']\"" - mock_UpdateIcons.reset_mock() - mock_log.reset_mock() + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.source_available = [] - # WHEN: process_inst called with test data - pjlink.process_inst(data=test_data) + # WHEN: process_inst called with test data + pjlink.process_inst(data=chk_data) - # THEN: Data should have been sorted and saved properly - self.assertEqual(pjlink.source_available, test_saved, "Sources should have been sorted and saved") - mock_log.debug.assert_called_once_with(log_data) - self.assertTrue(mock_UpdateIcons.emit.called, 'Update Icons should have been called') + # THEN: Data should have been sorted and saved properly + assert pjlink.source_available == chk_test, "Sources should have been sorted and saved" + mock_log.debug.assert_has_calls(log_debug_calls) - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_process_lamp_invalid(self, mock_log): + def test_projector_process_lamp_invalid(self): """ Test status multiple lamp on/off and hours """ + log_data = [call('(111.111.111.111) process_lamp(): Invalid data "11111 1 22222 0 333A3 1"')] + # GIVEN: Test object - pjlink = pjlink_test - pjlink.lamp = [{'Hours': 00000, 'On': True}, - {'Hours': 11111, 'On': False}] - log_data = '(127.0.0.1) process_lamp(): Invalid data "11111 1 22222 0 333A3 1"' + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.lamp = [{'Hours': 00000, 'On': True}, + {'Hours': 11111, 'On': False}] - # WHEN: Call process_command with invalid lamp data - pjlink.process_lamp('11111 1 22222 0 333A3 1') + # WHEN: Call process_command with invalid lamp data + pjlink.process_lamp('11111 1 22222 0 333A3 1') - # THEN: lamps should not have changed - self.assertEqual(len(pjlink.lamp), 2, - 'Projector should have kept 2 lamps specified') - self.assertEqual(pjlink.lamp[0]['On'], True, - 'Lamp 1 power status should have been set to TRUE') - self.assertEqual(pjlink.lamp[0]['Hours'], 00000, - 'Lamp 1 hours should have been left at 00000') - self.assertEqual(pjlink.lamp[1]['On'], False, - 'Lamp 2 power status should have been set to FALSE') - self.assertEqual(pjlink.lamp[1]['Hours'], 11111, - 'Lamp 2 hours should have been left at 11111') - mock_log.warning.assert_called_once_with(log_data) + # THEN: lamps should not have changed + assert 2 == len(pjlink.lamp), 'Projector should have kept 2 lamps specified' + assert pjlink.lamp[0]['On'] is True, 'Lamp 1 power status should have stayed TRUE' + assert 00000 == pjlink.lamp[0]['Hours'], 'Lamp 1 hours should have been left at 00000' + assert pjlink.lamp[1]['On'] is False, 'Lamp 2 power status should have stayed FALSE' + assert 11111 == pjlink.lamp[1]['Hours'], 'Lamp 2 hours should have been left at 11111' + mock_log.warning.assert_has_calls(log_data) def test_projector_process_lamp_multiple(self): """ Test status multiple lamp on/off and hours """ # GIVEN: Test object - pjlink = pjlink_test - pjlink.lamps = [] + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.lamp = [] - # WHEN: Call process_command with lamp data + # WHEN: Call process_command with invalid lamp data pjlink.process_lamp('11111 1 22222 0 33333 1') # THEN: Lamp should have been set with proper lamp status - self.assertEqual(len(pjlink.lamp), 3, - 'Projector should have 3 lamps specified') - self.assertEqual(pjlink.lamp[0]['On'], True, - 'Lamp 1 power status should have been set to TRUE') - self.assertEqual(pjlink.lamp[0]['Hours'], 11111, - 'Lamp 1 hours should have been set to 11111') - self.assertEqual(pjlink.lamp[1]['On'], False, - 'Lamp 2 power status should have been set to FALSE') - self.assertEqual(pjlink.lamp[1]['Hours'], 22222, - 'Lamp 2 hours should have been set to 22222') - self.assertEqual(pjlink.lamp[2]['On'], True, - 'Lamp 3 power status should have been set to TRUE') - self.assertEqual(pjlink.lamp[2]['Hours'], 33333, - 'Lamp 3 hours should have been set to 33333') + assert 3 == len(pjlink.lamp), 'Projector should have 3 lamps specified' + assert pjlink.lamp[0]['On'] is True, 'Lamp 1 power status should have been set to TRUE' + assert 11111 == pjlink.lamp[0]['Hours'], 'Lamp 1 hours should have been set to 11111' + assert pjlink.lamp[1]['On'] is False, 'Lamp 2 power status should have been set to FALSE' + assert 22222 == pjlink.lamp[1]['Hours'], 'Lamp 2 hours should have been set to 22222' + assert pjlink.lamp[2]['On'] is True, 'Lamp 3 power status should have been set to TRUE' + assert 33333 == pjlink.lamp[2]['Hours'], 'Lamp 3 hours should have been set to 33333' def test_projector_process_lamp_single(self): """ Test status lamp on/off and hours """ - # GIVEN: Test object - pjlink = pjlink_test - pjlink.lamps = [] - # WHEN: Call process_command with lamp data + # GIVEN: Test object + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.lamp = [] + + # WHEN: Call process_command with invalid lamp data pjlink.process_lamp('22222 1') # THEN: Lamp should have been set with status=ON and hours=22222 - self.assertEqual(pjlink.lamp[0]['On'], True, - 'Lamp power status should have been set to TRUE') - self.assertEqual(pjlink.lamp[0]['Hours'], 22222, - 'Lamp hours should have been set to 22222') + assert 1 == len(pjlink.lamp), 'Projector should have only 1 lamp' + assert pjlink.lamp[0]['On'] is True, 'Lamp power status should have been set to TRUE' + assert 22222 == pjlink.lamp[0]['Hours'], 'Lamp hours should have been set to 22222' - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_process_name(self, mock_log): + def test_projector_process_name(self): """ Test saving NAME data from projector """ - # GIVEN: Test data - pjlink = pjlink_test - test_data = "Some Name the End-User Set IN Projector" - test_log = '(127.0.0.1) Setting projector PJLink name to "Some Name the End-User Set IN Projector"' - mock_log.reset_mock() + chk_data = "Some Name the End-User Set IN Projector" + log_debug_calls = [call('(111.111.111.111) Setting projector PJLink name to ' + '"Some Name the End-User Set IN Projector"')] - # WHEN: process_name called with test data - pjlink.process_name(data=test_data) + # GIVEN: Test object + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) - # THEN: name should be set and logged - self.assertEqual(pjlink.pjlink_name, test_data, 'Name test data should have been saved') - mock_log.debug.assert_called_once_with(test_log) + # WHEN: process_name called with test data + pjlink.process_name(data=chk_data) - @patch.object(pjlink_test, 'projectorUpdateIcons') - @patch.object(pjlink_test, 'send_command') - @patch.object(pjlink_test, 'change_status') - def test_projector_process_powr_on(self, - mock_change_status, - mock_send_command, - mock_UpdateIcons): + # THEN: name should be set and logged + assert pjlink.pjlink_name == chk_data, 'Name test data should have been saved' + mock_log.debug.assert_has_calls(log_debug_calls) + + def test_projector_process_powr_on(self): """ Test status power to ON """ - # GIVEN: Test object and preset - pjlink = pjlink_test - pjlink.power = S_STANDBY - test_data = PJLINK_POWR_STATUS[S_ON] + # GIVEN: Test object + with patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'change_status') as mock_change_status, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons: - # WHEN: Call process_command with turn power on command - pjlink.process_command(cmd='POWR', data=test_data) + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.power = S_STANDBY - # THEN: Power should be set to ON - self.assertEqual(pjlink.power, S_ON, 'Power should have been set to ON') - mock_send_command.assert_called_once_with('INST') - mock_change_status.assert_called_once_with(PJLINK_POWR_STATUS[test_data]) - self.assertEqual(mock_UpdateIcons.emit.called, True, 'projectorUpdateIcons should have been called') + # WHEN: process_name called with test data + pjlink.process_powr(data=PJLINK_POWR_STATUS[S_ON]) - @patch.object(pjlink_test, 'projectorUpdateIcons') - @patch.object(pjlink_test, 'send_command') - @patch.object(pjlink_test, 'change_status') - def test_projector_process_powr_invalid(self, - mock_change_status, - mock_send_command, - mock_UpdateIcons): + # THEN: Power should be set to ON + assert pjlink.power == S_ON, 'Power should have been set to ON' + assert mock_UpdateIcons.emit.called is True, 'projectorUpdateIcons should have been called' + mock_send_command.assert_called_once_with('INST') + mock_change_status.assert_called_once_with(S_ON) + + def test_projector_process_powr_invalid(self): """ Test process_powr invalid call """ - # GIVEN: Test object and preset - pjlink = pjlink_test - pjlink.power = S_STANDBY - test_data = '99' + log_warn_calls = [call('(111.111.111.111) Unknown power response: "99"')] - # WHEN: Call process_command with turn power on command - pjlink.process_command(cmd='POWR', data=test_data) + # GIVEN: Test object + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'change_status') as mock_change_status, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons: - # THEN: Power should be set to ON - self.assertEqual(pjlink.power, S_STANDBY, 'Power should not have changed') - self.assertFalse(mock_change_status.called, 'Change status should not have been called') - self.assertFalse(mock_send_command.called, 'send_command("INST") should not have been called') - self.assertFalse(mock_UpdateIcons.emit.called, 'projectorUpdateIcons should not have been called') + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.power = S_STANDBY - @patch.object(pjlink_test, 'projectorUpdateIcons') - @patch.object(pjlink_test, 'send_command') - @patch.object(pjlink_test, 'change_status') - def test_projector_process_powr_off(self, - mock_change_status, - mock_send_command, - mock_UpdateIcons): + # WHEN: process_name called with test data + pjlink.process_powr(data='99') + + # THEN: Power should be set to ON + assert pjlink.power == S_STANDBY, 'Power should not have changed' + assert mock_UpdateIcons.emit.called is False, 'projectorUpdateIcons() should not have been called' + mock_change_status.called is False, 'change_status() should not have been called' + mock_send_command.called is False, 'send_command() should not have been called' + mock_log.warning.assert_has_calls(log_warn_calls) + + def test_projector_process_powr_off(self): """ Test status power to STANDBY """ - # GIVEN: Test object and preset - pjlink = pjlink_test - pjlink.power = S_ON - test_data = PJLINK_POWR_STATUS[S_STANDBY] + # GIVEN: Test object + with patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'change_status') as mock_change_status, \ + patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons: - # WHEN: Call process_command with turn power on command - pjlink.process_command(cmd='POWR', data=test_data) + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.power = S_ON - # THEN: Power should be set to STANDBY - self.assertEqual(pjlink.power, S_STANDBY, 'Power should have been set to STANDBY') - self.assertEqual(mock_UpdateIcons.emit.called, True, 'projectorUpdateIcons should have been called') - mock_change_status.assert_called_once_with(PJLINK_POWR_STATUS[test_data]) - self.assertFalse(mock_send_command.called, "send_command['INST'] should not have been called") + # WHEN: process_name called with test data + pjlink.process_powr(data=PJLINK_POWR_STATUS[S_STANDBY]) + + # THEN: Power should be set to ON + assert pjlink.power == S_STANDBY, 'Power should have changed to S_STANDBY' + assert mock_UpdateIcons.emit.called is True, 'projectorUpdateIcons should have been called' + mock_change_status.called is True, 'change_status should have been called' + mock_send_command.called is False, 'send_command should not have been called' def test_projector_process_rfil_save(self): """ Test saving filter type """ - # GIVEN: Test object - pjlink = pjlink_test - pjlink.model_filter = None filter_model = 'Filter Type Test' + # GIVEN: Test object + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.model_filter = None + # WHEN: Filter model is received pjlink.process_rfil(data=filter_model) # THEN: Filter model number should be saved - self.assertEqual(pjlink.model_filter, filter_model, 'Filter type should have been saved') + assert pjlink.model_filter == filter_model, 'Filter type should have been saved' def test_projector_process_rfil_nosave(self): """ Test saving filter type previously saved """ - # GIVEN: Test object - pjlink = pjlink_test - pjlink.model_filter = 'Old filter type' filter_model = 'Filter Type Test' + log_warn_calls = [call('(111.111.111.111) Filter model already set'), + call('(111.111.111.111) Saved model: "Old filter type"'), + call('(111.111.111.111) New model: "Filter Type Test"')] - # WHEN: Filter model is received - pjlink.process_rfil(data=filter_model) + # GIVEN: Test object + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: - # THEN: Filter model number should be saved - self.assertNotEquals(pjlink.model_filter, filter_model, 'Filter type should NOT have been saved') + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.model_filter = 'Old filter type' + + # WHEN: Filter model is received + pjlink.process_rfil(data=filter_model) + + # THEN: Filter model number should be saved + assert pjlink.model_filter != filter_model, 'Filter type should NOT have been saved' + mock_log.warning.assert_has_calls(log_warn_calls) def test_projector_process_rlmp_save(self): """ Test saving lamp type """ # GIVEN: Test object - pjlink = pjlink_test + # GIVEN: Test object + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) pjlink.model_lamp = None lamp_model = 'Lamp Type Test' @@ -962,159 +1041,179 @@ class TestPJLinkCommands(TestCase): pjlink.process_rlmp(data=lamp_model) # THEN: Filter model number should be saved - self.assertEqual(pjlink.model_lamp, lamp_model, 'Lamp type should have been saved') + assert pjlink.model_lamp == lamp_model, 'Lamp type should have been saved' def test_projector_process_rlmp_nosave(self): """ Test saving lamp type previously saved """ + lamp_model = 'Lamp Type Test' + log_warn_calls = [call('(111.111.111.111) Lamp model already set'), + call('(111.111.111.111) Saved lamp: "Old lamp type"'), + call('(111.111.111.111) New lamp: "Lamp Type Test"')] + # GIVEN: Test object - pjlink = pjlink_test - pjlink.model_lamp = 'Old lamp type' - lamp_model = 'Filter Type Test' + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: - # WHEN: Filter model is received - pjlink.process_rlmp(data=lamp_model) + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.model_lamp = 'Old lamp type' - # THEN: Filter model number should be saved - self.assertNotEquals(pjlink.model_lamp, lamp_model, 'Lamp type should NOT have been saved') + # WHEN: Filter model is received + pjlink.process_rlmp(data=lamp_model) + + # THEN: Filter model number should be saved + assert pjlink.model_lamp != lamp_model, 'Lamp type should NOT have been saved' + mock_log.warning.assert_has_calls(log_warn_calls) def test_projector_process_snum_set(self): """ Test saving serial number from projector """ - # GIVEN: Test object - pjlink = pjlink_test - pjlink.serial_no = None + log_debug_calls = [call('(111.111.111.111) Setting projector serial number to "Test Serial Number"')] test_number = 'Test Serial Number' - # WHEN: No serial number is set and we receive serial number command - pjlink.process_snum(data=test_number) + # GIVEN: Test object + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: - # THEN: Serial number should be set - self.assertEqual(pjlink.serial_no, test_number, - 'Projector serial number should have been set') + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.serial_no = None + + # WHEN: No serial number is set and we receive serial number command + pjlink.process_snum(data=test_number) + + # THEN: Serial number should be set + assert pjlink.serial_no == test_number, 'Projector serial number should have been set' + mock_log.debug.assert_has_calls(log_debug_calls) def test_projector_process_snum_different(self): """ Test projector serial number different than saved serial number """ - # GIVEN: Test object - pjlink = pjlink_test - pjlink.serial_no = 'Previous serial number' + log_warn_calls = [call('(111.111.111.111) Projector serial number does not match saved serial number'), + call('(111.111.111.111) Saved: "Previous serial number"'), + call('(111.111.111.111) Received: "Test Serial Number"'), + call('(111.111.111.111) NOT saving serial number')] test_number = 'Test Serial Number' - # WHEN: No serial number is set and we receive serial number command - pjlink.process_snum(data=test_number) + # GIVEN: Test object + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.serial_no = 'Previous serial number' - # THEN: Serial number should be set - self.assertNotEquals(pjlink.serial_no, test_number, - 'Projector serial number should NOT have been set') + # WHEN: No serial number is set and we receive serial number command + pjlink.process_snum(data=test_number) - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_process_sver(self, mock_log): + # THEN: Serial number should be set + assert pjlink.serial_no != test_number, 'Projector serial number should NOT have been set' + mock_log.warning.assert_has_calls(log_warn_calls) + + def test_projector_process_sver(self): """ Test invalid software version information - too long """ - # GIVEN: Test object - pjlink = pjlink_test - pjlink.sw_version = None - pjlink.sw_version_received = None test_data = 'Test 1 Subtest 1' - test_log = '(127.0.0.1) Setting projector software version to "Test 1 Subtest 1"' - mock_log.reset_mock() + log_debug_calls = [call('(111.111.111.111) Setting projector software version to "Test 1 Subtest 1"')] - # WHEN: process_sver called with invalid data - pjlink.process_sver(data=test_data) + # GIVEN: Test object + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.sw_version = None + pjlink.sw_version_received = None - # THEN: Version information should not change - self.assertEqual(pjlink.sw_version, test_data, 'Software version should have been updated') - self.assertIsNone(pjlink.sw_version_received, 'Received software version should not have changed') - mock_log.debug.assert_called_once_with(test_log) + # WHEN: process_sver called with invalid data + pjlink.process_sver(data=test_data) - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_process_sver_changed(self, mock_log): + # THEN: Version information should not change + assert pjlink.sw_version == test_data, 'Software version should have been updated' + mock_log.debug.assert_has_calls(log_debug_calls) + + def test_projector_process_sver_changed(self): """ Test invalid software version information - Received different than saved """ - # GIVEN: Test object - pjlink = pjlink_test - test_data_new = 'Test 1 Subtest 2' test_data_old = 'Test 1 Subtest 1' - pjlink.sw_version = test_data_old - pjlink.sw_version_received = None - test_log = '(127.0.0.1) Saving new serial number as sw_version_received' - mock_log.reset_mock() + test_data_new = 'Test 1 Subtest 2' + log_warn_calls = [call('(111.111.111.111) Projector software version does not match saved software version'), + call('(111.111.111.111) Saved: "Test 1 Subtest 1"'), + call('(111.111.111.111) Received: "Test 1 Subtest 2"'), + call('(111.111.111.111) Updating software version')] - # WHEN: process_sver called with invalid data - pjlink.process_sver(data=test_data_new) + # GIVEN: Test object + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.sw_version = test_data_old - # THEN: Version information should not change - self.assertEqual(pjlink.sw_version, test_data_old, 'Software version should not have been updated') - self.assertEqual(pjlink.sw_version_received, test_data_new, - 'Received software version should have been changed') - self.assertEqual(mock_log.warning.call_count, 4, 'log.warn should have been called 4 times') - # There was 4 calls, but only the last one is checked with this method - mock_log.warning.assert_called_with(test_log) + # WHEN: process_sver called with invalid data + pjlink.process_sver(data=test_data_new) - @patch.object(openlp.core.projectors.pjlink, 'log') - def test_projector_process_sver_invalid(self, mock_log): + # THEN: Version information should not change + assert pjlink.sw_version == test_data_new, 'Software version should have changed' + mock_log.warning.assert_has_calls(log_warn_calls) + + def test_projector_process_sver_invalid(self): """ Test invalid software version information - too long """ - # GIVEN: Test object - pjlink = pjlink_test - pjlink.sw_version = None - pjlink.sw_version_received = None test_data = 'This is a test software version line that is too long based on PJLink version 2 specs' - test_log = "Invalid software version - too long" - mock_log.reset_mock() + log_warn_calls = [call('Invalid software version - too long')] - # WHEN: process_sver called with invalid data - pjlink.process_sver(data=test_data) + # GIVEN: Test object + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + pjlink.sw_version = None - # THEN: Version information should not change - self.assertIsNone(pjlink.sw_version, 'Software version should not have changed') - self.assertIsNone(pjlink.sw_version_received, 'Received software version should not have changed') - mock_log.warning.assert_called_once_with(test_log) + # WHEN: process_sver called with invalid data + pjlink.process_sver(data=test_data) + + # THEN: Version information should not change + assert pjlink.sw_version is None, 'Software version should not have changed' + assert pjlink.sw_version_received is None, 'Received software version should not have changed' + mock_log.warning.assert_has_calls(log_warn_calls) def test_projector_reset_information(self): """ Test reset_information() resets all information and stops timers """ - # GIVEN: Test object and test data - pjlink = pjlink_test - pjlink.power = S_ON - pjlink.pjlink_name = 'OPENLPTEST' - pjlink.manufacturer = 'PJLINK' - pjlink.model = '1' - pjlink.shutter = True - pjlink.mute = True - pjlink.lamp = True - pjlink.fan = True - pjlink.source_available = True - pjlink.other_info = 'ANOTHER TEST' - pjlink.send_queue = True - pjlink.send_busy = True + log_debug_calls = [call('(111.111.111.111): Calling timer.stop()'), + call('(111.111.111.111): Calling socket_timer.stop()')] - # WHEN: reset_information() is called - with patch.object(pjlink, 'timer') as mock_timer: - with patch.object(pjlink, 'socket_timer') as mock_socket_timer: + # GIVEN: Test object + with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log: + pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True) + # timer and socket_timer not available until instantiation, so mock here + with patch.object(pjlink, 'socket_timer') as mock_socket_timer, \ + patch.object(pjlink, 'timer') as mock_timer: + + pjlink.power = S_ON + pjlink.pjlink_name = 'OPENLPTEST' + pjlink.manufacturer = 'PJLINK' + pjlink.model = '1' + pjlink.shutter = True + pjlink.mute = True + pjlink.lamp = True + pjlink.fan = True + pjlink.source_available = True + pjlink.other_info = 'ANOTHER TEST' + pjlink.send_queue = True + pjlink.send_busy = True + + # WHEN: reset_information() is called pjlink.reset_information() - # THEN: All information should be reset and timers stopped - self.assertEqual(pjlink.power, S_OFF, 'Projector power should be OFF') - self.assertIsNone(pjlink.pjlink_name, 'Projector pjlink_name should be None') - self.assertIsNone(pjlink.manufacturer, 'Projector manufacturer should be None') - self.assertIsNone(pjlink.model, 'Projector model should be None') - self.assertIsNone(pjlink.shutter, 'Projector shutter should be None') - self.assertIsNone(pjlink.mute, 'Projector shuttter should be None') - self.assertIsNone(pjlink.lamp, 'Projector lamp should be None') - self.assertIsNone(pjlink.fan, 'Projector fan should be None') - self.assertIsNone(pjlink.source_available, 'Projector source_available should be None') - self.assertIsNone(pjlink.source, 'Projector source should be None') - self.assertIsNone(pjlink.other_info, 'Projector other_info should be None') - self.assertEqual(pjlink.send_queue, [], 'Projector send_queue should be an empty list') - self.assertFalse(pjlink.send_busy, 'Projector send_busy should be False') - self.assertTrue(mock_timer.stop.called, 'Projector timer.stop() should have been called') - self.assertTrue(mock_socket_timer.stop.called, 'Projector socket_timer.stop() should have been called') + # THEN: All information should be reset and timers stopped + assert pjlink.power == S_OFF, 'Projector power should be OFF' + assert pjlink.pjlink_name is None, 'Projector pjlink_name should be None' + assert pjlink.manufacturer is None, 'Projector manufacturer should be None' + assert pjlink.model is None, 'Projector model should be None' + assert pjlink.shutter is None, 'Projector shutter should be None' + assert pjlink.mute is None, 'Projector shuttter should be None' + assert pjlink.lamp is None, 'Projector lamp should be None' + assert pjlink.fan is None, 'Projector fan should be None' + assert pjlink.source_available is None, 'Projector source_available should be None' + assert pjlink.source is None, 'Projector source should be None' + assert pjlink.other_info is None, 'Projector other_info should be None' + assert pjlink.send_queue == [], 'Projector send_queue should be an empty list' + assert pjlink.send_busy is False, 'Projector send_busy should be False' + assert mock_timer.stop.called is True, 'Projector timer.stop() should have been called' + assert mock_socket_timer.stop.called is True, 'Projector socket_timer.stop() should have been called' + mock_log.debug.assert_has_calls(log_debug_calls) diff --git a/tests/functional/openlp_core/projectors/test_projector_pjlink_commands_02.py b/tests/functional/openlp_core/projectors/test_projector_pjlink_commands_02.py index 62ba4ec76..c9ccc2543 100644 --- a/tests/functional/openlp_core/projectors/test_projector_pjlink_commands_02.py +++ b/tests/functional/openlp_core/projectors/test_projector_pjlink_commands_02.py @@ -29,7 +29,6 @@ import openlp.core.projectors.pjlink from openlp.core.projectors.constants import S_CONNECTED from openlp.core.projectors.db import Projector from openlp.core.projectors.pjlink import PJLink - from tests.resources.projector.data import TEST_HASH, TEST_PIN, TEST_SALT, TEST1_DATA diff --git a/tests/functional/openlp_core/test_app.py b/tests/functional/openlp_core/test_app.py index 6f5b05803..efce25a62 100644 --- a/tests/functional/openlp_core/test_app.py +++ b/tests/functional/openlp_core/test_app.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -19,7 +19,6 @@ # with this program; if not, write to the Free Software Foundation, Inc., 59 # # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### -import os import sys from unittest import TestCase, skip from unittest.mock import MagicMock, patch @@ -28,8 +27,7 @@ from PyQt5 import QtCore, QtWidgets from openlp.core.app import OpenLP, parse_options from openlp.core.common.settings import Settings - -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), '..', 'resources')) +from tests.utils.constants import RESOURCE_PATH def test_parse_options_basic(): @@ -280,7 +278,7 @@ class TestOpenLP(TestCase): Test the reimplemented event method """ # GIVEN: A file path and a QEvent. - file_path = os.path.join(TEST_PATH, 'church.jpg') + file_path = str(RESOURCE_PATH / 'church.jpg') mocked_file_method = MagicMock(return_value=file_path) event = QtCore.QEvent(QtCore.QEvent.FileOpen) event.file = mocked_file_method @@ -310,7 +308,7 @@ class TestOpenLP(TestCase): # THEN: assert result is True, "The method should have returned True." - # self.assertFalse(self.openlp.main_window.isMinimized()) + # assert self.openlp.main_window.isMinimized() is False @patch('openlp.core.app.get_version') @patch('openlp.core.app.QtWidgets.QMessageBox.question') diff --git a/tests/functional/openlp_core/test_version.py b/tests/functional/openlp_core/test_version.py index c5790a9b6..8d9d59fb1 100644 --- a/tests/functional/openlp_core/test_version.py +++ b/tests/functional/openlp_core/test_version.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -63,7 +63,7 @@ def test_worker_start(mock_requests, mock_platform): worker.start() # THEN: The check completes and the signal is emitted - expected_download_url = 'http://www.openlp.org/files/version.txt' + expected_download_url = 'https://www.openlp.org/files/version.txt' expected_headers = {'User-Agent': 'OpenLP/2.0 Linux/4.12.0-1-amd64; '} mock_requests.get.assert_called_once_with(expected_download_url, headers=expected_headers) mock_new_version.emit.assert_called_once_with('2.4.6') @@ -88,7 +88,7 @@ def test_worker_start_dev_version(mock_requests, mock_platform): worker.start() # THEN: The check completes and the signal is emitted - expected_download_url = 'http://www.openlp.org/files/dev_version.txt' + expected_download_url = 'https://www.openlp.org/files/dev_version.txt' expected_headers = {'User-Agent': 'OpenLP/2.1.3 Linux/4.12.0-1-amd64; '} mock_requests.get.assert_called_once_with(expected_download_url, headers=expected_headers) mock_new_version.emit.assert_called_once_with('2.4.6') @@ -113,13 +113,38 @@ def test_worker_start_nightly_version(mock_requests, mock_platform): worker.start() # THEN: The check completes and the signal is emitted - expected_download_url = 'http://www.openlp.org/files/nightly_version.txt' + expected_download_url = 'https://www.openlp.org/files/nightly_version.txt' expected_headers = {'User-Agent': 'OpenLP/2.1-bzr2345 Linux/4.12.0-1-amd64; '} mock_requests.get.assert_called_once_with(expected_download_url, headers=expected_headers) mock_new_version.emit.assert_called_once_with('2.4.6') mock_quit.emit.assert_called_once_with() +@patch('openlp.core.version.platform') +@patch('openlp.core.version.requests') +def test_worker_empty_response(mock_requests, mock_platform): + """Test the VersionWorkder.start() method for empty responses""" + # GIVEN: A last check date, current version, and an instance of worker + last_check_date = '1970-01-01' + current_version = {'full': '2.1-bzr2345', 'version': '2.1', 'build': '2345'} + mock_platform.system.return_value = 'Linux' + mock_platform.release.return_value = '4.12.0-1-amd64' + mock_requests.get.return_value = MagicMock(text='\n') + worker = VersionWorker(last_check_date, current_version) + + # WHEN: The worker is run + with patch.object(worker, 'new_version') as mock_new_version, \ + patch.object(worker, 'quit') as mock_quit: + worker.start() + + # THEN: The check completes and the signal is emitted + expected_download_url = 'https://www.openlp.org/files/nightly_version.txt' + expected_headers = {'User-Agent': 'OpenLP/2.1-bzr2345 Linux/4.12.0-1-amd64; '} + mock_requests.get.assert_called_once_with(expected_download_url, headers=expected_headers) + assert mock_new_version.emit.call_count == 0 + mock_quit.emit.assert_called_once_with() + + @patch('openlp.core.version.platform') @patch('openlp.core.version.requests') def test_worker_start_connection_error(mock_requests, mock_platform): @@ -138,7 +163,7 @@ def test_worker_start_connection_error(mock_requests, mock_platform): worker.start() # THEN: The check completes and the signal is emitted - expected_download_url = 'http://www.openlp.org/files/version.txt' + expected_download_url = 'https://www.openlp.org/files/version.txt' expected_headers = {'User-Agent': 'OpenLP/2.0 Linux/4.12.0-1-amd64; '} mock_requests.get.assert_called_with(expected_download_url, headers=expected_headers) assert mock_requests.get.call_count == 3 diff --git a/tests/functional/openlp_core/ui/media/__init__.py b/tests/functional/openlp_core/ui/media/__init__.py index c43523cae..d8d1f2db7 100644 --- a/tests/functional/openlp_core/ui/media/__init__.py +++ b/tests/functional/openlp_core/ui/media/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/ui/media/test_mediacontroller.py b/tests/functional/openlp_core/ui/media/test_mediacontroller.py index c93b11f33..8fb141c13 100644 --- a/tests/functional/openlp_core/ui/media/test_mediacontroller.py +++ b/tests/functional/openlp_core/ui/media/test_mediacontroller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,10 +25,9 @@ Package to test the openlp.core.ui.media package. from unittest import TestCase from unittest.mock import MagicMock, patch +from openlp.core.common.registry import Registry from openlp.core.ui.media.mediacontroller import MediaController from openlp.core.ui.media.mediaplayer import MediaPlayer -from openlp.core.common.registry import Registry - from tests.helpers.testmixin import TestMixin diff --git a/tests/functional/openlp_core/ui/media/test_vlcplayer.py b/tests/functional/openlp_core/ui/media/test_vlcplayer.py index b4c6b8c28..24c929563 100644 --- a/tests/functional/openlp_core/ui/media/test_vlcplayer.py +++ b/tests/functional/openlp_core/ui/media/test_vlcplayer.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -31,7 +31,6 @@ from unittest.mock import MagicMock, patch, call from openlp.core.common.registry import Registry from openlp.core.ui.media import MediaState, MediaType from openlp.core.ui.media.vlcplayer import AUDIO_EXT, VIDEO_EXT, VlcPlayer, get_vlc - from tests.helpers import MockDateTime from tests.helpers.testmixin import TestMixin diff --git a/tests/functional/openlp_core/ui/media/test_webkitplayer.py b/tests/functional/openlp_core/ui/media/test_webkitplayer.py index 35d6f7f24..ecdda4353 100644 --- a/tests/functional/openlp_core/ui/media/test_webkitplayer.py +++ b/tests/functional/openlp_core/ui/media/test_webkitplayer.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/ui/test_aboutform.py b/tests/functional/openlp_core/ui/test_aboutform.py index e90764e88..049fb68c4 100644 --- a/tests/functional/openlp_core/ui/test_aboutform.py +++ b/tests/functional/openlp_core/ui/test_aboutform.py @@ -27,7 +27,6 @@ from unittest import TestCase from unittest.mock import patch from openlp.core.ui.aboutform import AboutForm - from tests.helpers.testmixin import TestMixin diff --git a/tests/functional/openlp_core/ui/test_advancedtab.py b/tests/functional/openlp_core/ui/test_advancedtab.py index 52cf2068f..3f4069dc2 100644 --- a/tests/functional/openlp_core/ui/test_advancedtab.py +++ b/tests/functional/openlp_core/ui/test_advancedtab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,7 +27,6 @@ from unittest import TestCase from openlp.core.common.registry import Registry from openlp.core.ui.advancedtab import AdvancedTab from openlp.core.ui.settingsform import SettingsForm - from tests.helpers.testmixin import TestMixin diff --git a/tests/functional/openlp_core/ui/test_exceptionform.py b/tests/functional/openlp_core/ui/test_exceptionform.py index 3bc99d63f..207805f37 100644 --- a/tests/functional/openlp_core/ui/test_exceptionform.py +++ b/tests/functional/openlp_core/ui/test_exceptionform.py @@ -24,14 +24,12 @@ Package to test the openlp.core.ui.exeptionform package. """ import os import tempfile - from unittest import TestCase from unittest.mock import call, patch -from openlp.core.common.registry import Registry from openlp.core.common.path import Path +from openlp.core.common.registry import Registry from openlp.core.ui import exceptionform - from tests.helpers.testmixin import TestMixin exceptionform.WEBKIT_VERSION = 'Webkit Test' diff --git a/tests/functional/openlp_core/ui/test_first_time.py b/tests/functional/openlp_core/ui/test_first_time.py index 2be5e1ad6..b6404d2b1 100644 --- a/tests/functional/openlp_core/ui/test_first_time.py +++ b/tests/functional/openlp_core/ui/test_first_time.py @@ -26,7 +26,6 @@ from unittest import TestCase from unittest.mock import patch from openlp.core.common.httputils import CONNECTION_RETRIES, get_web_page - from tests.helpers.testmixin import TestMixin diff --git a/tests/functional/openlp_core/ui/test_firsttimeform.py b/tests/functional/openlp_core/ui/test_firsttimeform.py index f99fff2f0..cd507452e 100644 --- a/tests/functional/openlp_core/ui/test_firsttimeform.py +++ b/tests/functional/openlp_core/ui/test_firsttimeform.py @@ -24,14 +24,12 @@ Package to test the openlp.core.ui.firsttimeform package. """ import os import tempfile -import urllib from unittest import TestCase from unittest.mock import MagicMock, patch -from openlp.core.common.registry import Registry from openlp.core.common.path import Path +from openlp.core.common.registry import Registry from openlp.core.ui.firsttimeform import FirstTimeForm - from tests.helpers.testmixin import TestMixin FAKE_CONFIG = """ diff --git a/tests/functional/openlp_core/ui/test_maindisplay.py b/tests/functional/openlp_core/ui/test_maindisplay.py index 04ffa1d8c..cbfefa6a2 100644 --- a/tests/functional/openlp_core/ui/test_maindisplay.py +++ b/tests/functional/openlp_core/ui/test_maindisplay.py @@ -34,7 +34,6 @@ from openlp.core.display.screens import ScreenList from openlp.core.lib import PluginManager from openlp.core.ui import MainDisplay, AudioPlayer from openlp.core.ui.maindisplay import TRANSPARENT_STYLESHEET, OPAQUE_STYLESHEET - from tests.helpers.testmixin import TestMixin if is_macosx(): diff --git a/tests/functional/openlp_core/ui/test_mainwindow.py b/tests/functional/openlp_core/ui/test_mainwindow.py index 423a01a4d..81b29a939 100644 --- a/tests/functional/openlp_core/ui/test_mainwindow.py +++ b/tests/functional/openlp_core/ui/test_mainwindow.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -32,7 +32,6 @@ from openlp.core.common.i18n import UiStrings from openlp.core.common.registry import Registry from openlp.core.display.screens import ScreenList from openlp.core.ui.mainwindow import MainWindow - from tests.helpers.testmixin import TestMixin from tests.utils.constants import TEST_RESOURCES_PATH @@ -117,8 +116,8 @@ class TestMainWindow(TestCase, TestMixin): # WHEN no changes are made to the service # THEN the main window's title shoud be the same as the OpenLP string in the UiStrings class - self.assertEqual(self.main_window.windowTitle(), UiStrings().OpenLP, - 'The main window\'s title should be the same as the OpenLP string in UiStrings class') + assert self.main_window.windowTitle() == UiStrings().OpenLP, \ + 'The main window\'s title should be the same as the OpenLP string in UiStrings class' def test_set_service_modifed(self): """ @@ -204,7 +203,7 @@ class TestMainWindow(TestCase, TestMixin): self.main_window.on_search_shortcut_triggered() # THEN: The media manager dock is made visible - self.assertEqual(0, mocked_media_manager_dock.setVisible.call_count) + assert 0 == mocked_media_manager_dock.setVisible.call_count mocked_widget.on_focus.assert_called_with() @patch('openlp.core.ui.mainwindow.FirstTimeForm') diff --git a/tests/functional/openlp_core/ui/test_media.py b/tests/functional/openlp_core/ui/test_media.py index d11745ae9..eef1907e3 100644 --- a/tests/functional/openlp_core/ui/test_media.py +++ b/tests/functional/openlp_core/ui/test_media.py @@ -28,7 +28,6 @@ from unittest.mock import patch from PyQt5 import QtCore from openlp.core.ui.media import get_media_players, parse_optical_path - from tests.helpers.testmixin import TestMixin diff --git a/tests/functional/openlp_core/ui/test_style.py b/tests/functional/openlp_core/ui/test_style.py index fc017e87d..17f7cf873 100644 --- a/tests/functional/openlp_core/ui/test_style.py +++ b/tests/functional/openlp_core/ui/test_style.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/ui/test_thememanager.py b/tests/functional/openlp_core/ui/test_thememanager.py index 79d467583..ba5f7fc05 100644 --- a/tests/functional/openlp_core/ui/test_thememanager.py +++ b/tests/functional/openlp_core/ui/test_thememanager.py @@ -30,11 +30,10 @@ from unittest.mock import ANY, MagicMock, patch from PyQt5 import QtWidgets -from openlp.core.common.registry import Registry from openlp.core.common.path import Path +from openlp.core.common.registry import Registry from openlp.core.ui import ThemeManager - -from tests.utils.constants import TEST_RESOURCES_PATH +from tests.utils.constants import RESOURCE_PATH class TestThemeManager(TestCase): @@ -60,7 +59,7 @@ class TestThemeManager(TestCase): """ # GIVEN: A new ThemeManager instance. theme_manager = ThemeManager() - theme_manager.theme_path = Path(TEST_RESOURCES_PATH, 'themes') + theme_manager.theme_path = RESOURCE_PATH / 'themes' mocked_zipfile_init.return_value = None # WHEN: The theme is exported @@ -68,7 +67,7 @@ class TestThemeManager(TestCase): # THEN: The zipfile should be created at the given path mocked_zipfile_init.assert_called_with(os.path.join('some', 'path', 'Default.otz'), 'w') - mocked_zipfile_write.assert_called_with(os.path.join(TEST_RESOURCES_PATH, 'themes', 'Default', 'Default.xml'), + mocked_zipfile_write.assert_called_with(str(RESOURCE_PATH / 'themes' / 'Default' / 'Default.xml'), os.path.join('Default', 'Default.xml')) def test_initial_theme_manager(self): @@ -100,8 +99,8 @@ class TestThemeManager(TestCase): mocked_theme.extract_formatted_xml.return_value = 'fake_theme_xml'.encode() # WHEN: Calling _write_theme with path to the same image, but the path written slightly different - file_name1 = Path(TEST_RESOURCES_PATH, 'church.jpg') - theme_manager._write_theme(mocked_theme, file_name1, file_name1) + file_path_1 = RESOURCE_PATH / 'church.jpg' + theme_manager._write_theme(mocked_theme, file_path_1, file_path_1) # THEN: The mocked_copyfile should not have been called assert mocked_copyfile.called is False, 'copyfile should not be called' @@ -123,9 +122,9 @@ class TestThemeManager(TestCase): mocked_theme.filename = "filename" # WHEN: Calling _write_theme with path to different images - file_name1 = Path(TEST_RESOURCES_PATH, 'church.jpg') - file_name2 = Path(TEST_RESOURCES_PATH, 'church2.jpg') - theme_manager._write_theme(mocked_theme, file_name1, file_name2) + file_path_1 = RESOURCE_PATH / 'church.jpg' + file_path_2 = RESOURCE_PATH / 'church2.jpg' + theme_manager._write_theme(mocked_theme, file_path_1, file_path_2) # THEN: The mocked_copyfile should not have been called assert mocked_copyfile.called is True, 'copyfile should be called' @@ -200,10 +199,10 @@ class TestThemeManager(TestCase): theme_manager.generate_and_save_image = MagicMock() theme_manager.theme_path = None folder_path = Path(mkdtemp()) - theme_file = Path(TEST_RESOURCES_PATH, 'themes', 'Moss_on_tree.otz') + theme_file_path = RESOURCE_PATH / 'themes' / 'Moss_on_tree.otz' # WHEN: We try to unzip it - theme_manager.unzip_theme(theme_file, folder_path) + theme_manager.unzip_theme(theme_file_path, folder_path) # THEN: Files should be unpacked assert (folder_path / 'Moss on tree' / 'Moss on tree.xml').exists() is True diff --git a/tests/functional/openlp_core/ui/test_themetab.py b/tests/functional/openlp_core/ui/test_themetab.py index b88d3a246..f27f4a2ca 100644 --- a/tests/functional/openlp_core/ui/test_themetab.py +++ b/tests/functional/openlp_core/ui/test_themetab.py @@ -26,9 +26,8 @@ from unittest import TestCase from unittest.mock import MagicMock from openlp.core.common.registry import Registry -from openlp.core.ui.themestab import ThemesTab from openlp.core.ui.settingsform import SettingsForm - +from openlp.core.ui.themestab import ThemesTab from tests.helpers.testmixin import TestMixin diff --git a/tests/functional/openlp_core/widgets/__init__.py b/tests/functional/openlp_core/widgets/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/functional/openlp_core/widgets/__init__.py +++ b/tests/functional/openlp_core/widgets/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/widgets/test_buttons.py b/tests/functional/openlp_core/widgets/test_buttons.py index 02b953708..2bc6d8c5c 100644 --- a/tests/functional/openlp_core/widgets/test_buttons.py +++ b/tests/functional/openlp_core/widgets/test_buttons.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_core/widgets/test_edits.py b/tests/functional/openlp_core/widgets/test_edits.py index 0d997c906..603df3a83 100755 --- a/tests/functional/openlp_core/widgets/test_edits.py +++ b/tests/functional/openlp_core/widgets/test_edits.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,9 +27,9 @@ from unittest import TestCase from unittest.mock import MagicMock, PropertyMock, patch from openlp.core.common.path import Path -from openlp.core.widgets.enums import PathEditType from openlp.core.widgets.dialogs import FileDialog from openlp.core.widgets.edits import PathEdit +from openlp.core.widgets.enums import PathEditType class TestPathEdit(TestCase): diff --git a/tests/functional/openlp_core/widgets/test_views.py b/tests/functional/openlp_core/widgets/test_views.py index 0365f7612..a0bbb4437 100644 --- a/tests/functional/openlp_core/widgets/test_views.py +++ b/tests/functional/openlp_core/widgets/test_views.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,6 +22,7 @@ """ Package to test the openlp.core.widgets.views package. """ +import os from types import GeneratorType from unittest import TestCase from unittest.mock import MagicMock, patch, call @@ -30,7 +31,59 @@ from PyQt5 import QtGui from openlp.core.common.i18n import UiStrings from openlp.core.lib import ImageSource -from openlp.core.widgets.views import ListPreviewWidget, ListWidgetWithDnD, TreeWidgetWithDnD +from openlp.core.widgets.views import ListPreviewWidget, ListWidgetWithDnD, TreeWidgetWithDnD, handle_mime_data_urls + + +class TestHandleMimeDataUrls(TestCase): + """ + Test the :func:`openlp.core.widgets.views.handle_mime_data_urls` function. + """ + def test_files(self): + """ + Test handle_mime_data_urls when the data points to some files. + """ + # GIVEN: Some mocked objects that return True when is_file is called, and some mocked mime data + mocked_path_instance_1 = MagicMock(**{'is_file.return_value': True}) + mocked_path_instance_2 = MagicMock(**{'is_file.return_value': True}) + with patch('openlp.core.widgets.views.Path', + side_effect=[mocked_path_instance_1, mocked_path_instance_2]) as mocked_path: + mocked_q_url_1 = MagicMock(**{'toLocalFile.return_value': os.path.join('file', 'test', 'path', '1.ext')}) + mocked_q_url_2 = MagicMock(**{'toLocalFile.return_value': os.path.join('file', 'test', 'path', '2.ext')}) + mocked_q_mime_data = MagicMock(**{'urls.return_value': [mocked_q_url_1, mocked_q_url_2]}) + + # WHEN: Calling handle_mime_data_urls with the mocked mime data + result = handle_mime_data_urls(mocked_q_mime_data) + + # THEN: Both mocked Path objects should be returned in the list + mocked_path.assert_has_calls([call(os.path.join('file', 'test', 'path', '1.ext')), + call(os.path.join('file', 'test', 'path', '2.ext'))]) + assert result == [mocked_path_instance_1, mocked_path_instance_2] + + def test_directory(self): + """ + Test handle_mime_data_urls when the data points to some directories. + """ + # GIVEN: Some mocked objects that return True when is_dir is called, and some mocked mime data + mocked_path_instance_1 = MagicMock() + mocked_path_instance_2 = MagicMock() + mocked_path_instance_3 = MagicMock() + mocked_path_instance_4 = MagicMock(**{'is_file.return_value': False, 'is_directory.return_value': True, + 'iterdir.return_value': [mocked_path_instance_1, mocked_path_instance_2]}) + mocked_path_instance_5 = MagicMock(**{'is_file.return_value': False, 'is_directory.return_value': True, + 'iterdir.return_value': [mocked_path_instance_3]}) + with patch('openlp.core.widgets.views.Path', + side_effect=[mocked_path_instance_4, mocked_path_instance_5]) as mocked_path: + mocked_q_url_1 = MagicMock(**{'toLocalFile.return_value': os.path.join('file', 'test', 'path')}) + mocked_q_url_2 = MagicMock(**{'toLocalFile.return_value': os.path.join('file', 'test', 'path')}) + mocked_q_mime_data = MagicMock(**{'urls.return_value': [mocked_q_url_1, mocked_q_url_2]}) + + # WHEN: Calling handle_mime_data_urls with the mocked mime data + result = handle_mime_data_urls(mocked_q_mime_data) + + # THEN: The three mocked Path file objects should be returned in the list + mocked_path.assert_has_calls([call(os.path.join('file', 'test', 'path')), + call(os.path.join('file', 'test', 'path'))]) + assert result == [mocked_path_instance_1, mocked_path_instance_2, mocked_path_instance_3] class TestListPreviewWidget(TestCase): diff --git a/tests/functional/openlp_plugins/__init__.py b/tests/functional/openlp_plugins/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/functional/openlp_plugins/__init__.py +++ b/tests/functional/openlp_plugins/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_plugins/alerts/__init__.py b/tests/functional/openlp_plugins/alerts/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/functional/openlp_plugins/alerts/__init__.py +++ b/tests/functional/openlp_plugins/alerts/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_plugins/alerts/test_manager.py b/tests/functional/openlp_plugins/alerts/test_manager.py index c286e81cd..a2aadcc16 100644 --- a/tests/functional/openlp_plugins/alerts/test_manager.py +++ b/tests/functional/openlp_plugins/alerts/test_manager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,10 +22,8 @@ """ This module contains tests for the CSV Bible importer. """ -import os -import json from unittest import TestCase -from unittest.mock import MagicMock, patch +from unittest.mock import MagicMock from openlp.core.common.registry import Registry from openlp.plugins.alerts.lib.alertsmanager import AlertsManager @@ -51,7 +49,7 @@ class TestAlertManager(TestCase): alert_manager.alert_text('') # THEN: the display should not have been triggered - self.assertFalse(alert_manager.display_alert.called, 'The Alert should not have been called') + assert alert_manager.display_alert.called is False, 'The Alert should not have been called' def test_trigger_message_text(self): """ @@ -65,7 +63,7 @@ class TestAlertManager(TestCase): alert_manager.alert_text(['This is a string']) # THEN: the display should have been triggered - self.assertTrue(alert_manager.display_alert.called, 'The Alert should have been called') + assert alert_manager.display_alert.called is True, 'The Alert should have been called' def test_line_break_message_text(self): """ @@ -79,5 +77,5 @@ class TestAlertManager(TestCase): alert_manager.alert_text(['This is \n a string']) # THEN: the display should have been triggered - self.assertTrue(alert_manager.display_alert.called, 'The Alert should have been called') + assert alert_manager.display_alert.called is True, 'The Alert should have been called' alert_manager.display_alert.assert_called_once_with('This is a string') diff --git a/tests/functional/openlp_plugins/bibles/__init__.py b/tests/functional/openlp_plugins/bibles/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/functional/openlp_plugins/bibles/__init__.py +++ b/tests/functional/openlp_plugins/bibles/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_plugins/bibles/test_bibleimport.py b/tests/functional/openlp_plugins/bibles/test_bibleimport.py index 9b9a8fae8..013bbc267 100644 --- a/tests/functional/openlp_plugins/bibles/test_bibleimport.py +++ b/tests/functional/openlp_plugins/bibles/test_bibleimport.py @@ -26,8 +26,8 @@ from io import BytesIO from unittest import TestCase from unittest.mock import MagicMock, patch -from lxml import etree, objectify from PyQt5.QtWidgets import QDialog +from lxml import etree, objectify from openlp.core.common.i18n import Language from openlp.core.common.path import Path diff --git a/tests/functional/openlp_plugins/bibles/test_bibleserver.py b/tests/functional/openlp_plugins/bibles/test_bibleserver.py index bc05a601f..5d49a7a18 100644 --- a/tests/functional/openlp_plugins/bibles/test_bibleserver.py +++ b/tests/functional/openlp_plugins/bibles/test_bibleserver.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -75,9 +75,8 @@ class TestBSExtract(TestCase): self.mock_urllib.parse.quote.assert_called_once_with(b'NIV') self.mock_get_soup_for_bible_ref.assert_called_once_with( 'http://m.bibleserver.com/overlay/selectBook?translation=NIV') - self.assertIsNone(result, - 'BSExtract.get_books_from_http should return None when get_soup_for_bible_ref returns a ' - 'false value') + assert result is None, \ + 'BSExtract.get_books_from_http should return None when get_soup_for_bible_ref returns a false value' def test_get_books_from_http_no_content(self): """ @@ -106,9 +105,8 @@ class TestBSExtract(TestCase): self.mock_soup.find.assert_called_once_with('ul') self.mock_log.error.assert_called_once_with('No books found in the Bibleserver response.') self.mock_send_error_message.assert_called_once_with('parse') - self.assertIsNone(result, - 'BSExtract.get_books_from_http should return None when get_soup_for_bible_ref returns a ' - 'false value') + assert result is None, \ + 'BSExtract.get_books_from_http should return None when get_soup_for_bible_ref returns a false value' def test_get_books_from_http_content(self): """ @@ -138,6 +136,6 @@ class TestBSExtract(TestCase): self.mock_urllib.parse.quote.assert_called_once_with(b'NIV') self.mock_get_soup_for_bible_ref.assert_called_once_with( 'http://m.bibleserver.com/overlay/selectBook?translation=NIV') - self.assertFalse(self.mock_log.error.called, 'log.error should not have been called') - self.assertFalse(self.mock_send_error_message.called, 'send_error_message should not have been called') - self.assertEqual(result, ['Genesis', 'Leviticus']) + assert self.mock_log.error.called is False, 'log.error should not have been called' + assert self.mock_send_error_message.called is False, 'send_error_message should not have been called' + assert result == ['Genesis', 'Leviticus'] diff --git a/tests/functional/openlp_plugins/bibles/test_csvimport.py b/tests/functional/openlp_plugins/bibles/test_csvimport.py index 4d948f53b..db07706eb 100644 --- a/tests/functional/openlp_plugins/bibles/test_csvimport.py +++ b/tests/functional/openlp_plugins/bibles/test_csvimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,8 +23,6 @@ This module contains tests for the CSV Bible importer. """ import csv -import json -import os from collections import namedtuple from unittest import TestCase from unittest.mock import ANY, MagicMock, PropertyMock, call, patch @@ -33,10 +31,10 @@ from openlp.core.common.path import Path from openlp.core.lib.exceptions import ValidationError from openlp.plugins.bibles.lib.bibleimport import BibleImport from openlp.plugins.bibles.lib.importers.csvbible import Book, CSVBible, Verse +from tests.utils import load_external_result_data +from tests.utils.constants import RESOURCE_PATH - -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), - '..', '..', '..', 'resources', 'bibles')) +TEST_PATH = RESOURCE_PATH / 'bibles' class TestCSVImport(TestCase): @@ -64,9 +62,9 @@ class TestCSVImport(TestCase): CSVBible(mocked_manager, path='.', name='.', books_path=Path('books.csv'), verse_path=Path('verse.csv')) # THEN: The importer should be an instance of BibleImport - self.assertIsInstance(importer, BibleImport) - self.assertEqual(importer.books_path, Path('books.csv')) - self.assertEqual(importer.verses_path, Path('verse.csv')) + assert isinstance(importer, BibleImport) + assert importer.books_path == Path('books.csv') + assert importer.verses_path == Path('verse.csv') def test_book_namedtuple(self): """ @@ -77,10 +75,10 @@ class TestCSVImport(TestCase): result = Book('id', 'testament_id', 'name', 'abbreviation') # THEN: The attributes should match up with the data we used - self.assertEqual(result.id, 'id') - self.assertEqual(result.testament_id, 'testament_id') - self.assertEqual(result.name, 'name') - self.assertEqual(result.abbreviation, 'abbreviation') + assert result.id == 'id' + assert result.testament_id == 'testament_id' + assert result.name == 'name' + assert result.abbreviation == 'abbreviation' def test_verse_namedtuple(self): """ @@ -91,10 +89,10 @@ class TestCSVImport(TestCase): result = Verse('book_id_name', 'chapter_number', 'number', 'text') # THEN: The attributes should match up with the data we used - self.assertEqual(result.book_id_name, 'book_id_name') - self.assertEqual(result.chapter_number, 'chapter_number') - self.assertEqual(result.number, 'number') - self.assertEqual(result.text, 'text') + assert result.book_id_name == 'book_id_name' + assert result.chapter_number == 'chapter_number' + assert result.number == 'number' + assert result.text == 'text' def test_get_book_name_id(self): """ @@ -109,7 +107,7 @@ class TestCSVImport(TestCase): actual_result = CSVBible.get_book_name(name, books) # THEN: get_book_name() should return the book name associated with that id from the books dictionary - self.assertEqual(actual_result, expected_result) + assert actual_result == expected_result def test_get_book_name(self): """ @@ -124,7 +122,7 @@ class TestCSVImport(TestCase): actual_result = CSVBible.get_book_name(name, books) # THEN: get_book_name() should return the input - self.assertEqual(actual_result, expected_result) + assert actual_result == expected_result def test_parse_csv_file(self): """ @@ -144,8 +142,8 @@ class TestCSVImport(TestCase): result = CSVBible.parse_csv_file(Path('file.csv'), TestTuple) # THEN: A list of TestTuple instances with the parsed data should be returned - self.assertEqual(result, [TestTuple('1', 'Line 1', 'Data 1'), TestTuple('2', 'Line 2', 'Data 2'), - TestTuple('3', 'Line 3', 'Data 3')]) + assert result == [TestTuple('1', 'Line 1', 'Data 1'), TestTuple('2', 'Line 2', 'Data 2'), + TestTuple('3', 'Line 3', 'Data 3')] mocked_open.assert_called_once_with('r', encoding='utf-8', newline='') mocked_reader.assert_called_once_with(ANY, delimiter=',', quotechar='"') @@ -162,7 +160,7 @@ class TestCSVImport(TestCase): # THEN: A ValidationError should be raised with self.assertRaises(ValidationError) as context: CSVBible.parse_csv_file(Path('file.csv'), None) - self.assertEqual(context.exception.msg, 'Parsing "file.csv" failed') + assert context.exception.msg == 'Parsing "file.csv" failed' def test_parse_csv_file_csverror(self): """ @@ -178,7 +176,7 @@ class TestCSVImport(TestCase): # THEN: A ValidationError should be raised with self.assertRaises(ValidationError) as context: CSVBible.parse_csv_file(Path('file.csv'), None) - self.assertEqual(context.exception.msg, 'Parsing "file.csv" failed') + assert context.exception.msg == 'Parsing "file.csv" failed' def test_process_books_stopped_import(self): """ @@ -197,8 +195,8 @@ class TestCSVImport(TestCase): result = importer.process_books(['Book 1']) # THEN: increment_progress_bar should not be called and the return value should be an empty dictionary - self.assertFalse(importer.wizard.increment_progress_bar.called) - self.assertEqual(result, {}) + assert importer.wizard.increment_progress_bar.called is False + assert result == {} def test_process_books(self): """ @@ -222,9 +220,9 @@ class TestCSVImport(TestCase): # THEN: translate and find_and_create_book should have been called with both book names. # The returned data should be a dictionary with both song's id and names. - self.assertEqual(importer.find_and_create_book.mock_calls, - [call('1. Mosebog', 2, 10), call('2. Mosebog', 2, 10)]) - self.assertDictEqual(result, {1: '1. Mosebog', 2: '2. Mosebog'}) + assert importer.find_and_create_book.mock_calls == \ + [call('1. Mosebog', 2, 10), call('2. Mosebog', 2, 10)] + assert result == {1: '1. Mosebog', 2: '2. Mosebog'} def test_process_verses_stopped_import(self): """ @@ -244,8 +242,8 @@ class TestCSVImport(TestCase): result = importer.process_verses(['Dummy Verse'], []) # THEN: get_book_name should not be called and the return value should be None - self.assertFalse(importer.get_book_name.called) - self.assertIsNone(result) + assert importer.get_book_name.called is False + assert result is None def test_process_verses_successful(self): """ @@ -272,13 +270,13 @@ class TestCSVImport(TestCase): importer.process_verses(verses, books) # THEN: create_verse is called with the test data - self.assertEqual(importer.get_book_name.mock_calls, [call(1, books), call(1, books)]) + assert importer.get_book_name.mock_calls == [call(1, books), call(1, books)] importer.get_book.assert_called_once_with('1. Mosebog') - self.assertEqual(importer.session.commit.call_count, 2) - self.assertEqual(importer.create_verse.mock_calls, - [call('1', 1, 1, 'I Begyndelsen skabte Gud Himmelen og Jorden.'), - call('1', 1, 2, 'Og Jorden var øde og tom, og der var Mørke over Verdensdybet. ' - 'Men Guds Ånd svævede over Vandene.')]) + assert importer.session.commit.call_count == 2 + assert importer.create_verse.mock_calls == \ + [call('1', 1, 1, 'I Begyndelsen skabte Gud Himmelen og Jorden.'), + call('1', 1, 2, 'Og Jorden var øde og tom, og der var Mørke over Verdensdybet. ' + 'Men Guds Ånd svævede over Vandene.')] def test_do_import_invalid_language_id(self): """ @@ -296,7 +294,7 @@ class TestCSVImport(TestCase): # THEN: The False should be returned. importer.get_language.assert_called_once_with('Bible Name') - self.assertFalse(result) + assert result is False def test_do_import_success(self): """ @@ -320,11 +318,11 @@ class TestCSVImport(TestCase): # THEN: parse_csv_file should be called twice, # and True should be returned. - self.assertEqual(importer.parse_csv_file.mock_calls, - [call(Path('books.csv'), Book), call(Path('verses.csv'), Verse)]) + assert importer.parse_csv_file.mock_calls == \ + [call(Path('books.csv'), Book), call(Path('verses.csv'), Verse)] importer.process_books.assert_called_once_with(['Book 1']) importer.process_verses.assert_called_once_with(['Verse 1'], ['Book 1']) - self.assertTrue(result) + assert result is True def test_file_import(self): """ @@ -332,10 +330,9 @@ class TestCSVImport(TestCase): """ # GIVEN: Test files with a mocked out "manager", "import_wizard", and mocked functions # get_book_ref_id_by_name, create_verse, create_book, session and get_language. - result_file = open(os.path.join(TEST_PATH, 'dk1933.json'), 'rb') - test_data = json.loads(result_file.read().decode()) - books_file = Path(TEST_PATH, 'dk1933-books.csv') - verses_file = Path(TEST_PATH, 'dk1933-verses.csv') + test_data = load_external_result_data(TEST_PATH / 'dk1933.json') + books_file = TEST_PATH / 'dk1933-books.csv' + verses_file = TEST_PATH / 'dk1933-verses.csv' with patch('openlp.plugins.bibles.lib.importers.csvbible.CSVBible.application'): mocked_manager = MagicMock() mocked_import_wizard = MagicMock() @@ -353,7 +350,7 @@ class TestCSVImport(TestCase): importer.do_import() # THEN: The create_verse() method should have been called with each verse in the file. - self.assertTrue(importer.create_verse.called) + assert importer.create_verse.called is True for verse_tag, verse_text in test_data['verses']: importer.create_verse.assert_any_call(importer.get_book().id, 1, verse_tag, verse_text) importer.create_book.assert_any_call('1. Mosebog', importer.get_book_ref_id_by_name(), 1) diff --git a/tests/functional/openlp_plugins/bibles/test_db.py b/tests/functional/openlp_plugins/bibles/test_db.py index 7a65fcdd3..8a00a53c7 100644 --- a/tests/functional/openlp_plugins/bibles/test_db.py +++ b/tests/functional/openlp_plugins/bibles/test_db.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_plugins/bibles/test_lib.py b/tests/functional/openlp_plugins/bibles/test_lib.py index 5ae8ae85d..594b3e8cc 100644 --- a/tests/functional/openlp_plugins/bibles/test_lib.py +++ b/tests/functional/openlp_plugins/bibles/test_lib.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,7 +27,6 @@ from unittest.mock import MagicMock, patch from openlp.plugins.bibles import lib from openlp.plugins.bibles.lib import SearchResults, get_reference_match - from tests.helpers.testmixin import TestMixin @@ -59,7 +58,7 @@ class TestLib(TestCase, TestMixin): _ = lib.get_reference_separator(key) # THEN: get_reference_separator should return the correct separator - self.assertEqual(separators[key], value) + assert separators[key] == value mocked_update_reference_separators.assert_called_once_with() def test_reference_matched_full(self): @@ -116,13 +115,13 @@ class TestLib(TestCase, TestMixin): # THEN: A match should be returned, and the book and reference should match the # expected result - self.assertIsNotNone(match, '{text} should provide a match'.format(text=reference_text)) - self.assertEqual(book_result, match.group('book'), - '{text} does not provide the expected result for the book group.' - .format(text=reference_text)) - self.assertEqual(ranges_result, match.group('ranges'), - '{text} does not provide the expected result for the ranges group.' - .format(text=reference_text)) + assert match is not None, '{text} should provide a match'.format(text=reference_text) + assert book_result == match.group('book'), \ + '{text} does not provide the expected result for the book group.'\ + .format(text=reference_text) + assert ranges_result == match.group('ranges'), \ + '{text} does not provide the expected result for the ranges group.' \ + .format(text=reference_text) def test_reference_matched_range(self): """ @@ -158,12 +157,12 @@ class TestLib(TestCase, TestMixin): # THEN: A match should be returned, and the to/from chapter/verses should match as # expected - self.assertIsNotNone(match, '{text} should provide a match'.format(text=reference_text)) - self.assertEqual(match.group('from_chapter'), from_chapter) - self.assertEqual(match.group('from_verse'), from_verse) - self.assertEqual(match.group('range_to'), range_to) - self.assertEqual(match.group('to_chapter'), to_chapter) - self.assertEqual(match.group('to_verse'), to_verse) + assert match is not None, '{text} should provide a match'.format(text=reference_text) + assert match.group('from_chapter') == from_chapter + assert match.group('from_verse') == from_verse + assert match.group('range_to') == range_to + assert match.group('to_chapter') == to_chapter + assert match.group('to_verse') == to_verse def test_reference_matched_range_separator(self): # GIVEN: Some test data which contains different references to parse, with the expected results. @@ -199,7 +198,7 @@ class TestLib(TestCase, TestMixin): references = full_reference_match.split(reference_text) # THEN: The list of references should be as the expected results - self.assertEqual(references, ranges) + assert references == ranges def test_search_results_creation(self): """ @@ -218,10 +217,10 @@ class TestLib(TestCase, TestMixin): search_results = SearchResults(book, chapter, verse_list) # THEN: It should have a book, a chapter and a verse list - self.assertIsNotNone(search_results, 'The search_results object should not be None') - self.assertEqual(search_results.book, book, 'The book should be "Genesis"') - self.assertEqual(search_results.chapter, chapter, 'The chapter should be 1') - self.assertDictEqual(search_results.verse_list, verse_list, 'The verse lists should be identical') + assert search_results is not None, 'The search_results object should not be None' + assert search_results.book == book, 'The book should be "Genesis"' + assert search_results.chapter == chapter, 'The chapter should be 1' + assert search_results.verse_list == verse_list, 'The verse lists should be identical' def test_search_results_has_verse_list(self): """ @@ -234,7 +233,7 @@ class TestLib(TestCase, TestMixin): has_verse_list = search_results.has_verse_list() # THEN: It should be True - self.assertTrue(has_verse_list, 'The SearchResults object should have a verse list') + assert has_verse_list is True, 'The SearchResults object should have a verse list' def test_search_results_has_no_verse_list(self): """ @@ -247,4 +246,4 @@ class TestLib(TestCase, TestMixin): has_verse_list = search_results.has_verse_list() # THEN: It should be False - self.assertFalse(has_verse_list, 'The SearchResults object should have a verse list') + assert has_verse_list is False, 'The SearchResults object should have a verse list' diff --git a/tests/functional/openlp_plugins/bibles/test_manager.py b/tests/functional/openlp_plugins/bibles/test_manager.py index 73e64d130..b5a4d4f1c 100644 --- a/tests/functional/openlp_plugins/bibles/test_manager.py +++ b/tests/functional/openlp_plugins/bibles/test_manager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -63,7 +63,7 @@ class TestManager(TestCase): # THEN: The session should have been closed and set to None, the bible should be deleted, and the result of # the deletion returned. - self.assertTrue(result) + assert result is True mocked_close_all.assert_called_once_with() - self.assertIsNone(mocked_bible.session) + assert mocked_bible.session is None mocked_delete_file.assert_called_once_with(Path('bibles', 'KJV.sqlite')) diff --git a/tests/functional/openlp_plugins/bibles/test_mediaitem.py b/tests/functional/openlp_plugins/bibles/test_mediaitem.py index ddc66254f..1d5425b2a 100755 --- a/tests/functional/openlp_plugins/bibles/test_mediaitem.py +++ b/tests/functional/openlp_plugins/bibles/test_mediaitem.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,12 +27,11 @@ from unittest.mock import MagicMock, call, patch from PyQt5 import QtCore, QtWidgets -from tests.helpers.testmixin import TestMixin - from openlp.core.common.registry import Registry from openlp.core.lib import MediaManagerItem from openlp.plugins.bibles.lib.mediaitem import BibleMediaItem, BibleSearch, ResultsTab, SearchStatus, SearchTabs, \ get_reference_separators, VALID_TEXT_SEARCH +from tests.helpers.testmixin import TestMixin class TestBibleMediaItemModulefunctions(TestCase): @@ -53,9 +52,9 @@ class TestBibleMediaItemModulefunctions(TestCase): # THEN: The expected result should be returned if expected_result is None: - self.assertIsNone(result, expected_result) + assert result is None, expected_result else: - self.assertEqual(result.regs, expected_result) + assert result.regs == expected_result def test_get_reference_separators(self): """ @@ -69,7 +68,7 @@ class TestBibleMediaItemModulefunctions(TestCase): # THEN: The result should contain the 'verse', 'range', 'list' keys and get_reference_separator should have # been called with the expected values. - self.assertTrue(all(key in result for key in ('verse', 'range', 'list'))) + assert all(key in result for key in ('verse', 'range', 'list')) is True mocked_get_reference_separator.assert_has_calls( [call('sep_v_display'), call('sep_r_display'), call('sep_l_display')]) @@ -80,9 +79,9 @@ class TestBibleMediaItemModulefunctions(TestCase): # GIVEN: The BibleSearch class # WHEN: Testing its attributes # THEN: The BibleSearch class should have the following enumrations - self.assertTrue(hasattr(BibleSearch, 'Combined')) - self.assertTrue(hasattr(BibleSearch, 'Reference')) - self.assertTrue(hasattr(BibleSearch, 'Text')) + assert hasattr(BibleSearch, 'Combined') + assert hasattr(BibleSearch, 'Reference') + assert hasattr(BibleSearch, 'Text') def test_bible_media_item_subclass(self): """ @@ -91,7 +90,7 @@ class TestBibleMediaItemModulefunctions(TestCase): # GIVEN: The :class:`BibleMediaItem` # WHEN: Checking if it is a subclass of MediaManagerItem # THEN: BibleMediaItem should be a subclass of MediaManagerItem - self.assertTrue(issubclass(BibleMediaItem, MediaManagerItem)) + assert issubclass(BibleMediaItem, MediaManagerItem) def test_bible_media_item_signals(self): """ @@ -99,10 +98,10 @@ class TestBibleMediaItemModulefunctions(TestCase): """ # GIVEN: The :class:`BibleMediaItem` # THEN: The :class:`BibleMediaItem` should contain the following pyqtSignal's - self.assertTrue(hasattr(BibleMediaItem, 'bibles_go_live')) - self.assertTrue(hasattr(BibleMediaItem, 'bibles_add_to_service')) - self.assertTrue(isinstance(BibleMediaItem.bibles_go_live, QtCore.pyqtSignal)) - self.assertTrue(isinstance(BibleMediaItem.bibles_add_to_service, QtCore.pyqtSignal)) + assert hasattr(BibleMediaItem, 'bibles_go_live') + assert hasattr(BibleMediaItem, 'bibles_add_to_service') + assert isinstance(BibleMediaItem.bibles_go_live, QtCore.pyqtSignal) + assert isinstance(BibleMediaItem.bibles_add_to_service, QtCore.pyqtSignal) class TestMediaItem(TestCase, TestMixin): @@ -166,7 +165,7 @@ class TestMediaItem(TestCase, TestMixin): # GIVEN: An instance of :class:`BibleMediaItem` # WEHN: Checking its class # THEN: It should be a subclass of :class:`MediaManagerItem` - self.assertTrue(isinstance(self.media_item, MediaManagerItem)) + assert isinstance(self.media_item, MediaManagerItem) def test_steup_item(self): """ @@ -193,11 +192,11 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.required_icons() # THEN: The correct icons should be set - self.assertTrue(self.media_item.has_import_icon, 'Check that the icon is as True.') - self.assertFalse(self.media_item.has_new_icon, 'Check that the icon is called as False.') - self.assertTrue(self.media_item.has_edit_icon, 'Check that the icon is called as True.') - self.assertTrue(self.media_item.has_delete_icon, 'Check that the icon is called as True.') - self.assertFalse(self.media_item.add_to_service_item, 'Check that the icon is called as False') + assert self.media_item.has_import_icon is True, 'Check that the icon is as True.' + assert self.media_item.has_new_icon is False, 'Check that the icon is called as False.' + assert self.media_item.has_edit_icon is True, 'Check that the icon is called as True.' + assert self.media_item.has_delete_icon is True, 'Check that the icon is called as True.' + assert self.media_item.add_to_service_item is False, 'Check that the icon is called as False' def test_on_focus_search_tab_visible(self): """ @@ -305,8 +304,8 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.initialise() # THEN: The search_edit search types should have been set. - self.assertTrue(self.media_item.search_edit.set_search_types.called) - self.assertFalse(self.media_item.search_edit.set_current_search_type.called) + assert self.media_item.search_edit.set_search_types.called is True + assert self.media_item.search_edit.set_current_search_type.called is False def test_initalise_reset_search_type(self): """ @@ -323,7 +322,7 @@ class TestMediaItem(TestCase, TestMixin): # THEN: The search_edit search types should have been set and that the current search type should be set to # 'Combined' - self.assertTrue(self.media_item.search_edit.set_search_types.called) + assert self.media_item.search_edit.set_search_types.called is True self.media_item.search_edit.set_current_search_type.assert_called_once_with(BibleSearch.Combined) def test_populate_bible_combo_boxes(self): @@ -373,7 +372,7 @@ class TestMediaItem(TestCase, TestMixin): result = self.media_item.get_common_books(self.mocked_bible_1) # THEN: The book of the bible should be returned - self.assertEqual(result, self.book_list_1) + assert result == self.book_list_1 def test_get_common_books_second_book(self): """ @@ -384,7 +383,7 @@ class TestMediaItem(TestCase, TestMixin): result = self.media_item.get_common_books(self.mocked_bible_1, self.mocked_bible_2) # THEN: Only the books contained in both bibles should be returned - self.assertEqual(result, [self.mocked_book_2, self.mocked_book_3]) + assert result == [self.mocked_book_2, self.mocked_book_3] def test_initialise_advanced_bible_no_bible(self): """ @@ -399,7 +398,7 @@ class TestMediaItem(TestCase, TestMixin): result = self.media_item.initialise_advanced_bible() # THEN: initialise_advanced_bible should return with put calling get_common_books - self.assertIsNone(result) + assert result is None mocked_get_common_books.assert_not_called() def test_initialise_advanced_bible_add_books_with_last_id_found(self): @@ -515,8 +514,8 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_import_click() # THEN: BibleImport wizard should have been instianted and reload_bibles should not have been called - self.assertTrue(mocked_bible_import_form.called) - self.assertFalse(mocked_reload_bibles.called) + assert mocked_bible_import_form.called is True + assert mocked_reload_bibles.called is False def test_on_import_click_wizard_not_canceled(self): """ @@ -532,8 +531,8 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_import_click() # THEN: BibleImport wizard should have been instianted and reload_bibles should not have been called - self.assertFalse(mocked_import_wizard.called) - self.assertTrue(mocked_reload_bibles.called) + assert mocked_import_wizard.called is False + assert mocked_reload_bibles.called is True def test_on_edit_click_no_bible(self): """ @@ -547,7 +546,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_edit_click() # THEN: EditBibleForm should not have been instianted - self.assertFalse(mocked_edit_bible_form.called) + assert mocked_edit_bible_form.called is False def test_on_edit_click_user_cancel_edit_form(self): """ @@ -565,8 +564,8 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_edit_click() # THEN: EditBibleForm should have been been instianted but reload_bibles should not have been called - self.assertTrue(mocked_edit_bible_form.called) - self.assertFalse(mocked_reload_bibles.called) + assert mocked_edit_bible_form.called is True + assert mocked_reload_bibles.called is False def test_on_edit_click_user_accepts_edit_form(self): """ @@ -585,8 +584,8 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_edit_click() # THEN: EditBibleForm should have been been instianted and reload_bibles should have been called - self.assertTrue(mocked_edit_bible_form.called) - self.assertTrue(mocked_reload_bibles.called) + assert mocked_edit_bible_form.called is True + assert mocked_reload_bibles.called is True def test_on_delete_click_no_bible(self): """ @@ -600,7 +599,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_delete_click() # THEN: QMessageBox.question should not have been called - self.assertFalse(mocked_qmessage_box.question.called) + assert mocked_qmessage_box.question.called is False def test_on_delete_click_response_no(self): """ @@ -615,8 +614,8 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_delete_click() # THEN: QMessageBox.question should have been called, but the delete_bible should not have been called - self.assertTrue(mocked_qmessage_box.called) - self.assertFalse(self.mocked_plugin.manager.delete_bible.called) + assert mocked_qmessage_box.called is True + assert self.mocked_plugin.manager.delete_bible.called is False def test_on_delete_click_response_yes(self): """ @@ -632,8 +631,8 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_delete_click() # THEN: QMessageBox.question should and delete_bible should not have been called - self.assertTrue(mocked_qmessage_box.called) - self.assertTrue(self.mocked_plugin.manager.delete_bible.called) + assert mocked_qmessage_box.called is True + assert self.mocked_plugin.manager.delete_bible.called is True def test_on_search_tab_bar_current_changed_search_tab_selected(self): """ @@ -711,8 +710,8 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_clear_button_clicked() # THEN: The list_view and the search_edit should be cleared - self.assertEqual(self.media_item.current_results, []) - self.assertEqual(self.media_item.list_view.takeItem.call_count, 2) + assert self.media_item.current_results == [] + assert self.media_item.list_view.takeItem.call_count == 2 self.media_item.list_view.row.assert_has_calls([call('Some'), call('Results')]) def test_on_save_results_button_clicked(self): @@ -733,7 +732,7 @@ class TestMediaItem(TestCase, TestMixin): # THEN: The selected results in the list_view should be added to the 'saved_results' list. And the saved_tab # total should be updated. - self.assertEqual(self.media_item.saved_results, ['R1', 'R2', 'R3']) + assert self.media_item.saved_results == ['R1', 'R2', 'R3'] mocked_on_results_view_tab_total_update.assert_called_once_with(ResultsTab.Saved) def test_on_style_combo_box_changed(self): @@ -746,8 +745,8 @@ class TestMediaItem(TestCase, TestMixin): # WHEN: Calling on_style_combo_box_index_changed self.media_item.on_style_combo_box_index_changed(2) - # THEN: The layput_style settimg should have been set - self.assertEqual(self.media_item.settings.layout_style, 2) + # THEN: The layout_style setting should have been set + assert self.media_item.settings.layout_style == 2 self.media_item.settings.layout_style_combo_box.setCurrentIndex.assert_called_once_with(2) self.mocked_settings_instance.setValue.assert_called_once_with('bibles/verse layout style', 2) @@ -763,9 +762,9 @@ class TestMediaItem(TestCase, TestMixin): # WHEN: Calling on_version_combo_box_index_changed self.media_item.on_version_combo_box_index_changed() - # THEN: The vesion should be saved to settings and the 'select tab' should be initialised - self.assertFalse(self.mocked_settings_instance.setValue.called) - self.assertTrue(self.media_item.initialise_advanced_bible.called) + # THEN: The version should be saved to settings and the 'select tab' should be initialised + assert self.mocked_settings_instance.setValue.called is False + assert self.media_item.initialise_advanced_bible.called is True def test_on_version_combo_box_index_changed_bible_selected(self): """ @@ -781,9 +780,9 @@ class TestMediaItem(TestCase, TestMixin): # WHEN: Calling on_version_combo_box_index_changed self.media_item.on_version_combo_box_index_changed() - # THEN: The vesion should be saved to settings and the 'select tab' should be initialised + # THEN: The version should be saved to settings and the 'select tab' should be initialised self.mocked_settings_instance.setValue.assert_called_once_with('bibles/primary bible', 'ABC') - self.assertTrue(self.media_item.initialise_advanced_bible.called) + assert self.media_item.initialise_advanced_bible.called is True def test_on_second_combo_box_index_changed_mode_not_changed(self): """ @@ -798,15 +797,15 @@ class TestMediaItem(TestCase, TestMixin): patch('openlp.plugins.bibles.lib.mediaitem.critical_error_message_box') \ as mocked_critical_error_message_box: - # WHEN: The previously selected bible is one bible and the new selection is annother bible + # WHEN: The previously selected bible is one bible and the new selection is another bible self.media_item.second_bible = self.mocked_bible_1 self.media_item.second_combo_box = MagicMock(**{'currentData.return_value': self.mocked_bible_2}) self.media_item.on_second_combo_box_index_changed(5) # THEN: The new bible should now be the current bible - self.assertFalse(mocked_critical_error_message_box.called) + assert mocked_critical_error_message_box.called is False self.media_item.style_combo_box.setEnabled.assert_called_once_with(False) - self.assertEqual(self.media_item.second_bible, self.mocked_bible_2) + assert self.media_item.second_bible == self.mocked_bible_2 def test_on_second_combo_box_index_changed_single_to_dual_user_abort(self): """ @@ -828,11 +827,11 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.saved_results = ['saved_results'] self.media_item.on_second_combo_box_index_changed(5) - # THEN: The list_view should be cleared and the currently selected bible should not be channged - self.assertTrue(mocked_critical_error_message_box.called) - self.assertTrue(self.media_item.second_combo_box.setCurrentIndex.called) - self.assertFalse(self.media_item.style_combo_box.setEnabled.called) - self.assertEqual(self.media_item.second_bible, None) + # THEN: The list_view should be cleared and the currently selected bible should not be changed + assert mocked_critical_error_message_box.called is True + assert self.media_item.second_combo_box.setCurrentIndex.called is True + assert self.media_item.style_combo_box.setEnabled.called is False + assert self.media_item.second_bible is None def test_on_second_combo_box_index_changed_single_to_dual(self): """ @@ -857,10 +856,10 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_second_combo_box_index_changed(5) # THEN: The selected bible should be set as the current bible - self.assertTrue(mocked_critical_error_message_box.called) + assert mocked_critical_error_message_box.called is True self.media_item.style_combo_box.setEnabled.assert_called_once_with(False) - self.assertTrue(mocked_initialise_advanced_bible.called) - self.assertEqual(self.media_item.second_bible, self.mocked_bible_1) + assert mocked_initialise_advanced_bible.called is True + assert self.media_item.second_bible == self.mocked_bible_1 def test_on_second_combo_box_index_changed_dual_to_single(self): """ @@ -884,10 +883,10 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_second_combo_box_index_changed(0) # THEN: The selected bible should be set as the current bible - self.assertTrue(mocked_critical_error_message_box.called) + assert mocked_critical_error_message_box.called is True self.media_item.style_combo_box.setEnabled.assert_called_once_with(True) - self.assertFalse(mocked_initialise_advanced_bible.called) - self.assertEqual(self.media_item.second_bible, None) + assert mocked_initialise_advanced_bible.called is False + assert self.media_item.second_bible is None def test_on_advanced_book_combo_box(self): """ @@ -907,7 +906,7 @@ class TestMediaItem(TestCase, TestMixin): # THEN: The user should be informed that the bible cannot be used and the search button should be disabled self.mocked_plugin.manager.get_book_by_id.assert_called_once_with('Bible 1', 2) self.media_item.search_button.setEnabled.assert_called_once_with(False) - self.assertTrue(mocked_critical_error_message_box.called) + assert mocked_critical_error_message_box.called is True def test_on_advanced_book_combo_box_set_up_comboboxes(self): """ @@ -930,7 +929,7 @@ class TestMediaItem(TestCase, TestMixin): # THEN: The verse selection combobox's should be set up self.mocked_plugin.manager.get_book_by_id.assert_called_once_with('Bible 1', 2) self.media_item.search_button.setEnabled.assert_called_once_with(True) - self.assertEqual(mocked_adjust_combo_box.call_count, 4) + assert mocked_adjust_combo_box.call_count == 4 def test_on_from_chapter_activated_invalid_to_chapter(self): """ @@ -951,9 +950,9 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_from_chapter_activated() # THEN: The to_verse and to_chapter comboboxes should be updated appropriately - self.assertEqual(mocked_adjust_combo_box.call_args_list, [ + assert mocked_adjust_combo_box.call_args_list == [ call(1, 20, self.media_item.from_verse), call(1, 20, self.media_item.to_verse, False), - call(10, 25, self.media_item.to_chapter, False)]) + call(10, 25, self.media_item.to_chapter, False)] def test_on_from_chapter_activated_same_chapter(self): """ @@ -974,9 +973,9 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_from_chapter_activated() # THEN: The to_verse and to_chapter comboboxes should be updated appropriately - self.assertEqual(mocked_adjust_combo_box.call_args_list, [ + assert mocked_adjust_combo_box.call_args_list == [ call(1, 20, self.media_item.from_verse), call(1, 20, self.media_item.to_verse, True), - call(5, 25, self.media_item.to_chapter, False)]) + call(5, 25, self.media_item.to_chapter, False)] def test_on_from_chapter_activated_lower_chapter(self): """ @@ -996,8 +995,8 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_from_chapter_activated() # THEN: The to_verse and to_chapter comboboxes should be updated appropriately - self.assertEqual(mocked_adjust_combo_box.call_args_list, [ - call(1, 20, self.media_item.from_verse), call(5, 25, self.media_item.to_chapter, True)]) + assert mocked_adjust_combo_box.call_args_list == [ + call(1, 20, self.media_item.from_verse), call(5, 25, self.media_item.to_chapter, True)] def test_on_from_verse(self): """ @@ -1012,7 +1011,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_from_verse() # THEN: select_book_combo_box.currentData should nto be called - self.assertFalse(self.media_item.select_book_combo_box.currentData.called) + assert self.media_item.select_book_combo_box.currentData.called is False def test_on_from_verse_equal(self): """ @@ -1107,8 +1106,8 @@ class TestMediaItem(TestCase, TestMixin): # THEN: The combo_box should be cleared, and new items added mocked_combo_box.clear.assert_called_once_with() - self.assertEqual(mocked_combo_box.addItem.call_args_list, - [call('10', 10), call('11', 11), call('12', 12), call('13', 13)]) + assert mocked_combo_box.addItem.call_args_list == \ + [call('10', 10), call('11', 11), call('12', 12), call('13', 13)] def test_adjust_combo_box_restore_found(self): """ @@ -1123,8 +1122,8 @@ class TestMediaItem(TestCase, TestMixin): # THEN: The combo_box should be cleared, and new items added. Finally the previously selected item should be # reselected mocked_combo_box.clear.assert_called_once_with() - self.assertEqual(mocked_combo_box.addItem.call_args_list, - [call('10', 10), call('11', 11), call('12', 12), call('13', 13)]) + assert mocked_combo_box.addItem.call_args_list == \ + [call('10', 10), call('11', 11), call('12', 12), call('13', 13)] mocked_combo_box.setCurrentIndex.assert_called_once_with(2) def test_adjust_combo_box_restore_not_found(self): @@ -1140,8 +1139,8 @@ class TestMediaItem(TestCase, TestMixin): # THEN: The combo_box should be cleared, and new items added. Finally the first item should be selected mocked_combo_box.clear.assert_called_once_with() - self.assertEqual(mocked_combo_box.addItem.call_args_list, - [call('10', 10), call('11', 11), call('12', 12), call('13', 13)]) + assert mocked_combo_box.addItem.call_args_list == \ + [call('10', 10), call('11', 11), call('12', 12), call('13', 13)] mocked_combo_box.setCurrentIndex.assert_called_once_with(0) def test_on_search_button_no_bible(self): @@ -1154,7 +1153,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_search_button_clicked() # THEN: The user should be informed that there are no bibles selected - self.assertEqual(self.mocked_main_window.information_message.call_count, 1) + assert self.mocked_main_window.information_message.call_count == 1 def test_on_search_button_search_tab(self): """ @@ -1207,7 +1206,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.select_search() # THEN: reference_search should only be called once - self.assertEqual(self.mocked_plugin.manager.get_verses.call_count, 1) + assert self.mocked_plugin.manager.get_verses.call_count == 1 mocked_display_results.assert_called_once_with() def test_select_search_dual_bibles(self): @@ -1228,7 +1227,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.select_search() # THEN: reference_search should be called twice - self.assertEqual(self.mocked_plugin.manager.get_verses.call_count, 2) + assert self.mocked_plugin.manager.get_verses.call_count == 2 mocked_display_results.assert_called_once_with() def test_text_reference_search_single_bible(self): @@ -1244,7 +1243,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.text_reference_search('Search Text') # THEN: reference_search should only be called once - self.assertEqual(self.mocked_plugin.manager.get_verses.call_count, 1) + assert self.mocked_plugin.manager.get_verses.call_count == 1 mocked_display_results.assert_called_once_with() def text_reference_search(self, search_text, search_while_type=False): @@ -1272,7 +1271,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.text_reference_search('Search Text') # THEN: reference_search should only be called once - self.assertEqual(self.mocked_plugin.manager.get_verses.call_count, 1) + assert self.mocked_plugin.manager.get_verses.call_count == 1 mocked_display_results.assert_called_once_with() def test_text_reference_search_dual_bible(self): @@ -1288,7 +1287,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.text_reference_search('Search Text') # THEN: reference_search should be called twice - self.assertEqual(self.mocked_plugin.manager.get_verses.call_count, 2) + assert self.mocked_plugin.manager.get_verses.call_count == 2 mocked_display_results.assert_called_once_with() def test_on_text_search_single_bible(self): @@ -1305,7 +1304,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_text_search('Search Text') # THEN: The search results should be the same as those returned by plugin.manager.verse_search - self.assertEqual(self.media_item.search_results, ['results', 'list']) + assert self.media_item.search_results == ['results', 'list'] mocked_display_results.assert_called_once_with() def test_on_text_search_no_results(self): @@ -1322,7 +1321,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_text_search('Search Text') # THEN: The search results should be an empty list - self.assertEqual(self.media_item.search_results, []) + assert self.media_item.search_results == [] mocked_display_results.assert_called_once_with() def test_on_text_search_all_results_in_both_books(self): @@ -1345,10 +1344,10 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_text_search('Search Text') # THEN: The search results for both bibles should be returned - self.assertEqual(self.media_item.search_results, [mocked_verse_1, mocked_verse_2]) - self.assertEqual(self.media_item.second_search_results, [mocked_verse_1a, mocked_verse_2a]) - self.assertFalse(self.mocked_log.debug.called) - self.assertFalse(self.mocked_main_window.information_message.called) + assert self.media_item.search_results == [mocked_verse_1, mocked_verse_2] + assert self.media_item.second_search_results == [mocked_verse_1a, mocked_verse_2a] + assert self.mocked_log.debug.called is False + assert self.mocked_main_window.information_message.called is False mocked_display_results.assert_called_once_with() def test_on_text_search_not_all_results_in_both_books(self): @@ -1372,10 +1371,10 @@ class TestMediaItem(TestCase, TestMixin): # THEN: The search results included in both bibles should be returned and the user should be notified of # the missing verses - self.assertEqual(self.media_item.search_results, [mocked_verse_1]) - self.assertEqual(self.media_item.second_search_results, [mocked_verse_1a]) - self.assertEqual(self.mocked_log.debug.call_count, 2) - self.assertTrue(self.mocked_main_window.information_message.called) + assert self.media_item.search_results == [mocked_verse_1] + assert self.media_item.second_search_results == [mocked_verse_1a] + assert self.mocked_log.debug.call_count == 2 + assert self.mocked_main_window.information_message.called is True mocked_display_results.assert_called_once_with() def test_on_search_edit_text_changed_search_while_typing_disabled(self): @@ -1391,7 +1390,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_search_edit_text_changed() # THEN: The method should not have checked if the timer is active - self.assertFalse(self.media_item.search_timer.isActive.called) + assert self.media_item.search_timer.isActive.called is False def test_on_search_edit_text_changed_search_while_typing_enabled(self): """ @@ -1422,7 +1421,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.on_search_timer_timeout() # THEN: The search_status should be set to SearchAsYouType and text_search should have been called - self.assertEqual(self.media_item.search_status, SearchStatus.SearchAsYouType) + assert self.media_item.search_status == SearchStatus.SearchAsYouType mocked_text_search.assert_called_once_with() def test_display_results_no_results(self): @@ -1441,7 +1440,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.display_results() # THEN: No items should be added to the list - self.assertFalse(self.media_item.list_view.addItem.called) + assert self.media_item.list_view.addItem.called is False def test_display_results_results(self): """ diff --git a/tests/functional/openlp_plugins/bibles/test_opensongimport.py b/tests/functional/openlp_plugins/bibles/test_opensongimport.py index eab4d33a9..d02fffd5e 100644 --- a/tests/functional/openlp_plugins/bibles/test_opensongimport.py +++ b/tests/functional/openlp_plugins/bibles/test_opensongimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,22 +22,19 @@ """ This module contains tests for the OpenSong Bible importer. """ -import json -import os from unittest import TestCase from unittest.mock import MagicMock, patch, call from lxml import objectify -from openlp.core.common.path import Path from openlp.core.common.registry import Registry -from openlp.plugins.bibles.lib.importers.opensong import OpenSongBible, get_text, parse_chapter_number from openlp.plugins.bibles.lib.bibleimport import BibleImport - +from openlp.plugins.bibles.lib.importers.opensong import OpenSongBible, get_text, parse_chapter_number from tests.helpers.testmixin import TestMixin +from tests.utils import load_external_result_data +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), - '..', '..', '..', 'resources', 'bibles')) +TEST_PATH = RESOURCE_PATH / 'bibles' class TestOpenSongImport(TestCase, TestMixin): @@ -68,7 +65,7 @@ class TestOpenSongImport(TestCase, TestMixin): importer = OpenSongBible(mocked_manager, path='.', name='.', file_path=None) # THEN: The importer should be an instance of BibleDB - self.assertIsInstance(importer, BibleImport) + assert isinstance(importer, BibleImport) def test_get_text_no_text(self): """ @@ -81,7 +78,7 @@ class TestOpenSongImport(TestCase, TestMixin): result = get_text(test_data) # THEN: A blank string should be returned - self.assertEqual(result, '') + assert result == '' def test_get_text_text(self): """ @@ -98,7 +95,7 @@ class TestOpenSongImport(TestCase, TestMixin): result = get_text(test_data) # THEN: The text returned should be as expected - self.assertEqual(result, 'Element text sub_text_tail text sub_text_tail tail sub_text text sub_tail tail') + assert result == 'Element text sub_text_tail text sub_text_tail tail sub_text text sub_tail tail' def test_parse_chapter_number(self): """ @@ -109,7 +106,7 @@ class TestOpenSongImport(TestCase, TestMixin): result = parse_chapter_number('10', 0) # THEN: The 10 should be returned as an Int - self.assertEqual(result, 10) + assert result == 10 def test_parse_chapter_number_empty_attribute(self): """ @@ -120,7 +117,7 @@ class TestOpenSongImport(TestCase, TestMixin): result = parse_chapter_number('', 12) # THEN: parse_chapter_number should increment the previous verse number - self.assertEqual(result, 13) + assert result == 13 def test_parse_verse_number_valid_verse_no(self): """ @@ -133,7 +130,7 @@ class TestOpenSongImport(TestCase, TestMixin): result = importer.parse_verse_number('15', 0) # THEN: parse_verse_number should return the verse number - self.assertEqual(result, 15) + assert result == 15 def test_parse_verse_number_verse_range(self): """ @@ -146,7 +143,7 @@ class TestOpenSongImport(TestCase, TestMixin): result = importer.parse_verse_number('24-26', 0) # THEN: parse_verse_number should return the first verse number in the range - self.assertEqual(result, 24) + assert result == 24 def test_parse_verse_number_invalid_verse_no(self): """ @@ -159,7 +156,7 @@ class TestOpenSongImport(TestCase, TestMixin): result = importer.parse_verse_number('invalid', 41) # THEN: parse_verse_number should increment the previous verse number - self.assertEqual(result, 42) + assert result == 42 def test_parse_verse_number_empty_attribute(self): """ @@ -171,7 +168,7 @@ class TestOpenSongImport(TestCase, TestMixin): result = importer.parse_verse_number('', 14) # THEN: parse_verse_number should increment the previous verse number - self.assertEqual(result, 15) + assert result == 15 def test_parse_verse_number_invalid_type(self): """ @@ -187,7 +184,7 @@ class TestOpenSongImport(TestCase, TestMixin): # THEN: parse_verse_number should log the verse number it was called with increment the previous verse # number mocked_log_warning.assert_called_once_with('Illegal verse number: (1, 2, 3)') - self.assertEqual(result, 13) + assert result == 13 def test_process_books_stop_import(self): """ @@ -201,7 +198,7 @@ class TestOpenSongImport(TestCase, TestMixin): importer.process_books(['Book']) # THEN: find_and_create_book should not have been called - self.assertFalse(self.mocked_find_and_create_book.called) + assert self.mocked_find_and_create_book.called is False def test_process_books_completes(self): """ @@ -226,11 +223,10 @@ class TestOpenSongImport(TestCase, TestMixin): importer.process_books([book1, book2]) # THEN: find_and_create_book and process_books should be called with the details from the mocked books - self.assertEqual(self.mocked_find_and_create_book.call_args_list, - [call('Name1', 2, 10), call('Name2', 2, 10)]) - self.assertEqual(mocked_process_chapters.call_args_list, - [call('db_book1', 'Chapter1'), call('db_book2', 'Chapter2')]) - self.assertEqual(importer.session.commit.call_count, 2) + assert self.mocked_find_and_create_book.call_args_list == [call('Name1', 2, 10), call('Name2', 2, 10)] + assert mocked_process_chapters.call_args_list == \ + [call('db_book1', 'Chapter1'), call('db_book2', 'Chapter2')] + assert importer.session.commit.call_count == 2 def test_process_chapters_stop_import(self): """ @@ -245,7 +241,7 @@ class TestOpenSongImport(TestCase, TestMixin): importer.process_chapters('Book', ['Chapter1']) # THEN: importer.parse_chapter_number not have been called - self.assertFalse(importer.parse_chapter_number.called) + assert importer.parse_chapter_number.called is False @patch('openlp.plugins.bibles.lib.importers.opensong.parse_chapter_number', **{'side_effect': [1, 2]}) def test_process_chapters_completes(self, mocked_parse_chapter_number): @@ -273,12 +269,11 @@ class TestOpenSongImport(TestCase, TestMixin): importer.process_chapters(book, [chapter1, chapter2]) # THEN: parse_chapter_number, process_verses and increment_process_bar should have been called - self.assertEqual(mocked_parse_chapter_number.call_args_list, [call('1', 0), call('2', 1)]) - self.assertEqual( - importer.process_verses.call_args_list, - [call(book, 1, ['Chapter1 Verses']), call(book, 2, ['Chapter2 Verses'])]) - self.assertEqual(importer.wizard.increment_progress_bar.call_args_list, - [call('Importing Book 1...'), call('Importing Book 2...')]) + assert mocked_parse_chapter_number.call_args_list == [call('1', 0), call('2', 1)] + assert importer.process_verses.call_args_list == \ + [call(book, 1, ['Chapter1 Verses']), call(book, 2, ['Chapter2 Verses'])] + assert importer.wizard.increment_progress_bar.call_args_list == [call('Importing Book 1...'), + call('Importing Book 2...')] def test_process_verses_stop_import(self): """ @@ -293,7 +288,7 @@ class TestOpenSongImport(TestCase, TestMixin): importer.process_verses('Book', 1, 'Verses') # THEN: importer.parse_verse_number not have been called - self.assertFalse(importer.parse_verse_number.called) + assert importer.parse_verse_number.called is False def test_process_verses_completes(self): """ @@ -324,11 +319,10 @@ class TestOpenSongImport(TestCase, TestMixin): importer.process_verses(book, 1, [verse1, verse2]) # THEN: parse_chapter_number, process_verses and increment_process_bar should have been called - self.assertEqual(mocked_parse_verse_number.call_args_list, [call('1', 0), call('2', 1)]) - self.assertEqual(mocked_get_text.call_args_list, [call(verse1), call(verse2)]) - self.assertEqual( - importer.create_verse.call_args_list, - [call(1, 1, 1, 'Verse1 Text'), call(1, 1, 2, 'Verse2 Text')]) + assert mocked_parse_verse_number.call_args_list == [call('1', 0), call('2', 1)] + assert mocked_get_text.call_args_list == [call(verse1), call(verse2)] + assert importer.create_verse.call_args_list == \ + [call(1, 1, 1, 'Verse1 Text'), call(1, 1, 2, 'Verse2 Text')] def test_do_import_parse_xml_fails(self): """ @@ -345,8 +339,8 @@ class TestOpenSongImport(TestCase, TestMixin): result = importer.do_import() # THEN: do_import should return False and get_language_id should have not been called - self.assertFalse(result) - self.assertFalse(mocked_language_id.called) + assert result is False + assert mocked_language_id.called is False def test_do_import_no_language(self): """ @@ -364,8 +358,8 @@ class TestOpenSongImport(TestCase, TestMixin): result = importer.do_import() # THEN: do_import should return False and process_books should have not been called - self.assertFalse(result) - self.assertFalse(mocked_process_books.called) + assert result is False + assert mocked_process_books.called is False def test_do_import_completes(self): """ @@ -383,7 +377,7 @@ class TestOpenSongImport(TestCase, TestMixin): result = importer.do_import() # THEN: do_import should return True - self.assertTrue(result) + assert result is True class TestOpenSongImportFileImports(TestCase, TestMixin): @@ -401,8 +395,7 @@ class TestOpenSongImportFileImports(TestCase, TestMixin): """ # GIVEN: Test files with a mocked out "manager", "import_wizard", and mocked functions # get_book_ref_id_by_name, create_verse, create_book, session and get_language. - result_file = open(os.path.join(TEST_PATH, 'dk1933.json'), 'rb') - test_data = json.loads(result_file.read().decode()) + test_data = load_external_result_data(TEST_PATH / 'dk1933.json') bible_file = 'opensong-dk1933.xml' with patch('openlp.plugins.bibles.lib.importers.opensong.OpenSongBible.application'): mocked_manager = MagicMock() @@ -417,10 +410,10 @@ class TestOpenSongImportFileImports(TestCase, TestMixin): importer.get_language.return_value = 'Danish' # WHEN: Importing bible file - importer.file_path = Path(TEST_PATH, bible_file) + importer.file_path = TEST_PATH / bible_file importer.do_import() # THEN: The create_verse() method should have been called with each verse in the file. - self.assertTrue(importer.create_verse.called) + assert importer.create_verse.called is True for verse_tag, verse_text in test_data['verses']: importer.create_verse.assert_any_call(importer.create_book().id, 1, int(verse_tag), verse_text) diff --git a/tests/functional/openlp_plugins/bibles/test_osisimport.py b/tests/functional/openlp_plugins/bibles/test_osisimport.py index 02c6c3654..93cc7d05d 100644 --- a/tests/functional/openlp_plugins/bibles/test_osisimport.py +++ b/tests/functional/openlp_plugins/bibles/test_osisimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,17 +22,16 @@ """ This module contains tests for the OSIS Bible importer. """ -import os -import json from unittest import TestCase from unittest.mock import MagicMock, call, patch -from openlp.core.common.path import Path from openlp.plugins.bibles.lib.bibleimport import BibleImport from openlp.plugins.bibles.lib.db import BibleDB from openlp.plugins.bibles.lib.importers.osis import OSISBible +from tests.utils import load_external_result_data +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'bibles')) +TEST_PATH = RESOURCE_PATH / 'bibles' class TestOsisImport(TestCase): @@ -67,7 +66,7 @@ class TestOsisImport(TestCase): importer = OSISBible(mocked_manager, path='.', name='.', file_path=None) # THEN: The importer should be an instance of BibleDB - self.assertIsInstance(importer, BibleDB) + assert isinstance(importer, BibleDB) def test_process_books_stop_import(self): """ @@ -82,7 +81,7 @@ class TestOsisImport(TestCase): importer.process_books(mocked_data) # THEN: find_and_create_book should not have been called - self.assertFalse(self.mocked_find_and_create_book.called) + assert self.mocked_find_and_create_book.called is False def test_process_books_completes(self): """ @@ -106,11 +105,9 @@ class TestOsisImport(TestCase): importer.process_books(mocked_data) # THEN: find_and_create_book and process_books should be called with the details from the mocked books - self.assertEqual(self.mocked_find_and_create_book.call_args_list, - [call('Name1', 2, 10), call('Name2', 2, 10)]) - self.assertEqual(mocked_process_chapters.call_args_list, - [call('db_book1', book1), call('db_book2', book2)]) - self.assertEqual(importer.session.commit.call_count, 2) + assert self.mocked_find_and_create_book.call_args_list == [call('Name1', 2, 10), call('Name2', 2, 10)] + assert mocked_process_chapters.call_args_list == [call('db_book1', book1), call('db_book2', book2)] + assert importer.session.commit.call_count == 2 def test_process_chapters_verse_in_chapter_verse_text(self): """ @@ -185,8 +182,8 @@ class TestOsisImport(TestCase): importer.process_chapters(test_book, [test_chapter]) # THEN: neither set_current_chapter or process_verse should have been called - self.assertFalse(mocked_set_current_chapter.called) - self.assertFalse(mocked_process_verse.called) + assert mocked_set_current_chapter.called is False + assert mocked_process_verse.called is False def test_process_chapters_milestones_chapter_sid(self): """ @@ -209,7 +206,7 @@ class TestOsisImport(TestCase): # THEN: set_current_chapter should have been called with the test data mocked_set_current_chapter.assert_called_once_with(test_book.name, 2) - self.assertFalse(mocked_process_verse.called) + assert mocked_process_verse.called is False def test_process_chapters_milestones_verse_tag(self): """ @@ -233,7 +230,7 @@ class TestOsisImport(TestCase): importer.process_chapters(test_book, [test_verse]) # THEN: process_verse should have been called with the test data - self.assertFalse(mocked_set_current_chapter.called) + assert mocked_set_current_chapter.called is False mocked_process_verse.assert_called_once_with(test_book, 0, test_verse, use_milestones=True) def test_process_verse_no_osis_id(self): @@ -252,7 +249,7 @@ class TestOsisImport(TestCase): importer.process_verse(test_book, 2, test_verse) # THEN: create_verse should not have been called - self.assertFalse(self.mocked_create_verse.called) + assert self.mocked_create_verse.called is False def test_process_verse_use_milestones_no_s_id(self): """ @@ -271,7 +268,7 @@ class TestOsisImport(TestCase): importer.process_verse(test_book, 2, test_verse) # THEN: create_verse should not have been called - self.assertFalse(self.mocked_create_verse.called) + assert self.mocked_create_verse.called is False def test_process_verse_use_milestones_no_tail(self): """ @@ -289,7 +286,7 @@ class TestOsisImport(TestCase): importer.process_verse(test_book, 2, test_verse, use_milestones=True) # THEN: create_verse should not have been called - self.assertFalse(self.mocked_create_verse.called) + assert self.mocked_create_verse.called is False def test_process_verse_use_milestones_success(self): """ @@ -327,7 +324,7 @@ class TestOsisImport(TestCase): importer.process_verse(test_book, 2, test_verse) # THEN: create_verse should not have been called - self.assertFalse(self.mocked_create_verse.called) + assert self.mocked_create_verse.called is False def test_process_verse_success(self): """ @@ -363,8 +360,8 @@ class TestOsisImport(TestCase): result = importer.do_import() # THEN: do_import should return False and get_language_id should have not been called - self.assertFalse(result) - self.assertFalse(mocked_language_id.called) + assert result is False + assert mocked_language_id.called is False def test_do_import_no_language(self): """ @@ -382,8 +379,8 @@ class TestOsisImport(TestCase): result = importer.do_import() # THEN: do_import should return False and process_books should have not been called - self.assertFalse(result) - self.assertFalse(mocked_process_books.called) + assert result is False + assert mocked_process_books.called is False def test_do_import_completes(self): """ @@ -401,7 +398,7 @@ class TestOsisImport(TestCase): result = importer.do_import() # THEN: do_import should return True - self.assertTrue(result) + assert result is True class TestOsisImportFileImports(TestCase): @@ -422,8 +419,7 @@ class TestOsisImportFileImports(TestCase): """ # GIVEN: Test files with a mocked out "manager", "import_wizard", and mocked functions # get_book_ref_id_by_name, create_verse, create_book, session and get_language. - result_file = open(os.path.join(TEST_PATH, 'dk1933.json'), 'rb') - test_data = json.loads(result_file.read().decode()) + test_data = load_external_result_data(TEST_PATH / 'dk1933.json') bible_file = 'osis-dk1933.xml' with patch('openlp.plugins.bibles.lib.importers.osis.OSISBible.application'): mocked_manager = MagicMock() @@ -438,11 +434,11 @@ class TestOsisImportFileImports(TestCase): importer.get_language.return_value = 'Danish' # WHEN: Importing bible file - importer.file_path = Path(TEST_PATH, bible_file) + importer.file_path = TEST_PATH / bible_file importer.do_import() # THEN: The create_verse() method should have been called with each verse in the file. - self.assertTrue(importer.create_verse.called) + assert importer.create_verse.called is True for verse_tag, verse_text in test_data['verses']: importer.create_verse.assert_any_call(importer.create_book().id, 1, verse_tag, verse_text) @@ -452,8 +448,7 @@ class TestOsisImportFileImports(TestCase): """ # GIVEN: Test files with a mocked out "manager", "import_wizard", and mocked functions # get_book_ref_id_by_name, create_verse, create_book, session and get_language. - result_file = open(os.path.join(TEST_PATH, 'kjv.json'), 'rb') - test_data = json.loads(result_file.read().decode()) + test_data = load_external_result_data(TEST_PATH / 'kjv.json') bible_file = 'osis-kjv.xml' with patch('openlp.plugins.bibles.lib.importers.osis.OSISBible.application'): mocked_manager = MagicMock() @@ -468,11 +463,11 @@ class TestOsisImportFileImports(TestCase): importer.get_language.return_value = 'English' # WHEN: Importing bible file - importer.file_path = Path(TEST_PATH, bible_file) + importer.file_path = TEST_PATH / bible_file importer.do_import() # THEN: The create_verse() method should have been called with each verse in the file. - self.assertTrue(importer.create_verse.called) + assert importer.create_verse.called is True for verse_tag, verse_text in test_data['verses']: importer.create_verse.assert_any_call(importer.create_book().id, 1, verse_tag, verse_text) @@ -482,8 +477,7 @@ class TestOsisImportFileImports(TestCase): """ # GIVEN: Test files with a mocked out "manager", "import_wizard", and mocked functions # get_book_ref_id_by_name, create_verse, create_book, session and get_language. - result_file = open(os.path.join(TEST_PATH, 'web.json'), 'rb') - test_data = json.loads(result_file.read().decode()) + test_data = load_external_result_data(TEST_PATH / 'web.json') bible_file = 'osis-web.xml' with patch('openlp.plugins.bibles.lib.importers.osis.OSISBible.application'): mocked_manager = MagicMock() @@ -498,11 +492,11 @@ class TestOsisImportFileImports(TestCase): importer.get_language.return_value = 'English' # WHEN: Importing bible file - importer.file_path = Path(TEST_PATH, bible_file) + importer.file_path = TEST_PATH / bible_file importer.do_import() # THEN: The create_verse() method should have been called with each verse in the file. - self.assertTrue(importer.create_verse.called) + assert importer.create_verse.called for verse_tag, verse_text in test_data['verses']: importer.create_verse.assert_any_call(importer.create_book().id, 1, verse_tag, verse_text) @@ -512,8 +506,7 @@ class TestOsisImportFileImports(TestCase): """ # GIVEN: Test files with a mocked out "manager", "import_wizard", and mocked functions # get_book_ref_id_by_name, create_verse, create_book, session and get_language. - result_file = open(os.path.join(TEST_PATH, 'dk1933.json'), 'rb') - test_data = json.loads(result_file.read().decode()) + test_data = load_external_result_data(TEST_PATH / 'dk1933.json') bible_file = 'osis-dk1933-empty-verse.xml' with patch('openlp.plugins.bibles.lib.importers.osis.OSISBible.application'): mocked_manager = MagicMock() @@ -528,10 +521,10 @@ class TestOsisImportFileImports(TestCase): importer.get_language.return_value = 'Danish' # WHEN: Importing bible file - importer.file_path = Path(TEST_PATH, bible_file) + importer.file_path = TEST_PATH / bible_file importer.do_import() # THEN: The create_verse() method should have been called with each verse in the file. - self.assertTrue(importer.create_verse.called) + assert importer.create_verse.called is True for verse_tag, verse_text in test_data['verses']: importer.create_verse.assert_any_call(importer.create_book().id, 1, verse_tag, verse_text) diff --git a/tests/functional/openlp_plugins/bibles/test_swordimport.py b/tests/functional/openlp_plugins/bibles/test_swordimport.py index 34e011498..aecf5c597 100644 --- a/tests/functional/openlp_plugins/bibles/test_swordimport.py +++ b/tests/functional/openlp_plugins/bibles/test_swordimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,9 +22,6 @@ """ This module contains tests for the SWORD Bible importer. """ - -import os -import json from unittest import TestCase, skipUnless from unittest.mock import MagicMock, patch @@ -36,8 +33,10 @@ except ImportError: from openlp.plugins.bibles.lib.db import BibleDB -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), - '..', '..', '..', 'resources', 'bibles')) +from tests.utils import load_external_result_data +from tests.utils.constants import RESOURCE_PATH + +TEST_PATH = RESOURCE_PATH / 'bibles' @skipUnless(HAS_PYSWORD, 'pysword not installed') @@ -67,7 +66,7 @@ class TestSwordImport(TestCase): importer = SwordBible(mocked_manager, path='.', name='.', file_path=None, sword_key='', sword_path='') # THEN: The importer should be an instance of BibleDB - self.assertIsInstance(importer, BibleDB) + assert isinstance(importer, BibleDB) @patch('openlp.plugins.bibles.lib.importers.sword.SwordBible.application') @patch('openlp.plugins.bibles.lib.importers.sword.modules') @@ -81,8 +80,7 @@ class TestSwordImport(TestCase): mocked_manager = MagicMock() mocked_import_wizard = MagicMock() importer = SwordBible(mocked_manager, path='.', name='.', file_path=None, sword_key='', sword_path='') - result_file = open(os.path.join(TEST_PATH, 'dk1933.json'), 'rb') - test_data = json.loads(result_file.read().decode()) + test_data = load_external_result_data(TEST_PATH / 'dk1933.json') importer.wizard = mocked_import_wizard importer.get_book_ref_id_by_name = MagicMock() importer.create_verse = MagicMock() @@ -106,6 +104,6 @@ class TestSwordImport(TestCase): importer.do_import() # THEN: The create_verse() method should have been called with each verse in the file. - self.assertTrue(importer.create_verse.called) + assert importer.create_verse.called is True for verse_tag, verse_text in test_data['verses']: importer.create_verse.assert_any_call(importer.create_book().id, 1, int(verse_tag), verse_text) diff --git a/tests/functional/openlp_plugins/bibles/test_versereferencelist.py b/tests/functional/openlp_plugins/bibles/test_versereferencelist.py index b40db5076..b88af89c3 100644 --- a/tests/functional/openlp_plugins/bibles/test_versereferencelist.py +++ b/tests/functional/openlp_plugins/bibles/test_versereferencelist.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -48,14 +48,12 @@ class TestVerseReferenceList(TestCase): reference_list.add(book, chapter, verse, version, copyright_, permission) # THEN: The entries should be in the first entry of the list - self.assertEqual(reference_list.current_index, 0, 'The current index should be 0') - self.assertEqual(reference_list.verse_list[0]['book'], book, 'The book in first entry should be %s' % book) - self.assertEqual(reference_list.verse_list[0]['chapter'], chapter, 'The chapter in first entry should be %u' % - chapter) - self.assertEqual(reference_list.verse_list[0]['start'], verse, 'The start in first entry should be %u' % verse) - self.assertEqual(reference_list.verse_list[0]['version'], version, 'The version in first entry should be %s' % - version) - self.assertEqual(reference_list.verse_list[0]['end'], verse, 'The end in first entry should be %u' % verse) + assert reference_list.current_index == 0, 'The current index should be 0' + assert reference_list.verse_list[0]['book'] == book, 'The book in first entry should be %s' % book + assert reference_list.verse_list[0]['chapter'] == chapter, 'The chapter in first entry should be %u' % chapter + assert reference_list.verse_list[0]['start'] == verse, 'The start in first entry should be %u' % verse + assert reference_list.verse_list[0]['version'] == version, 'The version in first entry should be %s' % version + assert reference_list.verse_list[0]['end'] == verse, 'The end in first entry should be %u' % verse def test_add_next_verse(self): """ @@ -76,9 +74,8 @@ class TestVerseReferenceList(TestCase): reference_list.add(book, chapter, next_verse, version, copyright_, permission) # THEN: The current index should be 0 and the end pointer of the entry should be '2' - self.assertEqual(reference_list.current_index, 0, 'The current index should be 0') - self.assertEqual(reference_list.verse_list[0]['end'], next_verse, - 'The end in first entry should be %u' % next_verse) + assert reference_list.current_index == 0, 'The current index should be 0' + assert reference_list.verse_list[0]['end'] == next_verse, 'The end in first entry should be %u' % next_verse def test_add_another_verse(self): """ @@ -101,7 +98,7 @@ class TestVerseReferenceList(TestCase): reference_list.add(another_book, another_chapter, another_verse, version, copyright_, permission) # THEN: the current index should be 1 - self.assertEqual(reference_list.current_index, 1, 'The current index should be 1') + assert reference_list.current_index == 1, 'The current index should be 1' def test_add_version(self): """ @@ -117,10 +114,10 @@ class TestVerseReferenceList(TestCase): reference_list.add_version(version, copyright_, permission) # THEN: the data will be appended to the list - self.assertEqual(len(reference_list.version_list), 1, 'The version data should be appended') - self.assertEqual(reference_list.version_list[0], - {'version': version, 'copyright': copyright_, 'permission': permission}, - 'The version data should be appended') + assert len(reference_list.version_list) == 1, 'The version data should be appended' + assert reference_list.version_list[0] == \ + {'version': version, 'copyright': copyright_, 'permission': permission}, \ + 'The version data should be appended' def test_add_existing_version(self): """ @@ -137,4 +134,4 @@ class TestVerseReferenceList(TestCase): reference_list.add_version(version, copyright_, permission) # THEN: the data will not be appended to the list - self.assertEqual(len(reference_list.version_list), 1, 'The version data should not be appended') + assert len(reference_list.version_list) == 1, 'The version data should not be appended' diff --git a/tests/functional/openlp_plugins/bibles/test_wordprojectimport.py b/tests/functional/openlp_plugins/bibles/test_wordprojectimport.py index fbf5b0412..388da45f9 100644 --- a/tests/functional/openlp_plugins/bibles/test_wordprojectimport.py +++ b/tests/functional/openlp_plugins/bibles/test_wordprojectimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,18 +22,16 @@ """ This module contains tests for the WordProject Bible importer. """ -import os from unittest import TestCase from unittest.mock import MagicMock, patch, call from openlp.core.common.path import Path from openlp.plugins.bibles.lib.importers.wordproject import WordProjectBible +from tests.utils.constants import RESOURCE_PATH - -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), - '..', '..', '..', 'resources', 'bibles')) -INDEX_PAGE = open(os.path.join(TEST_PATH, 'wordproject_index.htm')).read() -CHAPTER_PAGE = open(os.path.join(TEST_PATH, 'wordproject_chapter.htm')).read() +TEST_PATH = RESOURCE_PATH / 'bibles' +INDEX_PAGE = (TEST_PATH / 'wordproject_index.htm').read_bytes().decode() +CHAPTER_PAGE = (TEST_PATH / 'wordproject_chapter.htm').read_bytes().decode() class TestWordProjectImport(TestCase): diff --git a/tests/functional/openlp_plugins/bibles/test_zefaniaimport.py b/tests/functional/openlp_plugins/bibles/test_zefaniaimport.py index d423a2153..3252ac152 100644 --- a/tests/functional/openlp_plugins/bibles/test_zefaniaimport.py +++ b/tests/functional/openlp_plugins/bibles/test_zefaniaimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,17 +22,15 @@ """ This module contains tests for the Zefania Bible importer. """ -import os -import json from unittest import TestCase from unittest.mock import MagicMock, patch -from openlp.core.common.path import Path -from openlp.plugins.bibles.lib.importers.zefania import ZefaniaBible from openlp.plugins.bibles.lib.db import BibleDB +from openlp.plugins.bibles.lib.importers.zefania import ZefaniaBible +from tests.utils import load_external_result_data +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), - '..', '..', '..', 'resources', 'bibles')) +TEST_PATH = RESOURCE_PATH / 'bibles' class TestZefaniaImport(TestCase): @@ -59,7 +57,7 @@ class TestZefaniaImport(TestCase): importer = ZefaniaBible(mocked_manager, path='.', name='.', file_path=None) # THEN: The importer should be an instance of BibleDB - self.assertIsInstance(importer, BibleDB) + assert isinstance(importer, BibleDB) def test_file_import(self): """ @@ -67,8 +65,7 @@ class TestZefaniaImport(TestCase): """ # GIVEN: Test files with a mocked out "manager", "import_wizard", and mocked functions # get_book_ref_id_by_name, create_verse, create_book, session and get_language. - result_file = open(os.path.join(TEST_PATH, 'dk1933.json'), 'rb') - test_data = json.loads(result_file.read().decode()) + test_data = load_external_result_data(TEST_PATH / 'dk1933.json') bible_file = 'zefania-dk1933.xml' with patch('openlp.plugins.bibles.lib.importers.zefania.ZefaniaBible.application'): mocked_manager = MagicMock() @@ -82,11 +79,11 @@ class TestZefaniaImport(TestCase): importer.get_language.return_value = 'Danish' # WHEN: Importing bible file - importer.file_path = Path(TEST_PATH, bible_file) + importer.file_path = TEST_PATH / bible_file importer.do_import() # THEN: The create_verse() method should have been called with each verse in the file. - self.assertTrue(importer.create_verse.called) + assert importer.create_verse.called is True for verse_tag, verse_text in test_data['verses']: importer.create_verse.assert_any_call(importer.create_book().id, 1, verse_tag, verse_text) importer.create_book.assert_any_call('Genesis', 1, 1) @@ -97,8 +94,7 @@ class TestZefaniaImport(TestCase): """ # GIVEN: Test files with a mocked out "manager", "import_wizard", and mocked functions # get_book_ref_id_by_name, create_verse, create_book, session and get_language. - result_file = open(os.path.join(TEST_PATH, 'rst.json'), 'rb') - test_data = json.loads(result_file.read().decode()) + test_data = load_external_result_data(TEST_PATH / 'rst.json') bible_file = 'zefania-rst.xml' with patch('openlp.plugins.bibles.lib.importers.zefania.ZefaniaBible.application'): mocked_manager = MagicMock() @@ -112,11 +108,11 @@ class TestZefaniaImport(TestCase): importer.get_language.return_value = 'Russian' # WHEN: Importing bible file - importer.file_path = Path(TEST_PATH, bible_file) + importer.file_path = TEST_PATH / bible_file importer.do_import() # THEN: The create_verse() method should have been called with each verse in the file. - self.assertTrue(importer.create_verse.called) + assert importer.create_verse.called is True for verse_tag, verse_text in test_data['verses']: importer.create_verse.assert_any_call(importer.create_book().id, 1, verse_tag, verse_text) importer.create_book.assert_any_call('Exodus', 2, 1) diff --git a/tests/functional/openlp_plugins/custom/__init__.py b/tests/functional/openlp_plugins/custom/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/functional/openlp_plugins/custom/__init__.py +++ b/tests/functional/openlp_plugins/custom/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_plugins/custom/test_mediaitem.py b/tests/functional/openlp_plugins/custom/test_mediaitem.py index d75fa727d..faa091bef 100644 --- a/tests/functional/openlp_plugins/custom/test_mediaitem.py +++ b/tests/functional/openlp_plugins/custom/test_mediaitem.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -30,7 +30,6 @@ from PyQt5 import QtCore from openlp.core.common.registry import Registry from openlp.core.lib import ServiceItem, PluginStatus from openlp.plugins.custom.lib import CustomMediaItem - from tests.helpers.testmixin import TestMixin FOOTER = ['Arky Arky (Unknown)', 'Public Domain', 'CCLI 123456'] @@ -73,7 +72,7 @@ class TestMediaItem(TestCase, TestMixin): item = self.media_item.service_load(service_item) # THEN: the processing should be ignored - self.assertEqual(item, None, 'The Service item is inactive so processing should be bypassed') + assert item is None, 'The Service item is inactive so processing should be bypassed' def test_service_load_basic_custom_false(self): """ @@ -95,8 +94,8 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.service_load(service_item) # THEN: the item should not be added to the database. - self.assertEqual(self.media_item.create_from_service_item.call_count, 0, - 'The item should not have been added to the database') + assert self.media_item.create_from_service_item.call_count == 0, \ + 'The item should not have been added to the database' def test_service_load_basic_custom_true(self): """ @@ -118,5 +117,5 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.service_load(service_item) # THEN: the item should not be added to the database. - self.assertEqual(self.media_item.create_from_service_item.call_count, 1, - 'The item should have been added to the database') + assert self.media_item.create_from_service_item.call_count == 1, \ + 'The item should have been added to the database' diff --git a/tests/functional/openlp_plugins/images/__init__.py b/tests/functional/openlp_plugins/images/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/functional/openlp_plugins/images/__init__.py +++ b/tests/functional/openlp_plugins/images/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_plugins/images/test_imagetab.py b/tests/functional/openlp_plugins/images/test_imagetab.py index 1000001c2..813be4e88 100644 --- a/tests/functional/openlp_plugins/images/test_imagetab.py +++ b/tests/functional/openlp_plugins/images/test_imagetab.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -30,7 +30,6 @@ from PyQt5 import QtWidgets from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings from openlp.plugins.images.lib import ImageTab - from tests.helpers.testmixin import TestMixin __default_settings__ = { @@ -74,8 +73,8 @@ class TestImageMediaItem(TestCase, TestMixin): # WHEN: the save is invoked self.form.save() # THEN: the post process should not be requested - self.assertEqual(0, self.form.settings_form.register_post_process.call_count, - 'Image Post processing should not have been requested') + assert 0 == self.form.settings_form.register_post_process.call_count, \ + 'Image Post processing should not have been requested' def test_save_tab_change(self): """ @@ -86,7 +85,7 @@ class TestImageMediaItem(TestCase, TestMixin): # WHEN: the save is invoked self.form.save() # THEN: the post process should be requested - self.assertEqual(1, self.form.settings_form.register_post_process.call_count, - 'Image Post processing should have been requested') + assert 1 == self.form.settings_form.register_post_process.call_count, \ + 'Image Post processing should have been requested' # THEN: The color should be set - self.assertEqual(self.form.background_color, '#999999', 'The updated color should have been saved') + assert self.form.background_color == '#999999', 'The updated color should have been saved' diff --git a/tests/functional/openlp_plugins/images/test_lib.py b/tests/functional/openlp_plugins/images/test_lib.py index 877ad722d..76eb20dab 100644 --- a/tests/functional/openlp_plugins/images/test_lib.py +++ b/tests/functional/openlp_plugins/images/test_lib.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,8 +27,8 @@ from unittest.mock import ANY, MagicMock, patch from PyQt5 import QtCore, QtWidgets -from openlp.core.common.registry import Registry from openlp.core.common.path import Path +from openlp.core.common.registry import Registry from openlp.plugins.images.lib.db import ImageFilenames, ImageGroups from openlp.plugins.images.lib.mediaitem import ImageMediaItem @@ -98,8 +98,8 @@ class TestImageMediaItem(TestCase): self.media_item.save_new_images_list(image_list) # THEN: The save_object() method should not have been called - self.assertEquals(self.media_item.manager.save_object.call_count, 0, - 'The save_object() method should not have been called') + assert self.media_item.manager.save_object.call_count == 0, \ + 'The save_object() method should not have been called' @patch('openlp.plugins.images.lib.mediaitem.ImageMediaItem.load_full_list') def test_save_new_images_list_single_image_with_reload(self, mocked_load_full_list): @@ -115,7 +115,7 @@ class TestImageMediaItem(TestCase): self.media_item.save_new_images_list(image_list, reload_list=True) # THEN: load_full_list() should have been called - self.assertEquals(mocked_load_full_list.call_count, 1, 'load_full_list() should have been called') + assert mocked_load_full_list.call_count == 1, 'load_full_list() should have been called' # CLEANUP: Remove added attribute from ImageFilenames delattr(ImageFilenames, 'file_path') @@ -133,7 +133,7 @@ class TestImageMediaItem(TestCase): self.media_item.save_new_images_list(image_list, reload_list=False) # THEN: load_full_list() should not have been called - self.assertEquals(mocked_load_full_list.call_count, 0, 'load_full_list() should not have been called') + assert mocked_load_full_list.call_count == 0, 'load_full_list() should not have been called' @patch('openlp.plugins.images.lib.mediaitem.ImageMediaItem.load_full_list') def test_save_new_images_list_multiple_images(self, mocked_load_full_list): @@ -148,8 +148,8 @@ class TestImageMediaItem(TestCase): self.media_item.save_new_images_list(image_list, reload_list=False) # THEN: load_full_list() should not have been called - self.assertEquals(self.media_item.manager.save_object.call_count, 3, - 'load_full_list() should have been called three times') + assert self.media_item.manager.save_object.call_count == 3, \ + 'load_full_list() should have been called three times' @patch('openlp.plugins.images.lib.mediaitem.ImageMediaItem.load_full_list') def test_save_new_images_list_other_objects_in_list(self, mocked_load_full_list): @@ -164,8 +164,7 @@ class TestImageMediaItem(TestCase): self.media_item.save_new_images_list(image_list, reload_list=False) # THEN: load_full_list() should not have been called - self.assertEquals(self.media_item.manager.save_object.call_count, 2, - 'load_full_list() should have been called only once') + assert self.media_item.manager.save_object.call_count == 2, 'load_full_list() should have been called only once' def test_on_reset_click(self): """ @@ -201,9 +200,9 @@ class TestImageMediaItem(TestCase): self.media_item.recursively_delete_group(test_group) # THEN: delete_file() should have been called 12 times and manager.delete_object() 7 times. - self.assertEquals(mocked_delete_file.call_count, 12, 'delete_file() should have been called 12 times') - self.assertEquals(self.media_item.manager.delete_object.call_count, 7, - 'manager.delete_object() should be called exactly 7 times') + assert mocked_delete_file.call_count == 12, 'delete_file() should have been called 12 times' + assert self.media_item.manager.delete_object.call_count == 7, \ + 'manager.delete_object() should be called exactly 7 times' # CLEANUP: Remove added attribute from Image Filenames and ImageGroups delattr(ImageFilenames, 'group_id') @@ -258,7 +257,7 @@ class TestImageMediaItem(TestCase): self.media_item.on_delete_click() # THEN: delete_file should have been called twice - self.assertEquals(mocked_delete_file.call_count, 2, 'delete_file() should have been called twice') + assert mocked_delete_file.call_count == 2, 'delete_file() should have been called twice' def test_create_item_from_id(self): """ @@ -276,9 +275,9 @@ class TestImageMediaItem(TestCase): item = self.media_item.create_item_from_id('1') # THEN: A QTreeWidgetItem should be created with the above model object as it's data - self.assertIsInstance(item, QtWidgets.QTreeWidgetItem) - self.assertEqual('test_file_1.jpg', item.text(0)) + assert isinstance(item, QtWidgets.QTreeWidgetItem) + assert 'test_file_1.jpg' == item.text(0) item_data = item.data(0, QtCore.Qt.UserRole) - self.assertIsInstance(item_data, ImageFilenames) - self.assertEqual(1, item_data.id) - self.assertEqual(Path('/', 'tmp', 'test_file_1.jpg'), item_data.file_path) + assert isinstance(item_data, ImageFilenames) + assert 1 == item_data.id + assert Path('/', 'tmp', 'test_file_1.jpg') == item_data.file_path diff --git a/tests/functional/openlp_plugins/images/test_upgrade.py b/tests/functional/openlp_plugins/images/test_upgrade.py index 471c33609..20c090a2b 100644 --- a/tests/functional/openlp_plugins/images/test_upgrade.py +++ b/tests/functional/openlp_plugins/images/test_upgrade.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -34,7 +34,6 @@ from openlp.core.common.settings import Settings from openlp.core.lib.db import Manager from openlp.plugins.images.lib import upgrade from openlp.plugins.images.lib.db import ImageFilenames, init_schema - from tests.helpers.testmixin import TestMixin from tests.utils.constants import TEST_RESOURCES_PATH @@ -80,6 +79,6 @@ class TestImageDBUpgrade(TestCase, TestMixin): 2: Path('/', 'test', 'dir', 'image2.jpg'), 3: Path('/', 'test', 'dir', 'subdir', 'image3.jpg')} - self.assertEqual(len(upgraded_results), 3) + assert len(upgraded_results) == 3 for result in upgraded_results: - self.assertEqual(expected_result_data[result.id], result.file_path) + assert expected_result_data[result.id] == result.file_path diff --git a/tests/functional/openlp_plugins/media/test_mediaitem.py b/tests/functional/openlp_plugins/media/test_mediaitem.py index 4f753c237..8e1035161 100644 --- a/tests/functional/openlp_plugins/media/test_mediaitem.py +++ b/tests/functional/openlp_plugins/media/test_mediaitem.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,10 +27,9 @@ from unittest.mock import MagicMock, patch from PyQt5 import QtCore -from openlp.core.common.settings import Settings from openlp.core.common.path import Path +from openlp.core.common.settings import Settings from openlp.plugins.media.lib.mediaitem import MediaMediaItem - from tests.helpers.testmixin import TestMixin __default_settings__ = { @@ -71,7 +70,7 @@ class MediaItemTest(TestCase, TestMixin): # WHEN: Retrieving the test file result = self.media_item.search('test.mp4', False) # THEN: a file should be found - self.assertEqual(result, [['test.mp4', 'test.mp4']], 'The result file contain the file name') + assert result == [['test.mp4', 'test.mp4']], 'The result file contain the file name' def test_search_not_found(self): """ @@ -82,4 +81,4 @@ class MediaItemTest(TestCase, TestMixin): # WHEN: Retrieving the test file result = self.media_item.search('test.mpx', False) # THEN: a file should be found - self.assertEqual(result, [], 'The result file should be empty') + assert result == [], 'The result file should be empty' diff --git a/tests/functional/openlp_plugins/media/test_mediaplugin.py b/tests/functional/openlp_plugins/media/test_mediaplugin.py index 3ab5b3034..4af0a9603 100644 --- a/tests/functional/openlp_plugins/media/test_mediaplugin.py +++ b/tests/functional/openlp_plugins/media/test_mediaplugin.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,7 +27,6 @@ from unittest.mock import patch from openlp.core.common.registry import Registry from openlp.plugins.media.mediaplugin import MediaPlugin, process_check_binary - from tests.helpers.testmixin import TestMixin @@ -56,9 +55,9 @@ class MediaPluginTest(TestCase, TestMixin): # GIVEN: The MediaPlugin # WHEN: Retrieving the about text # THEN: about() should return a string object - self.assertIsInstance(MediaPlugin.about(), str) + assert isinstance(MediaPlugin.about(), str) # THEN: about() should return a non-empty string - self.assertNotEquals(len(MediaPlugin.about()), 0) + assert len(MediaPlugin.about()) is not 0 @patch('openlp.plugins.media.mediaplugin.check_binary_exists') def test_process_check_binary_pass(self, mocked_checked_binary_exists): @@ -71,7 +70,7 @@ class MediaPluginTest(TestCase, TestMixin): result = process_check_binary('MediaInfo') # THEN: The the result should be True - self.assertTrue(result, 'Mediainfo should have been found') + assert result is True, 'Mediainfo should have been found' @patch('openlp.plugins.media.mediaplugin.check_binary_exists') def test_process_check_binary_fail(self, mocked_checked_binary_exists): @@ -84,4 +83,4 @@ class MediaPluginTest(TestCase, TestMixin): result = process_check_binary("MediaInfo1") # THEN: The the result should be True - self.assertFalse(result, "Mediainfo should not have been found") + assert result is False, "Mediainfo should not have been found" diff --git a/tests/functional/openlp_plugins/presentations/__init__.py b/tests/functional/openlp_plugins/presentations/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/functional/openlp_plugins/presentations/__init__.py +++ b/tests/functional/openlp_plugins/presentations/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_plugins/presentations/test_impresscontroller.py b/tests/functional/openlp_plugins/presentations/test_impresscontroller.py index 9e15a0c79..d3a911cec 100644 --- a/tests/functional/openlp_plugins/presentations/test_impresscontroller.py +++ b/tests/functional/openlp_plugins/presentations/test_impresscontroller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,17 +22,17 @@ """ Functional tests to test the Impress class and related methods. """ -from unittest import TestCase -from unittest.mock import MagicMock, patch import shutil from tempfile import mkdtemp +from unittest import TestCase +from unittest.mock import MagicMock, patch -from openlp.core.common.settings import Settings from openlp.core.common.path import Path +from openlp.core.common.settings import Settings from openlp.plugins.presentations.lib.impresscontroller import ImpressController, ImpressDocument, TextType from openlp.plugins.presentations.presentationplugin import __default_settings__ -from tests.utils.constants import TEST_RESOURCES_PATH +from tests.utils.constants import RESOURCE_PATH from tests.helpers.testmixin import TestMixin @@ -69,8 +69,7 @@ class TestImpressController(TestCase, TestMixin): controller = ImpressController(plugin=self.mock_plugin) # THEN: The name of the presentation controller should be correct - self.assertEqual('Impress', controller.name, - 'The name of the presentation controller should be correct') + assert 'Impress' == controller.name, 'The name of the presentation controller should be correct' @patch('openlp.plugins.presentations.lib.impresscontroller.log') def test_check_available(self, mocked_log): @@ -135,7 +134,7 @@ class TestImpressDocument(TestCase): mocked_plugin = MagicMock() mocked_plugin.settings_section = 'presentations' Settings().extend_default_settings(__default_settings__) - self.file_name = Path(TEST_RESOURCES_PATH, 'presentations', 'test.pptx') + self.file_name = RESOURCE_PATH / 'presentations' / 'test.pptx' self.ppc = ImpressController(mocked_plugin) self.doc = ImpressDocument(self.ppc, self.file_name) @@ -179,22 +178,21 @@ class TestImpressDocument(TestCase): result = self.doc._ImpressDocument__get_text_from_page(0, TextType.Notes) # THEN: the result should be an empty string - self.assertEqual(result, '', 'Result should be an empty string') + assert result == '', 'Result should be an empty string' # WHEN: regardless of the type of text, index 0x00 is out of bounds result = self.doc._ImpressDocument__get_text_from_page(0, TextType.Title) # THEN: result should be an empty string - self.assertEqual(result, '', 'Result should be an empty string') + assert result == '', 'Result should be an empty string' # WHEN: when called with 2, it should also be out of bounds result = self.doc._ImpressDocument__get_text_from_page(2, TextType.SlideText) # THEN: result should be an empty string ... and, getByIndex should # have never been called - self.assertEqual(result, '', 'Result should be an empty string') - self.assertEqual(self.doc.document.getDrawPages().getByIndex.call_count, 0, - 'There should be no call to getByIndex') + assert result == '', 'Result should be an empty string' + assert self.doc.document.getDrawPages().getByIndex.call_count == 0, 'There should be no call to getByIndex' def test_get_text_from_page_wrong_type(self): """ @@ -208,9 +206,8 @@ class TestImpressDocument(TestCase): result = self.doc._ImpressDocument__get_text_from_page(1, 3) # THEN: result should be an empty string - self.assertEqual(result, '', 'Result should be and empty string') - self.assertEqual(self.doc.document.getDrawPages().getByIndex.call_count, 0, - 'There should be no call to getByIndex') + assert result == '', 'Result should be and empty string' + assert self.doc.document.getDrawPages().getByIndex.call_count == 0, 'There should be no call to getByIndex' def test_get_text_from_page_valid_params(self): """ @@ -224,19 +221,19 @@ class TestImpressDocument(TestCase): result = self.doc._ImpressDocument__get_text_from_page(1, TextType.Notes) # THEN: result should be 'Note\nNote\n' - self.assertEqual(result, 'Note\nNote\n', 'Result should be \'Note\\n\' times the count of notes in the page') + assert result == 'Note\nNote\n', 'Result should be \'Note\\n\' times the count of notes in the page' # WHEN: get the Title result = self.doc._ImpressDocument__get_text_from_page(1, TextType.Title) # THEN: result should be 'Title\n' - self.assertEqual(result, 'Title\n', 'Result should be exactly \'Title\\n\'') + assert result == 'Title\n', 'Result should be exactly \'Title\\n\'' # WHEN: get all text result = self.doc._ImpressDocument__get_text_from_page(1, TextType.SlideText) # THEN: result should be 'Title\nString\nString\n' - self.assertEqual(result, 'Title\nString\nString\n', 'Result should be exactly \'Title\\nString\\nString\\n\'') + assert result == 'Title\nString\nString\n', 'Result should be exactly \'Title\\nString\\nString\\n\'' def _mock_a_LibreOffice_document(self, page_count, note_count, text_count): """ diff --git a/tests/functional/openlp_plugins/presentations/test_mediaitem.py b/tests/functional/openlp_plugins/presentations/test_mediaitem.py index fd28b9b03..f8375be2c 100644 --- a/tests/functional/openlp_plugins/presentations/test_mediaitem.py +++ b/tests/functional/openlp_plugins/presentations/test_mediaitem.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,10 +25,9 @@ This module contains tests for the lib submodule of the Presentations plugin. from unittest import TestCase from unittest.mock import patch, MagicMock, call -from openlp.core.common.registry import Registry from openlp.core.common.path import Path +from openlp.core.common.registry import Registry from openlp.plugins.presentations.lib.mediaitem import PresentationMediaItem - from tests.helpers.testmixin import TestMixin @@ -81,11 +80,11 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.build_file_mask_string() # THEN: The file mask should be generated correctly - self.assertIn('*.odp', self.media_item.on_new_file_masks, 'The file mask should contain the odp extension') - self.assertIn('*.ppt', self.media_item.on_new_file_masks, 'The file mask should contain the ppt extension') - self.assertIn('*.pdf', self.media_item.on_new_file_masks, 'The file mask should contain the pdf extension') - self.assertIn('*.xps', self.media_item.on_new_file_masks, 'The file mask should contain the xps extension') - self.assertIn('*.oxps', self.media_item.on_new_file_masks, 'The file mask should contain the oxps extension') + assert '*.odp' in self.media_item.on_new_file_masks, 'The file mask should contain the odp extension' + assert '*.ppt' in self.media_item.on_new_file_masks, 'The file mask should contain the ppt extension' + assert '*.pdf' in self.media_item.on_new_file_masks, 'The file mask should contain the pdf extension' + assert '*.xps' in self.media_item.on_new_file_masks, 'The file mask should contain the xps extension' + assert '*.oxps' in self.media_item.on_new_file_masks, 'The file mask should contain the oxps extension' def test_clean_up_thumbnails(self): """ diff --git a/tests/functional/openlp_plugins/presentations/test_messagelistener.py b/tests/functional/openlp_plugins/presentations/test_messagelistener.py index e38eeaf90..051f1e1a4 100644 --- a/tests/functional/openlp_plugins/presentations/test_messagelistener.py +++ b/tests/functional/openlp_plugins/presentations/test_messagelistener.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -28,7 +28,6 @@ from unittest.mock import patch, MagicMock from openlp.core.common.registry import Registry from openlp.plugins.presentations.lib.mediaitem import MessageListener, PresentationMediaItem from openlp.plugins.presentations.lib.messagelistener import Controller - from tests.helpers.testmixin import TestMixin @@ -73,7 +72,7 @@ class TestMessageListener(TestCase, TestMixin): ml.startup([mock_item, False, False, False]) # THEN: The controllers will be setup. - self.assertTrue(len(controllers), 'We have loaded a controller') + assert len(controllers) > 0, 'We have loaded a controller' @patch('openlp.plugins.presentations.lib.mediaitem.MessageListener._setup') def test_start_presentation_with_no_player(self, media_mock): @@ -105,7 +104,7 @@ class TestMessageListener(TestCase, TestMixin): ml.startup([mock_item, False, False, False]) # THEN: The controllers will be setup. - self.assertTrue(len(controllers), 'We have loaded a controller') + assert len(controllers) > 0, 'We have loaded a controller' @patch('openlp.plugins.presentations.lib.mediaitem.MessageListener._setup') def test_start_pdf_presentation(self, media_mock): @@ -125,7 +124,7 @@ class TestMessageListener(TestCase, TestMixin): ml.startup([mock_item, False, False, False]) # THEN: The handler should be set to None - self.assertIsNone(ml.handler, 'The handler should be None') + assert ml.handler is None, 'The handler should be None' class TestController(TestCase, TestMixin): @@ -148,4 +147,4 @@ class TestController(TestCase, TestMixin): controller.add_handler(mocked_doc_controller, MagicMock(), True, 0) # THEN: slidenumber should be 0 - self.assertEqual(controller.doc.slidenumber, 0, 'doc.slidenumber should be 0') + assert controller.doc.slidenumber == 0, 'doc.slidenumber should be 0' diff --git a/tests/functional/openlp_plugins/presentations/test_pdfcontroller.py b/tests/functional/openlp_plugins/presentations/test_pdfcontroller.py index 9bd492983..80f84f9fa 100644 --- a/tests/functional/openlp_plugins/presentations/test_pdfcontroller.py +++ b/tests/functional/openlp_plugins/presentations/test_pdfcontroller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,19 +23,18 @@ This module contains tests for the PdfController """ import os -import shutil from tempfile import mkdtemp from unittest import TestCase, SkipTest from unittest.mock import MagicMock, patch from PyQt5 import QtCore, QtGui -from openlp.plugins.presentations.lib.pdfcontroller import PdfController, PdfDocument -from openlp.core.common.settings import Settings from openlp.core.common.path import Path +from openlp.core.common.settings import Settings from openlp.core.display.screens import ScreenList +from openlp.plugins.presentations.lib.pdfcontroller import PdfController, PdfDocument -from tests.utils.constants import TEST_RESOURCES_PATH +from tests.utils.constants import RESOURCE_PATH from tests.helpers.testmixin import TestMixin __default_settings__ = { @@ -92,14 +91,14 @@ class TestPdfController(TestCase, TestMixin): controller = PdfController(plugin=self.mock_plugin) # THEN: The name of the presentation controller should be correct - self.assertEqual('Pdf', controller.name, 'The name of the presentation controller should be correct') + assert 'Pdf' == controller.name, 'The name of the presentation controller should be correct' def test_load_pdf(self): """ Test loading of a Pdf using the PdfController """ # GIVEN: A Pdf-file - test_file = Path(TEST_RESOURCES_PATH, 'presentations', 'pdf_test1.pdf') + test_file_path = RESOURCE_PATH / 'presentations' / 'pdf_test1.pdf' # WHEN: The Pdf is loaded controller = PdfController(plugin=self.mock_plugin) @@ -107,19 +106,19 @@ class TestPdfController(TestCase, TestMixin): raise SkipTest('Could not detect mudraw or ghostscript, so skipping PDF test') controller.temp_folder = self.temp_folder_path controller.thumbnail_folder = self.thumbnail_folder_path - document = PdfDocument(controller, test_file) + document = PdfDocument(controller, test_file_path) loaded = document.load_presentation() # THEN: The load should succeed and we should be able to get a pagecount - self.assertTrue(loaded, 'The loading of the PDF should succeed.') - self.assertEqual(3, document.get_slide_count(), 'The pagecount of the PDF should be 3.') + assert loaded is True, 'The loading of the PDF should succeed.' + assert 3 == document.get_slide_count(), 'The pagecount of the PDF should be 3.' def test_load_pdf_pictures(self): """ Test loading of a Pdf and check size of generate pictures """ # GIVEN: A Pdf-file - test_file = Path(TEST_RESOURCES_PATH, 'presentations', 'pdf_test1.pdf') + test_file_path = RESOURCE_PATH / 'presentations' / 'pdf_test1.pdf' # WHEN: The Pdf is loaded controller = PdfController(plugin=self.mock_plugin) @@ -127,19 +126,19 @@ class TestPdfController(TestCase, TestMixin): raise SkipTest('Could not detect mudraw or ghostscript, so skipping PDF test') controller.temp_folder = self.temp_folder_path controller.thumbnail_folder = self.thumbnail_folder_path - document = PdfDocument(controller, test_file) + document = PdfDocument(controller, test_file_path) loaded = document.load_presentation() # THEN: The load should succeed and pictures should be created and have been scales to fit the screen - self.assertTrue(loaded, 'The loading of the PDF should succeed.') + assert loaded is True, 'The loading of the PDF should succeed.' image = QtGui.QImage(os.path.join(str(self.temp_folder_path), 'pdf_test1.pdf', 'mainslide001.png')) # Based on the converter used the resolution will differ a bit if controller.gsbin: - self.assertEqual(760, image.height(), 'The height should be 760') - self.assertEqual(537, image.width(), 'The width should be 537') + assert 760 == image.height(), 'The height should be 760' + assert 537 == image.width(), 'The width should be 537' else: - self.assertEqual(768, image.height(), 'The height should be 768') - self.assertEqual(543, image.width(), 'The width should be 543') + assert 768 == image.height(), 'The height should be 768' + assert 543 == image.width(), 'The width should be 543' @patch('openlp.plugins.presentations.lib.pdfcontroller.check_binary_exists') def test_process_check_binary_mudraw(self, mocked_check_binary_exists): @@ -157,7 +156,7 @@ class TestPdfController(TestCase, TestMixin): ret = PdfController.process_check_binary('test') # THEN: mudraw should be detected - self.assertEqual('mudraw', ret, 'mudraw should have been detected') + assert 'mudraw' == ret, 'mudraw should have been detected' @patch('openlp.plugins.presentations.lib.pdfcontroller.check_binary_exists') def test_process_check_binary_new_motool(self, mocked_check_binary_exists): @@ -177,7 +176,7 @@ class TestPdfController(TestCase, TestMixin): ret = PdfController.process_check_binary('test') # THEN: mutool should be detected - self.assertEqual('mutool', ret, 'mutool should have been detected') + assert 'mutool' == ret, 'mutool should have been detected' @patch('openlp.plugins.presentations.lib.pdfcontroller.check_binary_exists') def test_process_check_binary_old_motool(self, mocked_check_binary_exists): @@ -194,7 +193,7 @@ class TestPdfController(TestCase, TestMixin): ret = PdfController.process_check_binary('test') # THEN: mutool should be detected - self.assertIsNone(ret, 'old mutool should not be accepted!') + assert ret is None, 'old mutool should not be accepted!' @patch('openlp.plugins.presentations.lib.pdfcontroller.check_binary_exists') def test_process_check_binary_gs(self, mocked_check_binary_exists): @@ -210,4 +209,4 @@ class TestPdfController(TestCase, TestMixin): ret = PdfController.process_check_binary('test') # THEN: mutool should be detected - self.assertEqual('gs', ret, 'mutool should have been detected') + assert 'gs' == ret, 'mutool should have been detected' diff --git a/tests/functional/openlp_plugins/presentations/test_powerpointcontroller.py b/tests/functional/openlp_plugins/presentations/test_powerpointcontroller.py index 5bab87b6a..3ebe0ede8 100644 --- a/tests/functional/openlp_plugins/presentations/test_powerpointcontroller.py +++ b/tests/functional/openlp_plugins/presentations/test_powerpointcontroller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -24,15 +24,14 @@ Functional tests to test the PowerPointController class and related methods. """ import os import shutil +from tempfile import mkdtemp from unittest import TestCase from unittest.mock import patch, MagicMock -from tempfile import mkdtemp from openlp.core.common import is_win from openlp.core.common.settings import Settings from openlp.plugins.presentations.lib.powerpointcontroller import PowerpointController, PowerpointDocument, \ _get_text_from_shapes - from tests.helpers.testmixin import TestMixin from tests.utils.constants import TEST_RESOURCES_PATH @@ -77,8 +76,7 @@ class TestPowerpointController(TestCase, TestMixin): controller = PowerpointController(plugin=self.mock_plugin) # THEN: The name of the presentation controller should be correct - self.assertEqual('Powerpoint', controller.name, - 'The name of the presentation controller should be correct') + assert 'Powerpoint' == controller.name, 'The name of the presentation controller should be correct' class TestPowerpointDocument(TestCase, TestMixin): @@ -157,7 +155,7 @@ class TestPowerpointDocument(TestCase, TestMixin): result = doc.is_loaded() # THEN: result should be true - self.assertEqual(result, True, 'The result should be True') + assert result is True, 'The result should be True' else: self.skipTest('Powerpoint not available, skipping test.') @@ -217,7 +215,7 @@ class TestPowerpointDocument(TestCase, TestMixin): result = _get_text_from_shapes(shapes) # THEN: it should return the text - self.assertEqual(result, 'slideText\nslideText\n', 'result should match \'slideText\nslideText\n\'') + assert result == 'slideText\nslideText\n', 'result should match \'slideText\nslideText\n\'' def test_get_text_from_shapes_with_no_shapes(self): """ @@ -230,7 +228,7 @@ class TestPowerpointDocument(TestCase, TestMixin): result = _get_text_from_shapes(shapes) # THEN: it should not fail but return empty string - self.assertEqual(result, '', 'result should be empty') + assert result == '', 'result should be empty' def test_goto_slide(self): """ @@ -250,7 +248,7 @@ class TestPowerpointDocument(TestCase, TestMixin): doc.goto_slide(1) # THEN: next_step() should be call to try to advance to the next effect. - self.assertTrue(doc.next_step.called, 'next_step() should have been called!') + assert doc.next_step.called is True, 'next_step() should have been called!' def test_blank_screen(self): """ @@ -268,9 +266,9 @@ class TestPowerpointDocument(TestCase, TestMixin): doc.blank_screen() # THEN: The view state, doc.blank_slide and doc.blank_click should have new values - self.assertEquals(doc.presentation.SlideShowWindow.View.State, 3, 'The View State should be 3') - self.assertEquals(doc.blank_slide, 2, 'doc.blank_slide should be 2 because of the PowerPoint version') - self.assertEquals(doc.blank_click, 3, 'doc.blank_click should be 3 because of the PowerPoint version') + assert doc.presentation.SlideShowWindow.View.State == 3, 'The View State should be 3' + assert doc.blank_slide == 2, 'doc.blank_slide should be 2 because of the PowerPoint version' + assert doc.blank_click == 3, 'doc.blank_click should be 3 because of the PowerPoint version' def test_unblank_screen(self): """ @@ -295,10 +293,10 @@ class TestPowerpointDocument(TestCase, TestMixin): doc.unblank_screen() # THEN: The view state have new value, and several function should have been called - self.assertEquals(doc.presentation.SlideShowWindow.View.State, 1, 'The View State should be 1') - self.assertEquals(doc.presentation.SlideShowWindow.Activate.called, True, - 'SlideShowWindow.Activate should have been called') - self.assertEquals(doc.presentation.SlideShowWindow.View.GotoSlide.called, True, - 'View.GotoSlide should have been called because of the PowerPoint version') - self.assertEquals(doc.presentation.SlideShowWindow.View.GotoClick.called, True, - 'View.GotoClick should have been called because of the PowerPoint version') + assert doc.presentation.SlideShowWindow.View.State == 1, 'The View State should be 1' + assert doc.presentation.SlideShowWindow.Activate.called is True, \ + 'SlideShowWindow.Activate should have been called' + assert doc.presentation.SlideShowWindow.View.GotoSlide.called is True, \ + 'View.GotoSlide should have been called because of the PowerPoint version' + assert doc.presentation.SlideShowWindow.View.GotoClick.called is True, \ + 'View.GotoClick should have been called because of the PowerPoint version' diff --git a/tests/functional/openlp_plugins/presentations/test_pptviewcontroller.py b/tests/functional/openlp_plugins/presentations/test_pptviewcontroller.py index 1245be274..5e6a7abdd 100644 --- a/tests/functional/openlp_plugins/presentations/test_pptviewcontroller.py +++ b/tests/functional/openlp_plugins/presentations/test_pptviewcontroller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,12 +27,11 @@ from tempfile import mkdtemp from unittest import TestCase, skipIf from unittest.mock import MagicMock, patch -from openlp.plugins.presentations.lib.pptviewcontroller import PptviewDocument, PptviewController from openlp.core.common import is_win from openlp.core.common.path import Path - +from openlp.plugins.presentations.lib.pptviewcontroller import PptviewDocument, PptviewController from tests.helpers.testmixin import TestMixin -from tests.utils.constants import TEST_RESOURCES_PATH +from tests.utils.constants import RESOURCE_PATH class TestPptviewController(TestCase, TestMixin): @@ -67,8 +66,7 @@ class TestPptviewController(TestCase, TestMixin): controller = PptviewController(plugin=self.mock_plugin) # THEN: The name of the presentation controller should be correct - self.assertEqual('Powerpoint Viewer', controller.name, - 'The name of the presentation controller should be correct') + assert 'Powerpoint Viewer' == controller.name, 'The name of the presentation controller should be correct' def test_check_available(self): """ @@ -86,9 +84,9 @@ class TestPptviewController(TestCase, TestMixin): # THEN: On windows it should return True, on other platforms False if is_win(): - self.assertTrue(available, 'check_available should return True on windows.') + assert available is True, 'check_available should return True on windows.' else: - self.assertFalse(available, 'check_available should return False when not on windows.') + assert available is False, 'check_available should return False when not on windows.' class TestPptviewDocument(TestCase): @@ -165,7 +163,7 @@ class TestPptviewDocument(TestCase): result = instance.load_presentation() # THEN: The temp folder should be created and PptviewDocument.load_presentation should return False - self.assertFalse(result) + assert result is False def test_create_titles_and_notes(self): """ @@ -173,7 +171,7 @@ class TestPptviewDocument(TestCase): """ # GIVEN: mocked PresentationController.save_titles_and_notes and a pptx file doc = PptviewDocument(self.mock_controller, self.mock_presentation) - doc.file_path = Path(TEST_RESOURCES_PATH, 'presentations', 'test.pptx') + doc.file_path = RESOURCE_PATH / 'presentations' / 'test.pptx' doc.save_titles_and_notes = MagicMock() # WHEN reading the titles and notes @@ -205,7 +203,7 @@ class TestPptviewDocument(TestCase): # THEN: File existens should have been checked, and not have been opened. doc.save_titles_and_notes.assert_called_once_with(None, None) mocked_path_exists.assert_called_with() - self.assertEqual(mocked_open.call_count, 0, 'There should be no calls to open a file.') + assert mocked_open.call_count == 0, 'There should be no calls to open a file.' def test_create_titles_and_notes_invalid_file(self): """ @@ -217,7 +215,7 @@ class TestPptviewDocument(TestCase): mocked_is_zf.return_value = False mocked_open.filesize = 10 doc = PptviewDocument(self.mock_controller, self.mock_presentation) - doc.file_path = Path(TEST_RESOURCES_PATH, 'presentations', 'test.ppt') + doc.file_path = RESOURCE_PATH / 'presentations' / 'test.ppt' doc.save_titles_and_notes = MagicMock() # WHEN: reading the titles and notes @@ -225,4 +223,4 @@ class TestPptviewDocument(TestCase): # THEN: doc.save_titles_and_notes.assert_called_once_with(None, None) - self.assertEqual(mocked_is_zf.call_count, 1, 'is_zipfile should have been called once') + assert mocked_is_zf.call_count == 1, 'is_zipfile should have been called once' diff --git a/tests/functional/openlp_plugins/presentations/test_presentationcontroller.py b/tests/functional/openlp_plugins/presentations/test_presentationcontroller.py index a921ef81e..4383122e8 100644 --- a/tests/functional/openlp_plugins/presentations/test_presentationcontroller.py +++ b/tests/functional/openlp_plugins/presentations/test_presentationcontroller.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -58,8 +58,8 @@ class TestPresentationController(TestCase): # WHEN: The PresentationController is created # THEN: The name of the presentation controller should be correct - self.assertEqual('PresentationController', self.presentation.name, - 'The name of the presentation controller should be correct') + assert 'PresentationController' == self.presentation.name, \ + 'The name of the presentation controller should be correct' def test_save_titles_and_notes(self): """ @@ -76,7 +76,7 @@ class TestPresentationController(TestCase): self.document.save_titles_and_notes(titles, notes) # THEN: the last call to open should have been for slideNotes2.txt - self.assertEqual(mocked_write_text.call_count, 3, 'There should be exactly three files written') + assert mocked_write_text.call_count == 3, 'There should be exactly three files written' mocked_write_text.assert_has_calls([call('uno\ndos'), call('one'), call('two')]) def test_save_titles_and_notes_with_None(self): @@ -93,7 +93,7 @@ class TestPresentationController(TestCase): self.document.save_titles_and_notes(titles, notes) # THEN: No file should have been created - self.assertEqual(mocked_open.call_count, 0, 'No file should be created') + assert mocked_open.call_count == 0, 'No file should be created' def test_get_titles_and_notes(self): """ @@ -112,11 +112,11 @@ class TestPresentationController(TestCase): result_titles, result_notes = self.document.get_titles_and_notes() # THEN: it should return two items for the titles and two empty strings for the notes - self.assertIs(type(result_titles), list, 'result_titles should be of type list') - self.assertEqual(len(result_titles), 2, 'There should be two items in the titles') - self.assertIs(type(result_notes), list, 'result_notes should be of type list') - self.assertEqual(len(result_notes), 2, 'There should be two items in the notes') - self.assertEqual(mocked_read_text.call_count, 3, 'Three files should be read') + assert type(result_titles) is list, 'result_titles should be of type list' + assert len(result_titles) == 2, 'There should be two items in the titles' + assert type(result_notes) is list, 'result_notes should be of type list' + assert len(result_notes) == 2, 'There should be two items in the notes' + assert mocked_read_text.call_count == 3, 'Three files should be read' def test_get_titles_and_notes_with_file_not_found(self): """ @@ -132,10 +132,10 @@ class TestPresentationController(TestCase): result_titles, result_notes = self.document.get_titles_and_notes() # THEN: it should return two empty lists - self.assertIsInstance(result_titles, list, 'result_titles should be of type list') - self.assertEqual(len(result_titles), 0, 'there be no titles') - self.assertIsInstance(result_notes, list, 'result_notes should be a list') - self.assertEqual(len(result_notes), 0, 'but the list should be empty') + assert isinstance(result_titles, list), 'result_titles should be of type list' + assert len(result_titles) == 0, 'there be no titles' + assert isinstance(result_notes, list), 'result_notes should be a list' + assert len(result_notes) == 0, 'but the list should be empty' def test_get_titles_and_notes_with_file_error(self): """ @@ -151,7 +151,7 @@ class TestPresentationController(TestCase): result_titles, result_notes = self.document.get_titles_and_notes() # THEN: it should return two empty lists - self.assertIs(type(result_titles), list, 'result_titles should be a list') + assert type(result_titles) is list, 'result_titles should be a list' class TestPresentationDocument(TestCase): @@ -226,4 +226,4 @@ class TestPresentationDocument(TestCase): result = instance.load_presentation() # THEN: load_presentation should return false - self.assertFalse(result, "PresentationDocument.load_presentation should return false.") + assert result is False, "PresentationDocument.load_presentation should return false." diff --git a/tests/functional/openlp_plugins/songs/__init__.py b/tests/functional/openlp_plugins/songs/__init__.py index 8e4693e5e..f66326757 100644 --- a/tests/functional/openlp_plugins/songs/__init__.py +++ b/tests/functional/openlp_plugins/songs/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_plugins/songs/test_chordproimport.py b/tests/functional/openlp_plugins/songs/test_chordproimport.py index 51ab19f25..d2b8ee1dc 100644 --- a/tests/functional/openlp_plugins/songs/test_chordproimport.py +++ b/tests/functional/openlp_plugins/songs/test_chordproimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,15 +22,12 @@ """ This module contains tests for the OpenSong song importer. """ -import os - -from openlp.core.common.path import Path - -from tests.helpers.songfileimport import SongImportTestHelper from unittest.mock import patch, MagicMock -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'chordprosongs')) +from tests.helpers.songfileimport import SongImportTestHelper +from tests.utils.constants import RESOURCE_PATH + +TEST_PATH = RESOURCE_PATH / 'songs' / 'chordpro' class TestChordProFileImport(SongImportTestHelper): @@ -50,5 +47,5 @@ class TestChordProFileImport(SongImportTestHelper): mocked_returned_settings.value.side_effect = lambda value: True if value == 'songs/enable chords' else False mocked_settings.return_value = mocked_returned_settings # Do the test import - self.file_import([Path(TEST_PATH, 'swing-low.chordpro')], - self.load_external_result_data(os.path.join(TEST_PATH, 'swing-low.json'))) + self.file_import([TEST_PATH / 'swing-low.chordpro'], + self.load_external_result_data(TEST_PATH / 'swing-low.json')) diff --git a/tests/functional/openlp_plugins/songs/test_db.py b/tests/functional/openlp_plugins/songs/test_db.py index 797359139..1078bfca4 100644 --- a/tests/functional/openlp_plugins/songs/test_db.py +++ b/tests/functional/openlp_plugins/songs/test_db.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -24,12 +24,12 @@ This module contains tests for the db submodule of the Songs plugin. """ import os import shutil -from unittest import TestCase from tempfile import mkdtemp +from unittest import TestCase -from openlp.plugins.songs.lib.db import Song, Author, AuthorType, Book -from openlp.plugins.songs.lib import upgrade from openlp.core.lib.db import upgrade_db +from openlp.plugins.songs.lib import upgrade +from openlp.plugins.songs.lib.db import Song, Author, AuthorType, Book from tests.utils.constants import TEST_RESOURCES_PATH @@ -66,10 +66,10 @@ class TestDB(TestCase): song.add_author(author) # THEN: The author should have been added with author_type=None - self.assertEqual(1, len(song.authors_songs)) - self.assertEqual("Max", song.authors_songs[0].author.first_name) - self.assertEqual("Mustermann", song.authors_songs[0].author.last_name) - self.assertIsNone(song.authors_songs[0].author_type) + assert 1 == len(song.authors_songs) + assert "Max" == song.authors_songs[0].author.first_name + assert "Mustermann" == song.authors_songs[0].author.last_name + assert song.authors_songs[0].author_type is None def test_add_author_with_type(self): """ @@ -86,10 +86,10 @@ class TestDB(TestCase): song.add_author(author, AuthorType.Words) # THEN: The author should have been added with author_type=None - self.assertEqual(1, len(song.authors_songs)) - self.assertEqual("Max", song.authors_songs[0].author.first_name) - self.assertEqual("Mustermann", song.authors_songs[0].author.last_name) - self.assertEqual(AuthorType.Words, song.authors_songs[0].author_type) + assert 1 == len(song.authors_songs) + assert "Max" == song.authors_songs[0].author.first_name + assert "Mustermann" == song.authors_songs[0].author.last_name + assert AuthorType.Words == song.authors_songs[0].author_type def test_remove_author(self): """ @@ -105,7 +105,7 @@ class TestDB(TestCase): song.remove_author(author) # THEN: It should have been removed - self.assertEqual(0, len(song.authors_songs)) + assert 0 == len(song.authors_songs) def test_remove_author_with_type(self): """ @@ -122,8 +122,8 @@ class TestDB(TestCase): song.remove_author(author, AuthorType.Translation) # THEN: It should have been removed and the other author should still be there - self.assertEqual(1, len(song.authors_songs)) - self.assertEqual(None, song.authors_songs[0].author_type) + assert 1 == len(song.authors_songs) + assert song.authors_songs[0].author_type is None def test_get_author_type_from_translated_text(self): """ @@ -136,7 +136,7 @@ class TestDB(TestCase): author_type = AuthorType.from_translated_text(author_type_name) # THEN: The type should be correct - self.assertEqual(author_type, AuthorType.Words) + assert author_type == AuthorType.Words def test_author_get_display_name(self): """ @@ -150,7 +150,7 @@ class TestDB(TestCase): display_name = author.get_display_name() # THEN: It should return only the name - self.assertEqual("John Doe", display_name) + assert "John Doe" == display_name def test_author_get_display_name_with_type_words(self): """ @@ -164,7 +164,7 @@ class TestDB(TestCase): display_name = author.get_display_name(AuthorType.Words) # THEN: It should return the name with the type in brackets - self.assertEqual("John Doe (Words)", display_name) + assert "John Doe (Words)" == display_name def test_author_get_display_name_with_type_translation(self): """ @@ -178,7 +178,7 @@ class TestDB(TestCase): display_name = author.get_display_name(AuthorType.Translation) # THEN: It should return the name with the type in brackets - self.assertEqual("John Doe (Translation)", display_name) + assert "John Doe (Translation)" == display_name def test_add_songbooks(self): """ @@ -195,7 +195,7 @@ class TestDB(TestCase): song.add_songbook_entry(songbook, "550A") # THEN: The song should have two songbook entries - self.assertEqual(len(song.songbook_entries), 2, 'There should be two Songbook entries.') + assert len(song.songbook_entries) == 2, 'There should be two Songbook entries.' def test_upgrade_old_song_db(self): """ @@ -211,8 +211,7 @@ class TestDB(TestCase): updated_to_version, latest_version = upgrade_db(db_url, upgrade) # THEN: the song db should have been upgraded to the latest version - self.assertEqual(updated_to_version, latest_version, - 'The song DB should have been upgrade to the latest version') + assert updated_to_version == latest_version, 'The song DB should have been upgrade to the latest version' def test_upgrade_invalid_song_db(self): """ @@ -228,5 +227,4 @@ class TestDB(TestCase): updated_to_version, latest_version = upgrade_db(db_url, upgrade) # THEN: the song db should have been upgraded to the latest version without errors - self.assertEqual(updated_to_version, latest_version, - 'The song DB should have been upgrade to the latest version') + assert updated_to_version == latest_version, 'The song DB should have been upgrade to the latest version' diff --git a/tests/functional/openlp_plugins/songs/test_easyslidesimport.py b/tests/functional/openlp_plugins/songs/test_easyslidesimport.py index 6e0e6848b..7e6c52e96 100644 --- a/tests/functional/openlp_plugins/songs/test_easyslidesimport.py +++ b/tests/functional/openlp_plugins/songs/test_easyslidesimport.py @@ -3,7 +3,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,14 +21,10 @@ """ This module contains tests for the EasySlides song importer. """ -import os - -from openlp.core.common.path import Path - from tests.helpers.songfileimport import SongImportTestHelper +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'easyslidessongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'easyslides' class TestEasySlidesFileImport(SongImportTestHelper): @@ -42,7 +38,7 @@ class TestEasySlidesFileImport(SongImportTestHelper): """ Test that loading an EasySlides file works correctly on various files """ - self.file_import(Path(TEST_PATH, 'amazing-grace.xml'), - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace.json'))) - self.file_import(Path(TEST_PATH, 'Export_2017-01-12_BB.xml'), - self.load_external_result_data(os.path.join(TEST_PATH, 'Export_2017-01-12_BB.json'))) + self.file_import(TEST_PATH / 'amazing-grace.xml', + self.load_external_result_data(TEST_PATH / 'Amazing Grace.json')) + self.file_import(TEST_PATH / 'Export_2017-01-12_BB.xml', + self.load_external_result_data(TEST_PATH / 'Export_2017-01-12_BB.json')) diff --git a/tests/functional/openlp_plugins/songs/test_editsongform.py b/tests/functional/openlp_plugins/songs/test_editsongform.py index 5a5e861c7..650f9ca91 100644 --- a/tests/functional/openlp_plugins/songs/test_editsongform.py +++ b/tests/functional/openlp_plugins/songs/test_editsongform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,7 +29,6 @@ from PyQt5 import QtCore from openlp.core.common.registry import Registry from openlp.plugins.songs.forms.editsongform import EditSongForm - from tests.helpers.testmixin import TestMixin @@ -64,7 +63,7 @@ class TestEditSongForm(TestCase, TestMixin): valid = self.edit_song_form._validate_tags(tags) # THEN they should be valid - self.assertTrue(valid, "The tags list should be valid") + assert valid is True, "The tags list should be valid" def test_validate_nonmatching_tags(self): # Given a set of tags @@ -74,7 +73,7 @@ class TestEditSongForm(TestCase, TestMixin): valid = self.edit_song_form._validate_tags(tags) # THEN they should be valid - self.assertTrue(valid, "The tags list should be valid") + assert valid is True, "The tags list should be valid" @patch('openlp.plugins.songs.forms.editsongform.set_case_insensitive_completer') def test_load_objects(self, mocked_set_case_insensitive_completer): diff --git a/tests/functional/openlp_plugins/songs/test_editverseform.py b/tests/functional/openlp_plugins/songs/test_editverseform.py index 10b339dc2..f269b262c 100644 --- a/tests/functional/openlp_plugins/songs/test_editverseform.py +++ b/tests/functional/openlp_plugins/songs/test_editverseform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,7 +29,6 @@ from PyQt5 import QtCore from openlp.core.common.settings import Settings from openlp.plugins.songs.forms.editverseform import EditVerseForm - from tests.helpers.testmixin import TestMixin __default_settings__ = { @@ -71,7 +70,7 @@ class TestEditVerseForm(TestCase, TestMixin): self.edit_verse_form.update_suggested_verse_number() # THEN the verse number must not be changed - self.assertEqual(3, self.edit_verse_form.verse_number_box.value(), 'The verse number should be 3') + assert 3 == self.edit_verse_form.verse_number_box.value(), 'The verse number should be 3' def test_on_divide_split_button_clicked(self): """ @@ -84,8 +83,8 @@ class TestEditVerseForm(TestCase, TestMixin): # WHEN the method is called self.edit_verse_form.on_forced_split_button_clicked() # THEN the verse number must not be changed - self.assertEqual('[--}{--]\nText\n', self.edit_verse_form.verse_text_edit.toPlainText(), - 'The verse number should be [--}{--]\nText\n') + assert '[--}{--]\nText\n' == self.edit_verse_form.verse_text_edit.toPlainText(), \ + 'The verse number should be [--}{--]\nText\n' def test_on_split_button_clicked(self): """ @@ -98,5 +97,5 @@ class TestEditVerseForm(TestCase, TestMixin): # WHEN the method is called self.edit_verse_form.on_overflow_split_button_clicked() # THEN the verse number must not be changed - self.assertEqual('[---]\nText\n', self.edit_verse_form.verse_text_edit.toPlainText(), - 'The verse number should be [---]\nText\n') + assert '[---]\nText\n' == self.edit_verse_form.verse_text_edit.toPlainText(), \ + 'The verse number should be [---]\nText\n' diff --git a/tests/functional/openlp_plugins/songs/test_ewimport.py b/tests/functional/openlp_plugins/songs/test_ewimport.py index befa5b1f7..39835e677 100644 --- a/tests/functional/openlp_plugins/songs/test_ewimport.py +++ b/tests/functional/openlp_plugins/songs/test_ewimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -28,9 +28,9 @@ from unittest.mock import MagicMock, patch from openlp.core.common.registry import Registry from openlp.plugins.songs.lib.importers.easyworship import EasyWorshipSongImport, FieldDescEntry, FieldType +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'easyworshipsongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'easyworship' SONG_TEST_DATA = [ {'title': 'Amazing Grace', 'authors': ['John Newton'], @@ -165,11 +165,10 @@ class TestEasyWorshipSongImport(TestCase): field_desc_entry = FieldDescEntry(name, field_type, size) # THEN: - self.assertIsNotNone(field_desc_entry, 'Import should not be none') - self.assertEqual(field_desc_entry.name, name, 'FieldDescEntry.name should be the same as the name argument') - self.assertEqual(field_desc_entry.field_type, field_type, - 'FieldDescEntry.type should be the same as the type argument') - self.assertEqual(field_desc_entry.size, size, 'FieldDescEntry.size should be the same as the size argument') + assert field_desc_entry is not None, 'Import should not be none' + assert field_desc_entry.name == name, 'FieldDescEntry.name should be the same as the name argument' + assert field_desc_entry.field_type == field_type, 'FieldDescEntry.type should be the same as the type argument' + assert field_desc_entry.size == size, 'FieldDescEntry.size should be the same as the size argument' def test_create_importer(self): """ @@ -183,7 +182,7 @@ class TestEasyWorshipSongImport(TestCase): importer = EasyWorshipSongImport(mocked_manager, file_paths=[]) # THEN: The importer object should not be None - self.assertIsNotNone(importer, 'Import should not be none') + assert importer is not None, 'Import should not be none' def test_find_field_exists(self): """ @@ -201,7 +200,7 @@ class TestEasyWorshipSongImport(TestCase): for field_name in existing_fields: # THEN: The item corresponding the index returned should have the same name attribute - self.assertEqual(importer.field_descriptions[importer.db_find_field(field_name)].name, field_name) + assert importer.field_descriptions[importer.db_find_field(field_name)].name == field_name def test_find_non_existing_field(self): """ @@ -236,7 +235,7 @@ class TestEasyWorshipSongImport(TestCase): # THEN: db_set_record_struct should return None and Struct should be called with a value representing # the list of field descriptions - self.assertIsNone(return_value, 'db_set_record_struct should return None') + assert return_value is None, 'db_set_record_struct should return None' mocked_struct.Struct.assert_called_with('>50sHIB250s250s10sQ') @patch('openlp.plugins.songs.lib.importers.easyworship.SongImport') @@ -257,9 +256,8 @@ class TestEasyWorshipSongImport(TestCase): return_value = importer.db_get_field(field_index) # THEN: db_get_field should return the known results - self.assertEqual(return_value, result, - 'db_get_field should return "%s" when called with "%s"' % - (result, TEST_FIELDS[field_index])) + assert return_value == result, 'db_get_field should return "%s" when called with "%s"' % \ + (result, TEST_FIELDS[field_index]) @patch('openlp.plugins.songs.lib.importers.easyworship.SongImport') def test_get_memo_field(self, MockSongImport): @@ -285,7 +283,7 @@ class TestEasyWorshipSongImport(TestCase): # THEN: db_get_field should return the appropriate value with the appropriate mocked objects being # called - self.assertEqual(importer.db_get_field(field_index), get_field_result) + assert importer.db_get_field(field_index) == get_field_result for call in get_field_read_calls: mocked_memo_file.read.assert_any_call(call) for call in get_field_seek_calls: @@ -330,7 +328,7 @@ class TestEasyWorshipSongImport(TestCase): mocked_stat.return_value.st_size = 0x7FF # THEN: do_import should return None having called Path.stat() - self.assertIsNone(importer.do_import(), 'do_import should return None when db_size is less than 0x800') + assert importer.do_import() is None, 'do_import should return None when db_size is less than 0x800' mocked_stat.assert_called_once_with() @patch('openlp.plugins.songs.lib.importers.easyworship.SongImport') @@ -353,11 +351,10 @@ class TestEasyWorshipSongImport(TestCase): # THEN: do_import should return None having called closed the open files db and memo files. for effect in struct_unpack_return_values: - self.assertIsNone(importer.do_import(), 'do_import should return None when db_size is less than 0x800') - self.assertEqual(mocked_open().close.call_count, 2, - 'The open db and memo files should have been closed') + assert importer.do_import() is None, 'do_import should return None when db_size is less than 0x800' + assert mocked_open().close.call_count == 2, 'The open db and memo files should have been closed' mocked_open().close.reset_mock() - self.assertIs(mocked_open().seek.called, False, 'db_file.seek should not have been called.') + assert mocked_open().seek.called is False, 'db_file.seek should not have been called.' @patch('openlp.plugins.songs.lib.importers.easyworship.SongImport') @patch('openlp.plugins.songs.lib.importers.easyworship.Path.is_file', return_value=True) @@ -383,14 +380,14 @@ class TestEasyWorshipSongImport(TestCase): mocked_retrieve_windows_encoding.return_value = False # THEN: do_import should return None having called retrieve_windows_encoding with the correct encoding. - self.assertIsNone(importer.do_import(), 'do_import should return None when db_size is less than 0x800') + assert importer.do_import() is None, 'do_import should return None when db_size is less than 0x800' mocked_retrieve_windows_encoding.assert_any_call(encoding) def test_db_file_import(self): - return self._run_db_file_import(os.path.join(TEST_PATH, 'Songs.DB')) + return self._run_db_file_import(TEST_PATH / 'Songs.DB') def test_sqlite_db_file_import(self): - return self._run_db_file_import(os.path.join(TEST_PATH, 'ew6')) + return self._run_db_file_import(TEST_PATH / 'ew6') def _run_db_file_import(self, source_path): """ @@ -420,12 +417,13 @@ class TestEasyWorshipSongImport(TestCase): importer.topics = [] # WHEN: Importing each file - importer.import_source = source_path + # TODO: To Path object + importer.import_source = str(source_path) import_result = importer.do_import() # THEN: do_import should return none, the song data should be as expected, and finish should have been # called. - self.assertIsNone(import_result, 'do_import should return None when it has completed') + assert import_result is None, 'do_import should return None when it has completed' for song_data in SONG_TEST_DATA: title = song_data['title'] author_calls = song_data['authors'] @@ -433,19 +431,18 @@ class TestEasyWorshipSongImport(TestCase): ccli_number = song_data['ccli_number'] add_verse_calls = song_data['verses'] verse_order_list = song_data['verse_order_list'] - self.assertIn(title, importer._title_assignment_list, 'title for %s should be "%s"' % (title, title)) + assert title in importer._title_assignment_list, 'title for %s should be "%s"' % (title, title) for author in author_calls: mocked_add_author.assert_any_call(author) if song_copyright: - self.assertEqual(importer.copyright, song_copyright) + assert importer.copyright == song_copyright if ccli_number: - self.assertEqual(importer.ccli_number, ccli_number, - 'ccli_number for %s should be %s' % (title, ccli_number)) + assert importer.ccli_number == ccli_number, 'ccli_number for %s should be %s' % (title, ccli_number) for verse_text, verse_tag in add_verse_calls: mocked_add_verse.assert_any_call(verse_text, verse_tag) if verse_order_list: - self.assertEqual(importer.verse_order_list, verse_order_list, - 'verse_order_list for %s should be %s' % (title, verse_order_list)) + assert importer.verse_order_list == verse_order_list, \ + 'verse_order_list for %s should be %s' % (title, verse_order_list) mocked_finish.assert_called_with() @patch('openlp.plugins.songs.lib.importers.easyworship.SongImport') @@ -475,14 +472,14 @@ class TestEasyWorshipSongImport(TestCase): importer.topics = [] # WHEN: Importing ews file - importer.import_source = os.path.join(TEST_PATH, 'test1.ews') + importer.import_source = str(TEST_PATH / 'test1.ews') import_result = importer.do_import() # THEN: do_import should return none, the song data should be as expected, and finish should have been # called. title = EWS_SONG_TEST_DATA['title'] - self.assertIsNone(import_result, 'do_import should return None when it has completed') - self.assertIn(title, importer._title_assignment_list, 'title for should be "%s"' % title) + assert import_result is None, 'do_import should return None when it has completed' + assert title in importer._title_assignment_list, 'title for should be "%s"' % title mocked_add_author.assert_any_call(EWS_SONG_TEST_DATA['authors'][0]) for verse_text, verse_tag in EWS_SONG_TEST_DATA['verses']: mocked_add_verse.assert_any_call(verse_text, verse_tag) @@ -505,4 +502,4 @@ class TestEasyWorshipSongImport(TestCase): importer.set_song_import_object('Test Author', b'Det som var fr\x86n begynnelsen') # THEN: The import should fail - self.assertEquals(importer.entry_error_log, 'Unexpected data formatting.', 'Import should fail') + assert importer.entry_error_log == 'Unexpected data formatting.', 'Import should fail' diff --git a/tests/functional/openlp_plugins/songs/test_foilpresenterimport.py b/tests/functional/openlp_plugins/songs/test_foilpresenterimport.py index d3d705722..9c0af59a4 100644 --- a/tests/functional/openlp_plugins/songs/test_foilpresenterimport.py +++ b/tests/functional/openlp_plugins/songs/test_foilpresenterimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,15 +22,11 @@ """ This module contains tests for the SongShow Plus song importer. """ -import os from unittest import TestCase from unittest.mock import patch, MagicMock from openlp.plugins.songs.lib.importers.foilpresenter import FoilPresenter -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', '/resources/foilpresentersongs')) - class TestFoilPresenter(TestCase): """ @@ -106,7 +102,7 @@ class TestFoilPresenter(TestCase): foil_presenter_instance = FoilPresenter(mocked_manager, mocked_song_import) # THEN: The instance should not be None - self.assertIsNotNone(foil_presenter_instance, 'foil_presenter instance should not be none') + assert foil_presenter_instance is not None, 'foil_presenter instance should not be none' def test_no_xml(self): """ @@ -122,7 +118,7 @@ class TestFoilPresenter(TestCase): result = foil_presenter_instance.xml_to_song(arg) # Then: xml_to_song should return False - self.assertEqual(result, None, 'xml_to_song should return None when called with %s' % arg) + assert result is None, 'xml_to_song should return None when called with %s' % arg def test_encoding_declaration_removal(self): """ @@ -169,6 +165,6 @@ class TestFoilPresenter(TestCase): result = foil_presenter_instance._process_lyrics(mock_foilpresenterfolie, mocked_song) # THEN: _process_lyrics should return None and the song_import log_error method should have been called once - self.assertIsNone(result) + assert result is None self.mocked_song_import.log_error.assert_called_once_with('Element Text', 'Translated String') self.process_lyrics_patcher.start() diff --git a/tests/functional/openlp_plugins/songs/test_lib.py b/tests/functional/openlp_plugins/songs/test_lib.py index 334282a44..09011a3e3 100644 --- a/tests/functional/openlp_plugins/songs/test_lib.py +++ b/tests/functional/openlp_plugins/songs/test_lib.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -63,7 +63,7 @@ class TestLib(TestCase): result = clean_string(dirty_string) # THEN: The string should be cleaned up and lower-cased - self.assertEqual(result, 'aint gonna find you there ', 'The string should be cleaned up properly') + assert result == 'aint gonna find you there ', 'The string should be cleaned up properly' def test_clean_title(self): """ @@ -76,7 +76,7 @@ class TestLib(TestCase): result = clean_title(dirty_string) # THEN: The string should be cleaned up - self.assertEqual(result, 'This is a dirty string', 'The title should be cleaned up properly: "%s"' % result) + assert result == 'This is a dirty string', 'The title should be cleaned up properly: "%s"' % result def test_songs_probably_equal_same_song(self): """ @@ -275,7 +275,7 @@ class TestLib(TestCase): new_chord = transpose_chord(chord, 1, 'english') # THEN: The chord should be transposed up one note - self.assertEqual(new_chord, 'C#', 'The chord should be transposed up.') + assert new_chord == 'C#', 'The chord should be transposed up.' def test_transpose_chord_up_adv(self): """ @@ -288,7 +288,7 @@ class TestLib(TestCase): new_chord = transpose_chord(chord, 1, 'english') # THEN: The chord should be transposed up one note - self.assertEqual(new_chord, '(C#/E)', 'The chord should be transposed up.') + assert new_chord == '(C#/E)', 'The chord should be transposed up.' def test_transpose_chord_down(self): """ @@ -301,7 +301,7 @@ class TestLib(TestCase): new_chord = transpose_chord(chord, -1, 'english') # THEN: The chord should be transposed down one note - self.assertEqual(new_chord, 'B', 'The chord should be transposed down.') + assert new_chord == 'B', 'The chord should be transposed down.' def test_transpose_chord_error(self): """ @@ -314,8 +314,8 @@ class TestLib(TestCase): # THEN: An exception should be raised with self.assertRaises(ValueError) as err: new_chord = transpose_chord(chord, -1, 'english') - self.assertEqual(err.exception.args[0], '\'T\' is not in list', - 'ValueError exception should have been thrown for invalid chord') + assert err.exception.args[0] == '\'T\' is not in list', \ + 'ValueError exception should have been thrown for invalid chord' @patch('openlp.plugins.songs.lib.transpose_verse') @patch('openlp.plugins.songs.lib.Settings') @@ -361,13 +361,13 @@ class TestVerseType(TestCase): result = VerseType.translated_tag('v') # THEN: The result should be "V" - self.assertEqual(result, 'V', 'The result should be "V"') + assert result == 'V', 'The result should be "V"' # WHEN: We run the translated_tag() method with a "chorus" result = VerseType.translated_tag('c') # THEN: The result should be "C" - self.assertEqual(result, 'C', 'The result should be "C"') + assert result == 'C', 'The result should be "C"' def test_translated_invalid_tag(self): """ @@ -381,7 +381,7 @@ class TestVerseType(TestCase): result = VerseType.translated_tag('z') # THEN: The result should be "O" - self.assertEqual(result, 'O', 'The result should be "O", but was "%s"' % result) + assert result == 'O', 'The result should be "O", but was "%s"' % result def test_translated_invalid_tag_with_specified_default(self): """ @@ -395,7 +395,7 @@ class TestVerseType(TestCase): result = VerseType.translated_tag('q', VerseType.Bridge) # THEN: The result should be "B" - self.assertEqual(result, 'B', 'The result should be "B", but was "%s"' % result) + assert result == 'B', 'The result should be "B", but was "%s"' % result def test_translated_invalid_tag_with_invalid_default(self): """ @@ -409,7 +409,7 @@ class TestVerseType(TestCase): result = VerseType.translated_tag('q', 29) # THEN: The result should be "O" - self.assertEqual(result, 'O', 'The result should be "O", but was "%s"' % result) + assert result == 'O', 'The result should be "O", but was "%s"' % result def test_translated_name(self): """ @@ -423,13 +423,13 @@ class TestVerseType(TestCase): result = VerseType.translated_name('v') # THEN: The result should be "Verse" - self.assertEqual(result, 'Verse', 'The result should be "Verse"') + assert result == 'Verse', 'The result should be "Verse"' # WHEN: We run the translated_name() method with a "chorus" result = VerseType.translated_name('c') # THEN: The result should be "Chorus" - self.assertEqual(result, 'Chorus', 'The result should be "Chorus"') + assert result == 'Chorus', 'The result should be "Chorus"' def test_translated_invalid_name(self): """ @@ -443,7 +443,7 @@ class TestVerseType(TestCase): result = VerseType.translated_name('z') # THEN: The result should be "Other" - self.assertEqual(result, 'Other', 'The result should be "Other", but was "%s"' % result) + assert result == 'Other', 'The result should be "Other", but was "%s"' % result def test_translated_invalid_name_with_specified_default(self): """ @@ -457,7 +457,7 @@ class TestVerseType(TestCase): result = VerseType.translated_name('q', VerseType.Bridge) # THEN: The result should be "Bridge" - self.assertEqual(result, 'Bridge', 'The result should be "Bridge", but was "%s"' % result) + assert result == 'Bridge', 'The result should be "Bridge", but was "%s"' % result def test_translated_invalid_name_with_invalid_default(self): """ @@ -471,7 +471,7 @@ class TestVerseType(TestCase): result = VerseType.translated_name('q', 29) # THEN: The result should be "Other" - self.assertEqual(result, 'Other', 'The result should be "Other", but was "%s"' % result) + assert result == 'Other', 'The result should be "Other", but was "%s"' % result def test_from_tag(self): """ @@ -485,7 +485,7 @@ class TestVerseType(TestCase): result = VerseType.from_tag('v') # THEN: The result should be VerseType.Verse - self.assertEqual(result, VerseType.Verse, 'The result should be VerseType.Verse, but was "%s"' % result) + assert result == VerseType.Verse, 'The result should be VerseType.Verse, but was "%s"' % result def test_from_tag_with_invalid_tag(self): """ @@ -499,7 +499,7 @@ class TestVerseType(TestCase): result = VerseType.from_tag('w') # THEN: The result should be VerseType.Other - self.assertEqual(result, VerseType.Other, 'The result should be VerseType.Other, but was "%s"' % result) + assert result == VerseType.Other, 'The result should be VerseType.Other, but was "%s"' % result def test_from_tag_with_specified_default(self): """ @@ -513,7 +513,7 @@ class TestVerseType(TestCase): result = VerseType.from_tag('x', VerseType.Chorus) # THEN: The result should be VerseType.Chorus - self.assertEqual(result, VerseType.Chorus, 'The result should be VerseType.Chorus, but was "%s"' % result) + assert result == VerseType.Chorus, 'The result should be VerseType.Chorus, but was "%s"' % result def test_from_tag_with_invalid_intdefault(self): """ @@ -527,7 +527,7 @@ class TestVerseType(TestCase): result = VerseType.from_tag('m', 29) # THEN: The result should be VerseType.Other - self.assertEqual(result, VerseType.Other, 'The result should be VerseType.Other, but was "%s"' % result) + assert result == VerseType.Other, 'The result should be VerseType.Other, but was "%s"' % result def test_from_tag_with_invalid_default(self): """ @@ -541,7 +541,7 @@ class TestVerseType(TestCase): result = VerseType.from_tag('@', 'asdf') # THEN: The result should be VerseType.Other - self.assertEqual(result, VerseType.Other, 'The result should be VerseType.Other, but was "%s"' % result) + assert result == VerseType.Other, 'The result should be VerseType.Other, but was "%s"' % result def test_from_tag_with_none_default(self): """ @@ -555,7 +555,7 @@ class TestVerseType(TestCase): result = VerseType.from_tag('m', None) # THEN: The result should be None - self.assertIsNone(result, 'The result should be None, but was "%s"' % result) + assert result is None, 'The result should be None, but was "%s"' % result @patch('openlp.plugins.songs.lib.VerseType.translated_tags', new_callable=PropertyMock, return_value=['x']) def test_from_loose_input_with_invalid_input(self, mocked_translated_tags): @@ -567,7 +567,7 @@ class TestVerseType(TestCase): result = VerseType.from_loose_input('m', None) # THEN: The result should be None - self.assertIsNone(result, 'The result should be None, but was "%s"' % result) + assert result is None, 'The result should be None, but was "%s"' % result @patch('openlp.plugins.songs.lib.VerseType.translated_tags', new_callable=PropertyMock, return_value=['x']) def test_from_loose_input_with_valid_input(self, mocked_translated_tags): @@ -579,4 +579,4 @@ class TestVerseType(TestCase): result = VerseType.from_loose_input('v') # THEN: The result should be a Verse - self.assertEqual(result, VerseType.Verse, 'The result should be a verse, but was "%s"' % result) + assert result == VerseType.Verse, 'The result should be a verse, but was "%s"' % result diff --git a/tests/functional/openlp_plugins/songs/test_lyriximport.py b/tests/functional/openlp_plugins/songs/test_lyriximport.py index 2732b3154..eea29fceb 100644 --- a/tests/functional/openlp_plugins/songs/test_lyriximport.py +++ b/tests/functional/openlp_plugins/songs/test_lyriximport.py @@ -3,7 +3,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,14 +21,10 @@ """ This module contains tests for the LyriX song importer. """ -import os - -from openlp.core.common.path import Path - from tests.helpers.songfileimport import SongImportTestHelper +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'lyrixsongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'lyrix' class TestLyrixFileImport(SongImportTestHelper): @@ -42,9 +38,9 @@ class TestLyrixFileImport(SongImportTestHelper): """ Test that loading an LyriX file works correctly on various files """ - self.file_import([Path(TEST_PATH, 'A06.TXT')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace.json'))) - self.file_import([Path(TEST_PATH, 'A002.TXT')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace2.json'))) - self.file_import([Path(TEST_PATH, 'AO05.TXT')], - self.load_external_result_data(os.path.join(TEST_PATH, 'in die regterhand.json'))) + self.file_import([TEST_PATH / 'A06.TXT'], + self.load_external_result_data(TEST_PATH / 'Amazing Grace.json')) + self.file_import([TEST_PATH / 'A002.TXT'], + self.load_external_result_data(TEST_PATH / 'Amazing Grace2.json')) + self.file_import([TEST_PATH / 'AO05.TXT'], + self.load_external_result_data(TEST_PATH / 'in die regterhand.json')) diff --git a/tests/functional/openlp_plugins/songs/test_mediaitem.py b/tests/functional/openlp_plugins/songs/test_mediaitem.py index 530c1cf6b..9af310e26 100644 --- a/tests/functional/openlp_plugins/songs/test_mediaitem.py +++ b/tests/functional/openlp_plugins/songs/test_mediaitem.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -32,7 +32,6 @@ from openlp.core.common.settings import Settings from openlp.core.lib import ServiceItem from openlp.plugins.songs.lib.db import AuthorType, Song from openlp.plugins.songs.lib.mediaitem import SongMediaItem - from tests.helpers.testmixin import TestMixin @@ -324,10 +323,9 @@ class TestMediaItem(TestCase, TestMixin): author_list = self.media_item.generate_footer(service_item, mock_song) # THEN: I get the following Array returned - self.assertEqual(service_item.raw_footer, ['My Song', 'Written by: my author', 'My copyright'], - 'The array should be returned correctly with a song, one author and copyright') - self.assertEqual(author_list, ['my author'], - 'The author list should be returned correctly with one author') + assert service_item.raw_footer == ['My Song', 'Written by: my author', 'My copyright'], \ + 'The array should be returned correctly with a song, one author and copyright' + assert author_list == ['my author'], 'The author list should be returned correctly with one author' @patch(u'openlp.plugins.songs.lib.mediaitem.Settings') def test_build_song_footer_one_author_hide_written_by(self, MockedSettings): @@ -356,11 +354,10 @@ class TestMediaItem(TestCase, TestMixin): author_list = self.media_item.generate_footer(service_item, mock_song) # THEN: I get the following Array returned - self.assertEqual(service_item.raw_footer, ['My Song', 'my author', 'My copyright'], - 'The array should be returned correctly with a song, one author and copyright,' - 'text Written by should not be part of the text.') - self.assertEqual(author_list, ['my author'], - 'The author list should be returned correctly with one author') + assert service_item.raw_footer == ['My Song', 'my author', 'My copyright'], \ + 'The array should be returned correctly with a song, one author and copyright, ' \ + 'text Written by should not be part of the text.' + assert author_list == ['my author'], 'The author list should be returned correctly with one author' def test_build_song_footer_two_authors(self): """ @@ -395,11 +392,11 @@ class TestMediaItem(TestCase, TestMixin): author_list = self.media_item.generate_footer(service_item, mock_song) # THEN: I get the following Array returned - self.assertEqual(service_item.raw_footer, ['My Song', 'Words: another author', 'Music: my author', - 'Translation: translator', 'My copyright'], - 'The array should be returned correctly with a song, two authors and copyright') - self.assertEqual(author_list, ['another author', 'my author', 'translator'], - 'The author list should be returned correctly with two authors') + assert service_item.raw_footer == ['My Song', 'Words: another author', 'Music: my author', + 'Translation: translator', 'My copyright'], \ + 'The array should be returned correctly with a song, two authors and copyright' + assert author_list == ['another author', 'my author', 'translator'], \ + 'The author list should be returned correctly with two authors' def test_build_song_footer_base_ccli(self): """ @@ -416,16 +413,16 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.generate_footer(service_item, mock_song) # THEN: I get the following Array returned - self.assertEqual(service_item.raw_footer, ['My Song', 'My copyright', 'CCLI License: 1234'], - 'The array should be returned correctly with a song, an author, copyright and ccli') + assert service_item.raw_footer == ['My Song', 'My copyright', 'CCLI License: 1234'], \ + 'The array should be returned correctly with a song, an author, copyright and ccli' # WHEN: I amend the CCLI value Settings().setValue('core/ccli number', '4321') self.media_item.generate_footer(service_item, mock_song) # THEN: I would get an amended footer string - self.assertEqual(service_item.raw_footer, ['My Song', 'My copyright', 'CCLI License: 4321'], - 'The array should be returned correctly with a song, an author, copyright and amended ccli') + assert service_item.raw_footer == ['My Song', 'My copyright', 'CCLI License: 4321'], \ + 'The array should be returned correctly with a song, an author, copyright and amended ccli' def test_build_song_footer_base_songbook(self): """ @@ -451,14 +448,14 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.generate_footer(service_item, song) # THEN: The songbook should not be in the footer - self.assertEqual(service_item.raw_footer, ['My Song', 'My copyright']) + assert service_item.raw_footer == ['My Song', 'My copyright'] # WHEN: I activate the "display songbook" option self.media_item.display_songbook = True self.media_item.generate_footer(service_item, song) # THEN: The songbook should be in the footer - self.assertEqual(service_item.raw_footer, ['My Song', 'My copyright', 'My songbook #12, Thy songbook #502A']) + assert service_item.raw_footer == ['My Song', 'My copyright', 'My songbook #12, Thy songbook #502A'] def test_build_song_footer_copyright_enabled(self): """ @@ -475,7 +472,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.generate_footer(service_item, mock_song) # THEN: The copyright symbol should be in the footer - self.assertEqual(service_item.raw_footer, ['My Song', '© My copyright']) + assert service_item.raw_footer == ['My Song', '© My copyright'] def test_build_song_footer_copyright_disabled(self): """ @@ -491,7 +488,7 @@ class TestMediaItem(TestCase, TestMixin): self.media_item.generate_footer(service_item, mock_song) # THEN: The copyright symbol should not be in the footer - self.assertEqual(service_item.raw_footer, ['My Song', 'My copyright']) + assert service_item.raw_footer == ['My Song', 'My copyright'] def test_authors_match(self): """ @@ -517,7 +514,7 @@ class TestMediaItem(TestCase, TestMixin): result = self.media_item._authors_match(song, authors_str) # THEN: They should match - self.assertTrue(result, "Authors should match") + assert result is True, "Authors should match" def test_authors_dont_match(self): # GIVEN: A song and a string with authors @@ -540,7 +537,7 @@ class TestMediaItem(TestCase, TestMixin): result = self.media_item._authors_match(song, authors_str) # THEN: They should not match - self.assertFalse(result, "Authors should not match") + assert result is False, "Authors should not match" def test_build_remote_search(self): """ @@ -559,7 +556,7 @@ class TestMediaItem(TestCase, TestMixin): search_results = self.media_item.search('My Song', False) # THEN: The correct formatted results are returned - self.assertEqual(search_results, [[123, 'My Song', 'My alternative']]) + assert search_results == [[123, 'My Song', 'My alternative']] @patch('openlp.plugins.songs.lib.mediaitem.Book') @patch('openlp.plugins.songs.lib.mediaitem.SongBookEntry') @@ -590,4 +587,4 @@ class TestMediaItem(TestCase, TestMixin): mocked_or.assert_called_once_with('%jesus%', '%jesus%', '%jesus%', '%jesus%', '%jesus%') self.mocked_plugin.manager.session.query.assert_called_once_with(MockedSong) - self.assertEqual(self.mocked_plugin.manager.session.query.mock_calls[4][0], '().join().join().filter().all') + assert self.mocked_plugin.manager.session.query.mock_calls[4][0] == '().join().join().filter().all' diff --git a/tests/functional/openlp_plugins/songs/test_mediashout.py b/tests/functional/openlp_plugins/songs/test_mediashout.py index 8fc452ea4..15adfded0 100644 --- a/tests/functional/openlp_plugins/songs/test_mediashout.py +++ b/tests/functional/openlp_plugins/songs/test_mediashout.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,6 +27,7 @@ from unittest import TestCase, skipUnless from unittest.mock import MagicMock, patch, call from openlp.core.common.registry import Registry + try: from openlp.plugins.songs.lib.importers.mediashout import MediaShoutImport CAN_RUN_TESTS = True @@ -54,7 +55,7 @@ class TestMediaShoutImport(TestCase): importer = MediaShoutImport(MagicMock(), file_path='mediashout.db') # THEN: It should not be None - self.assertIsNotNone(importer) + assert importer is not None @patch('openlp.plugins.songs.lib.importers.mediashout.pyodbc') def test_do_import_fails_to_connect(self, mocked_pyodbc): @@ -112,7 +113,7 @@ class TestMediaShoutImport(TestCase): call('SELECT Name FROM Groups INNER JOIN SongGroups ON SongGroups.GroupId = Groups.GroupId ' 'WHERE SongGroups.Record = ?', 1.0) ] - self.assertEqual(expected_execute_calls, mocked_cursor.execute.call_args_list) + assert expected_execute_calls == mocked_cursor.execute.call_args_list mocked_process_song.assert_called_once_with(song, [verse], [play_order], [theme, group]) @patch('openlp.plugins.songs.lib.importers.mediashout.pyodbc') @@ -172,16 +173,16 @@ class TestMediaShoutImport(TestCase): # THEN: It should be added to the database mocked_set_defaults.assert_called_once_with() - self.assertEqual('Amazing Grace', importer.title) + assert 'Amazing Grace' == importer.title mocked_parse_author.assert_called_once_with('William Wilberforce') mocked_add_copyright.assert_called_once_with('Public Domain') - self.assertEqual('Great old hymn', importer.comments) - self.assertEqual(['Grace', 'Hymns'], importer.topics) - self.assertEqual('Hymns', importer.song_book_name) - self.assertEqual('', importer.song_number) + assert 'Great old hymn' == importer.comments + assert ['Grace', 'Hymns'] == importer.topics + assert 'Hymns' == importer.song_book_name + assert '' == importer.song_number mocked_add_verse.assert_called_once_with( 'Amazing grace, how sweet the sound\nThat saved a wretch like me', 'V1') - self.assertEqual(['V1'], importer.verse_order_list) + assert ['V1'] == importer.verse_order_list mocked_finish.assert_called_once_with() def test_process_song_with_song_number(self): @@ -214,14 +215,14 @@ class TestMediaShoutImport(TestCase): # THEN: It should be added to the database mocked_set_defaults.assert_called_once_with() - self.assertEqual('Amazing Grace', importer.title) + assert 'Amazing Grace' == importer.title mocked_parse_author.assert_called_once_with('William Wilberforce') mocked_add_copyright.assert_called_once_with('Public Domain') - self.assertEqual('Great old hymn', importer.comments) - self.assertEqual(['Grace', 'Hymns'], importer.topics) - self.assertEqual('Hymns', importer.song_book_name) - self.assertEqual('2', importer.song_number) + assert 'Great old hymn' == importer.comments + assert ['Grace', 'Hymns'] == importer.topics + assert 'Hymns' == importer.song_book_name + assert '2' == importer.song_number mocked_add_verse.assert_called_once_with( 'Amazing grace, how sweet the sound\nThat saved a wretch like me', 'V1') - self.assertEqual(['V1'], importer.verse_order_list) + assert ['V1'], importer.verse_order_list mocked_finish.assert_called_once_with() diff --git a/tests/functional/openlp_plugins/songs/test_openlpimporter.py b/tests/functional/openlp_plugins/songs/test_openlpimporter.py index 590d09b79..5bf9d3a9a 100644 --- a/tests/functional/openlp_plugins/songs/test_openlpimporter.py +++ b/tests/functional/openlp_plugins/songs/test_openlpimporter.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -51,7 +51,7 @@ class TestOpenLPImport(TestCase): importer = OpenLPSongImport(mocked_manager, file_paths=[]) # THEN: The importer object should not be None - self.assertIsNotNone(importer, 'Import should not be none') + assert importer is not None, 'Import should not be none' def test_invalid_import_source(self): """ @@ -70,6 +70,6 @@ class TestOpenLPImport(TestCase): importer.import_source = source # THEN: do_import should return none and the progress bar maximum should not be set. - self.assertIsNone(importer.do_import(), 'do_import should return None when import_source is not a list') - self.assertEqual(mocked_import_wizard.progress_bar.setMaximum.called, False, - 'setMaximum on import_wizard.progress_bar should not have been called') + assert importer.do_import() is None, 'do_import should return None when import_source is not a list' + assert mocked_import_wizard.progress_bar.setMaximum.called is False, \ + 'setMaximum on import_wizard.progress_bar should not have been called' diff --git a/tests/functional/openlp_plugins/songs/test_openlyricsexport.py b/tests/functional/openlp_plugins/songs/test_openlyricsexport.py index 85bf0818c..ba9e959af 100644 --- a/tests/functional/openlp_plugins/songs/test_openlyricsexport.py +++ b/tests/functional/openlp_plugins/songs/test_openlyricsexport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -26,10 +26,9 @@ from tempfile import mkdtemp from unittest import TestCase from unittest.mock import MagicMock, patch -from openlp.core.common.registry import Registry from openlp.core.common.path import Path +from openlp.core.common.registry import Registry from openlp.plugins.songs.lib.openlyricsexport import OpenLyricsExport - from tests.helpers.testmixin import TestMixin @@ -72,9 +71,7 @@ class TestOpenLyricsExport(TestCase, TestMixin): ol_export.do_export() # THEN: The exporter should have created 2 files - self.assertTrue((self.temp_folder / - '{title} ({display_name}).xml'.format( - title=song.title, display_name=author.display_name)).exists()) - self.assertTrue((self.temp_folder / - '{title} ({display_name})-1.xml'.format( - title=song.title, display_name=author.display_name)).exists()) + assert (self.temp_folder / '{title} ({display_name}).xml'.format( + title=song.title, display_name=author.display_name)).exists() is True + assert (self.temp_folder / '{title} ({display_name})-1.xml'.format( + title=song.title, display_name=author.display_name)).exists() is True diff --git a/tests/functional/openlp_plugins/songs/test_openlyricsimport.py b/tests/functional/openlp_plugins/songs/test_openlyricsimport.py index 088711fbc..d3356666e 100644 --- a/tests/functional/openlp_plugins/songs/test_openlyricsimport.py +++ b/tests/functional/openlp_plugins/songs/test_openlyricsimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,24 +22,21 @@ """ This module contains tests for the OpenLyrics song importer. """ -import os import json from unittest import TestCase from unittest.mock import MagicMock, patch from lxml import etree, objectify -from openlp.core.common.path import Path from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings from openlp.plugins.songs.lib.importers.openlyrics import OpenLyricsImport from openlp.plugins.songs.lib.importers.songimport import SongImport from openlp.plugins.songs.lib.openlyricsxml import OpenLyrics - from tests.helpers.testmixin import TestMixin +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), - '..', '..', '..', 'resources', 'openlyricssongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'openlyrics' SONG_TEST_DATA = { 'What a friend we have in Jesus.xml': { 'title': 'What A Friend We Have In Jesus', @@ -114,7 +111,7 @@ class TestOpenLyricsImport(TestCase, TestMixin): importer = OpenLyricsImport(mocked_manager, file_paths=[]) # THEN: The importer should be an instance of SongImport - self.assertIsInstance(importer, SongImport) + assert isinstance(importer, SongImport) def test_file_import(self): """ @@ -130,11 +127,11 @@ class TestOpenLyricsImport(TestCase, TestMixin): importer.open_lyrics.xml_to_song = MagicMock() # WHEN: Importing each file - importer.import_source = [Path(TEST_PATH, song_file)] + importer.import_source = [TEST_PATH / song_file] importer.do_import() # THEN: The xml_to_song() method should have been called - self.assertTrue(importer.open_lyrics.xml_to_song.called) + assert importer.open_lyrics.xml_to_song.called is True def test_process_formatting_tags(self): """ @@ -145,7 +142,7 @@ class TestOpenLyricsImport(TestCase, TestMixin): Settings().setValue('formattingTags/html_tags', json.dumps(start_tags)) ol = OpenLyrics(mocked_manager) parser = etree.XMLParser(remove_blank_text=True) - parsed_file = etree.parse(open(os.path.join(TEST_PATH, 'duchu-tags.xml'), 'rb'), parser) + parsed_file = etree.parse((TEST_PATH / 'duchu-tags.xml').open('rb'), parser) xml = etree.tostring(parsed_file).decode() song_xml = objectify.fromstring(xml) @@ -153,9 +150,8 @@ class TestOpenLyricsImport(TestCase, TestMixin): ol._process_formatting_tags(song_xml, False) # THEN: New tags should have been saved - self.assertListEqual(json.loads(json.dumps(result_tags)), - json.loads(str(Settings().value('formattingTags/html_tags'))), - 'The formatting tags should contain both the old and the new') + assert json.loads(json.dumps(result_tags)) == json.loads(str(Settings().value('formattingTags/html_tags'))), \ + 'The formatting tags should contain both the old and the new' def test_process_author(self): """ @@ -173,8 +169,8 @@ class TestOpenLyricsImport(TestCase, TestMixin): ol._process_authors(properties_xml, mocked_song) # THEN: add_author should have been called twice - self.assertEquals(mocked_song.method_calls[0][1][1], 'words+music') - self.assertEquals(mocked_song.method_calls[1][1][1], 'words') + assert mocked_song.method_calls[0][1][1] == 'words+music' + assert mocked_song.method_calls[1][1][1] == 'words' def test_process_songbooks(self): """ @@ -192,5 +188,5 @@ class TestOpenLyricsImport(TestCase, TestMixin): ol._process_songbooks(properties_xml, mocked_song) # THEN: add_songbook_entry should have been called twice - self.assertEquals(mocked_song.method_calls[0][1][1], '48') - self.assertEquals(mocked_song.method_calls[1][1][1], '445 A') + assert mocked_song.method_calls[0][1][1] == '48' + assert mocked_song.method_calls[1][1][1] == '445 A' diff --git a/tests/functional/openlp_plugins/songs/test_openoffice.py b/tests/functional/openlp_plugins/songs/test_openoffice.py index 45ef2acfd..8821865d7 100644 --- a/tests/functional/openlp_plugins/songs/test_openoffice.py +++ b/tests/functional/openlp_plugins/songs/test_openoffice.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -26,7 +26,6 @@ from unittest import TestCase, skipIf from unittest.mock import MagicMock, patch from openlp.core.common.registry import Registry - from tests.helpers.testmixin import TestMixin try: @@ -59,7 +58,7 @@ class TestOpenOfficeImport(TestCase, TestMixin): importer = OpenOfficeImport(mocked_manager, file_paths=[]) # THEN: The importer object should not be None - self.assertIsNotNone(importer, 'Import should not be none') + assert importer is not None, 'Import should not be none' @patch('openlp.plugins.songs.lib.importers.openoffice.SongImport') def test_close_ooo_file(self, mocked_songimport): @@ -76,4 +75,4 @@ class TestOpenOfficeImport(TestCase, TestMixin): importer.close_ooo_file() # THEN: The document attribute should be None even if an exception is raised') - self.assertIsNone(importer.document, 'Document should be None even if an exception is raised') + assert importer.document is None, 'Document should be None even if an exception is raised' diff --git a/tests/functional/openlp_plugins/songs/test_opensongimport.py b/tests/functional/openlp_plugins/songs/test_opensongimport.py index a8582b3e4..b4c892f3e 100644 --- a/tests/functional/openlp_plugins/songs/test_opensongimport.py +++ b/tests/functional/openlp_plugins/songs/test_opensongimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,18 +22,15 @@ """ This module contains tests for the OpenSong song importer. """ -import os from unittest import TestCase from unittest.mock import patch, MagicMock from openlp.core.common.registry import Registry -from openlp.core.common.path import Path from openlp.plugins.songs.lib.importers.opensong import OpenSongImport - from tests.helpers.songfileimport import SongImportTestHelper +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'opensongsongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'opensong' class TestOpenSongFileImport(SongImportTestHelper): @@ -53,16 +50,16 @@ class TestOpenSongFileImport(SongImportTestHelper): mocked_returned_settings.value.side_effect = lambda value: True if value == 'songs/enable chords' else False mocked_settings.return_value = mocked_returned_settings # Do the test import - self.file_import([Path(TEST_PATH, 'Amazing Grace')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace.json'))) - self.file_import([Path(TEST_PATH, 'Beautiful Garden Of Prayer')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Beautiful Garden Of Prayer.json'))) - self.file_import([Path(TEST_PATH, 'One, Two, Three, Four, Five')], - self.load_external_result_data(os.path.join(TEST_PATH, 'One, Two, Three, Four, Five.json'))) - self.file_import([Path(TEST_PATH, 'Amazing Grace2')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace.json'))) - self.file_import([Path(TEST_PATH, 'Amazing Grace with bad CCLI')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace without CCLI.json'))) + self.file_import([TEST_PATH / 'Amazing Grace'], + self.load_external_result_data(TEST_PATH / 'Amazing Grace.json')) + self.file_import([TEST_PATH / 'Beautiful Garden Of Prayer'], + self.load_external_result_data(TEST_PATH / 'Beautiful Garden Of Prayer.json')) + self.file_import([TEST_PATH / 'One, Two, Three, Four, Five'], + self.load_external_result_data(TEST_PATH / 'One, Two, Three, Four, Five.json')) + self.file_import([TEST_PATH / 'Amazing Grace2'], + self.load_external_result_data(TEST_PATH / 'Amazing Grace.json')) + self.file_import([TEST_PATH / 'Amazing Grace with bad CCLI'], + self.load_external_result_data(TEST_PATH / 'Amazing Grace without CCLI.json')) class TestOpenSongImport(TestCase): @@ -87,7 +84,7 @@ class TestOpenSongImport(TestCase): importer = OpenSongImport(mocked_manager, file_paths=[]) # THEN: The importer object should not be None - self.assertIsNotNone(importer, 'Import should not be none') + assert importer is not None, 'Import should not be none' def test_invalid_import_source(self): """ @@ -106,9 +103,9 @@ class TestOpenSongImport(TestCase): importer.import_source = source # THEN: do_import should return none and the progress bar maximum should not be set. - self.assertIsNone(importer.do_import(), 'do_import should return None when import_source is not a list') - self.assertEqual(mocked_import_wizard.progress_bar.setMaximum.called, False, - 'setMaximum on import_wizard.progress_bar should not have been called') + assert importer.do_import() is None, 'do_import should return None when import_source is not a list' + assert mocked_import_wizard.progress_bar.setMaximum.called is False, \ + 'setMaximum on import_wizard.progress_bar should not have been called' def test_valid_import_source(self): """ @@ -127,6 +124,6 @@ class TestOpenSongImport(TestCase): # THEN: do_import should return none and the progress bar setMaximum should be called with the length of # import_source. - self.assertIsNone(importer.do_import(), 'do_import should return None when import_source is a list ' - 'and stop_import_flag is True') + assert importer.do_import() is None, \ + 'do_import should return None when import_source is a list and stop_import_flag is True' mocked_import_wizard.progress_bar.setMaximum.assert_called_with(len(importer.import_source)) diff --git a/tests/functional/openlp_plugins/songs/test_opsproimport.py b/tests/functional/openlp_plugins/songs/test_opsproimport.py index 8dac8eca4..2c9e61ee9 100644 --- a/tests/functional/openlp_plugins/songs/test_opsproimport.py +++ b/tests/functional/openlp_plugins/songs/test_opsproimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,8 +22,6 @@ """ This module contains tests for the WorshipCenter Pro song importer. """ -import os -import json from unittest import TestCase, skipUnless from unittest.mock import patch, MagicMock @@ -34,7 +32,10 @@ try: except ImportError: CAN_RUN_TESTS = False -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'opsprosongs')) +from tests.utils import load_external_result_data +from tests.utils.constants import RESOURCE_PATH + +TEST_PATH = RESOURCE_PATH / 'songs' / 'opspro' def _get_item(data, key): @@ -59,8 +60,7 @@ def _build_data(test_file, dual_language): song.Version = '1' song.Origin = '...' lyrics = MagicMock() - test_file = open(os.path.join(TEST_PATH, test_file), 'rb') - lyrics.Lyrics = test_file.read().decode() + lyrics.Lyrics = (TEST_PATH / test_file).read_bytes().decode() lyrics.Type = 1 lyrics.IsDualLanguage = dual_language return song, lyrics @@ -89,7 +89,7 @@ class TestOpsProSongImport(TestCase): importer = OPSProImport(mocked_manager, file_paths=[]) # THEN: The importer object should not be None - self.assertIsNotNone(importer, 'Import should not be none') + assert importer is not None, 'Import should not be none' @patch('openlp.plugins.songs.lib.importers.opspro.SongImport') def test_detect_chorus(self, mocked_songimport): @@ -106,10 +106,9 @@ class TestOpsProSongImport(TestCase): importer.process_song(song, lyrics, []) # THEN: The imported data should look like expected - result_file = open(os.path.join(TEST_PATH, 'You are so faithful.json'), 'rb') - result_data = json.loads(result_file.read().decode()) - self.assertListEqual(importer.verses, _get_item(result_data, 'verses')) - self.assertListEqual(importer.verse_order_list_generated, _get_item(result_data, 'verse_order_list')) + result_data = load_external_result_data(TEST_PATH / 'You are so faithful.json') + assert importer.verses == _get_item(result_data, 'verses') + assert importer.verse_order_list_generated == _get_item(result_data, 'verse_order_list') @patch('openlp.plugins.songs.lib.importers.opspro.SongImport') def test_join_and_split(self, mocked_songimport): @@ -126,10 +125,9 @@ class TestOpsProSongImport(TestCase): importer.process_song(song, lyrics, []) # THEN: The imported data should look like expected - result_file = open(os.path.join(TEST_PATH, 'Amazing Grace.json'), 'rb') - result_data = json.loads(result_file.read().decode()) - self.assertListEqual(importer.verses, _get_item(result_data, 'verses')) - self.assertListEqual(importer.verse_order_list_generated, _get_item(result_data, 'verse_order_list')) + result_data = load_external_result_data(TEST_PATH / 'Amazing Grace.json') + assert importer.verses == _get_item(result_data, 'verses') + assert importer.verse_order_list_generated == _get_item(result_data, 'verse_order_list') @patch('openlp.plugins.songs.lib.importers.opspro.SongImport') def test_trans_off_tag(self, mocked_songimport): @@ -146,10 +144,9 @@ class TestOpsProSongImport(TestCase): importer.process_song(song, lyrics, []) # THEN: The imported data should look like expected - result_file = open(os.path.join(TEST_PATH, 'Amazing Grace.json'), 'rb') - result_data = json.loads(result_file.read().decode()) - self.assertListEqual(importer.verses, _get_item(result_data, 'verses')) - self.assertListEqual(importer.verse_order_list_generated, _get_item(result_data, 'verse_order_list')) + result_data = load_external_result_data(TEST_PATH / 'Amazing Grace.json') + assert importer.verses == _get_item(result_data, 'verses') + assert importer.verse_order_list_generated == _get_item(result_data, 'verse_order_list') @patch('openlp.plugins.songs.lib.importers.opspro.SongImport') def test_trans_tag(self, mocked_songimport): @@ -166,7 +163,6 @@ class TestOpsProSongImport(TestCase): importer.process_song(song, lyrics, []) # THEN: The imported data should look like expected - result_file = open(os.path.join(TEST_PATH, 'Amazing Grace3.json'), 'rb') - result_data = json.loads(result_file.read().decode()) - self.assertListEqual(importer.verses, _get_item(result_data, 'verses')) - self.assertListEqual(importer.verse_order_list_generated, _get_item(result_data, 'verse_order_list')) + result_data = load_external_result_data(TEST_PATH / 'Amazing Grace3.json') + assert importer.verses == _get_item(result_data, 'verses') + assert importer.verse_order_list_generated == _get_item(result_data, 'verse_order_list') diff --git a/tests/functional/openlp_plugins/songs/test_powerpraiseimport.py b/tests/functional/openlp_plugins/songs/test_powerpraiseimport.py index 4df5806ae..ae823fb03 100644 --- a/tests/functional/openlp_plugins/songs/test_powerpraiseimport.py +++ b/tests/functional/openlp_plugins/songs/test_powerpraiseimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,14 +23,10 @@ The :mod:`powerpraiseimport` module provides the functionality for importing ProPresenter song files into the current installation database. """ -import os - -from openlp.core.common.path import Path - from tests.helpers.songfileimport import SongImportTestHelper +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'powerpraisesongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'powerpraise' class TestPowerPraiseFileImport(SongImportTestHelper): @@ -44,7 +40,7 @@ class TestPowerPraiseFileImport(SongImportTestHelper): """ Test that loading a PowerPraise file works correctly """ - self.file_import([Path(TEST_PATH, 'Naher, mein Gott zu Dir.ppl')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Naher, mein Gott zu Dir.json'))) - self.file_import([Path(TEST_PATH, 'You are so faithful.ppl')], - self.load_external_result_data(os.path.join(TEST_PATH, 'You are so faithful.json'))) + self.file_import([TEST_PATH / 'Naher, mein Gott zu Dir.ppl'], + self.load_external_result_data(TEST_PATH / 'Naher, mein Gott zu Dir.json')) + self.file_import([TEST_PATH / 'You are so faithful.ppl'], + self.load_external_result_data(TEST_PATH / 'You are so faithful.json')) diff --git a/tests/functional/openlp_plugins/songs/test_presentationmanagerimport.py b/tests/functional/openlp_plugins/songs/test_presentationmanagerimport.py index 5391c31af..88524a38d 100644 --- a/tests/functional/openlp_plugins/songs/test_presentationmanagerimport.py +++ b/tests/functional/openlp_plugins/songs/test_presentationmanagerimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,14 +22,10 @@ """ This module contains tests for the PresentationManager song importer. """ -import os - -from openlp.core.common.path import Path - from tests.helpers.songfileimport import SongImportTestHelper +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'presentationmanagersongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'presentationmanager' class TestPresentationManagerFileImport(SongImportTestHelper): @@ -43,7 +39,7 @@ class TestPresentationManagerFileImport(SongImportTestHelper): """ Test that loading a PresentationManager file works correctly """ - self.file_import([Path(TEST_PATH, 'Great Is Thy Faithfulness.sng')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Great Is Thy Faithfulness.json'))) - self.file_import([Path(TEST_PATH, 'Amazing Grace.sng')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace.json'))) + self.file_import([TEST_PATH / 'Great Is Thy Faithfulness.sng'], + self.load_external_result_data(TEST_PATH / 'Great Is Thy Faithfulness.json')) + self.file_import([TEST_PATH / 'Amazing Grace.sng'], + self.load_external_result_data(TEST_PATH / 'Amazing Grace.json')) diff --git a/tests/functional/openlp_plugins/songs/test_propresenterimport.py b/tests/functional/openlp_plugins/songs/test_propresenterimport.py index e93dd6d9f..fccae340d 100644 --- a/tests/functional/openlp_plugins/songs/test_propresenterimport.py +++ b/tests/functional/openlp_plugins/songs/test_propresenterimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,14 +23,10 @@ The :mod:`propresenterimport` module provides the functionality for importing ProPresenter song files into the current installation database. """ -import os - -from openlp.core.common.path import Path - from tests.helpers.songfileimport import SongImportTestHelper +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'propresentersongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'propresenter' class TestProPresenterFileImport(SongImportTestHelper): @@ -44,19 +40,19 @@ class TestProPresenterFileImport(SongImportTestHelper): """ Test that loading a ProPresenter 4 file works correctly """ - self.file_import([Path(TEST_PATH, 'Amazing Grace.pro4')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace.json'))) + self.file_import([TEST_PATH / 'Amazing Grace.pro4'], + self.load_external_result_data(TEST_PATH / 'Amazing Grace.json')) def test_pro5_song_import(self): """ Test that loading a ProPresenter 5 file works correctly """ - self.file_import([Path(TEST_PATH, 'Amazing Grace.pro5')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace.json'))) + self.file_import([TEST_PATH / 'Amazing Grace.pro5'], + self.load_external_result_data(TEST_PATH / 'Amazing Grace.json')) def test_pro6_song_import(self): """ Test that loading a ProPresenter 6 file works correctly """ - self.file_import([Path(TEST_PATH, 'Amazing Grace.pro6')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace.json'))) + self.file_import([TEST_PATH / 'Amazing Grace.pro6'], + self.load_external_result_data(TEST_PATH / 'Amazing Grace.json')) diff --git a/tests/functional/openlp_plugins/songs/test_songbeamerimport.py b/tests/functional/openlp_plugins/songs/test_songbeamerimport.py index 165abd1a9..4118ac837 100644 --- a/tests/functional/openlp_plugins/songs/test_songbeamerimport.py +++ b/tests/functional/openlp_plugins/songs/test_songbeamerimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,18 +22,15 @@ """ This module contains tests for the Songbeamer song importer. """ -import os from unittest import TestCase from unittest.mock import MagicMock, patch from openlp.core.common.registry import Registry -from openlp.core.common.path import Path from openlp.plugins.songs.lib.importers.songbeamer import SongBeamerImport, SongBeamerTypes - from tests.helpers.songfileimport import SongImportTestHelper +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), - '..', '..', '..', 'resources', 'songbeamersongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'songbeamer' class TestSongBeamerFileImport(SongImportTestHelper): @@ -52,19 +49,19 @@ class TestSongBeamerFileImport(SongImportTestHelper): mocked_returned_settings = MagicMock() mocked_returned_settings.value.side_effect = lambda value: True if value == 'songs/enable chords' else False mocked_settings.return_value = mocked_returned_settings - self.file_import([Path(TEST_PATH, 'Amazing Grace.sng')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace.json'))) - self.file_import([Path(TEST_PATH, 'Lobsinget dem Herrn.sng')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Lobsinget dem Herrn.json'))) - self.file_import([Path(TEST_PATH, 'When I Call On You.sng')], - self.load_external_result_data(os.path.join(TEST_PATH, 'When I Call On You.json'))) + self.file_import([TEST_PATH / 'Amazing Grace.sng'], + self.load_external_result_data(TEST_PATH / 'Amazing Grace.json')) + self.file_import([TEST_PATH / 'Lobsinget dem Herrn.sng'], + self.load_external_result_data(TEST_PATH / 'Lobsinget dem Herrn.json')) + self.file_import([TEST_PATH / 'When I Call On You.sng'], + self.load_external_result_data(TEST_PATH / 'When I Call On You.json')) def test_cp1252_encoded_file(self): """ Test that a CP1252 encoded file get's decoded properly. """ - self.file_import([Path(TEST_PATH, 'cp1252song.sng')], - self.load_external_result_data(os.path.join(TEST_PATH, 'cp1252song.json'))) + self.file_import([TEST_PATH / 'cp1252song.sng'], + self.load_external_result_data(TEST_PATH / 'cp1252song.json')) class TestSongBeamerImport(TestCase): @@ -99,7 +96,7 @@ class TestSongBeamerImport(TestCase): importer = SongBeamerImport(mocked_manager, file_paths=[]) # THEN: The importer object should not be None - self.assertIsNotNone(importer, 'Import should not be none') + assert importer is not None, 'Import should not be none' def test_invalid_import_source(self): """ @@ -115,10 +112,10 @@ class TestSongBeamerImport(TestCase): self.importer.import_source = source # THEN: do_import should return none and the progress bar maximum should not be set. - self.assertIsNone(self.importer.do_import(), - 'do_import should return None when import_source is not a list') - self.assertEqual(mocked_import_wizard.progress_bar.setMaximum.called, False, - 'setMaxium on import_wizard.progress_bar should not have been called') + assert self.importer.do_import() is None, \ + 'do_import should return None when import_source is not a list' + assert mocked_import_wizard.progress_bar.setMaximum.called is False, \ + 'setMaxium on import_wizard.progress_bar should not have been called' def test_valid_import_source(self): """ @@ -134,8 +131,8 @@ class TestSongBeamerImport(TestCase): # THEN: do_import should return none and the progress bar setMaximum should be called with the length of # import_source. - self.assertIsNone(self.importer.do_import(), - 'do_import should return None when import_source is a list and stop_import_flag is True') + assert self.importer.do_import() is None, \ + 'do_import should return None when import_source is a list and stop_import_flag is True' mocked_import_wizard.progress_bar.setMaximum.assert_called_with(len(self.importer.import_source)) def test_check_verse_marks(self): @@ -149,8 +146,8 @@ class TestSongBeamerImport(TestCase): # WHEN: line is being checked for verse marks result = self.importer.check_verse_marks(line) # THEN: we should get back true and c as self.importer.current_verse_type - self.assertTrue(result, 'Versemark for should be found, value true') - self.assertEqual(self.importer.current_verse_type, 'c', ' should be interpreted as ') + assert result is True, 'Versemark for should be found, value true' + assert self.importer.current_verse_type == 'c', ' should be interpreted as ' # GIVEN: line with unnumbered verse-type and trailing space line = 'ReFrain ' @@ -158,8 +155,8 @@ class TestSongBeamerImport(TestCase): # WHEN: line is being checked for verse marks result = self.importer.check_verse_marks(line) # THEN: we should get back true and c as self.importer.current_verse_type - self.assertTrue(result, 'Versemark for should be found, value true') - self.assertEqual(self.importer.current_verse_type, 'c', ' should be interpreted as ') + assert result is True, 'Versemark for should be found, value true' + assert self.importer.current_verse_type == 'c', ' should be interpreted as ' # GIVEN: line with numbered verse-type line = 'VersE 1' @@ -167,8 +164,8 @@ class TestSongBeamerImport(TestCase): # WHEN: line is being checked for verse marks result = self.importer.check_verse_marks(line) # THEN: we should get back true and v1 as self.importer.current_verse_type - self.assertTrue(result, 'Versemark for should be found, value true') - self.assertEqual(self.importer.current_verse_type, 'v1', u' should be interpreted as ') + assert result is True, 'Versemark for should be found, value true' + assert self.importer.current_verse_type == 'v1', u' should be interpreted as ' # GIVEN: line with special unnumbered verse-mark (used in Songbeamer to allow usage of non-supported tags) line = '$$M=special' @@ -176,8 +173,8 @@ class TestSongBeamerImport(TestCase): # WHEN: line is being checked for verse marks result = self.importer.check_verse_marks(line) # THEN: we should get back true and o as self.importer.current_verse_type - self.assertTrue(result, 'Versemark for <$$M=special> should be found, value true') - self.assertEqual(self.importer.current_verse_type, 'o', u'<$$M=special> should be interpreted as ') + assert result is True, 'Versemark for <$$M=special> should be found, value true' + assert self.importer.current_verse_type == 'o', u'<$$M=special> should be interpreted as ' # GIVEN: line with song-text with 3 words line = 'Jesus my saviour' @@ -185,9 +182,8 @@ class TestSongBeamerImport(TestCase): # WHEN: line is being checked for verse marks result = self.importer.check_verse_marks(line) # THEN: we should get back false and none as self.importer.current_verse_type - self.assertFalse(result, 'No versemark for should be found, value false') - self.assertIsNone(self.importer.current_verse_type, - ' should be interpreted as none versemark') + assert result is False, 'No versemark for should be found, value false' + assert self.importer.current_verse_type is None, ' should be interpreted as none versemark' # GIVEN: line with song-text with 2 words line = 'Praise him' @@ -195,8 +191,8 @@ class TestSongBeamerImport(TestCase): # WHEN: line is being checked for verse marks result = self.importer.check_verse_marks(line) # THEN: we should get back false and none as self.importer.current_verse_type - self.assertFalse(result, 'No versemark for should be found, value false') - self.assertIsNone(self.importer.current_verse_type, ' should be interpreted as none versemark') + assert result is False, 'No versemark for should be found, value false' + assert self.importer.current_verse_type is None, ' should be interpreted as none versemark' # GIVEN: line with only a space (could occur, nothing regular) line = ' ' @@ -204,8 +200,8 @@ class TestSongBeamerImport(TestCase): # WHEN: line is being checked for verse marks result = self.importer.check_verse_marks(line) # THEN: we should get back false and none as self.importer.current_verse_type - self.assertFalse(result, 'No versemark for < > should be found, value false') - self.assertIsNone(self.importer.current_verse_type, '< > should be interpreted as none versemark') + assert result is False, 'No versemark for < > should be found, value false' + assert self.importer.current_verse_type is None, '< > should be interpreted as none versemark' # GIVEN: blank line (could occur, nothing regular) line = '' @@ -213,8 +209,8 @@ class TestSongBeamerImport(TestCase): # WHEN: line is being checked for verse marks result = self.importer.check_verse_marks(line) # THEN: we should get back false and none as self.importer.current_verse_type - self.assertFalse(result, 'No versemark for <> should be found, value false') - self.assertIsNone(self.importer.current_verse_type, '<> should be interpreted as none versemark') + assert result is False, 'No versemark for <> should be found, value false' + assert self.importer.current_verse_type is None, '<> should be interpreted as none versemark' def test_verse_marks_defined_in_lowercase(self): """ @@ -223,4 +219,4 @@ class TestSongBeamerImport(TestCase): # GIVEN: SongBeamber MarkTypes for tag in SongBeamerTypes.MarkTypes.keys(): # THEN: tag should be defined in lowercase - self.assertEquals(tag, tag.lower(), 'Tags should be defined in lowercase') + assert tag == tag.lower(), 'Tags should be defined in lowercase' diff --git a/tests/functional/openlp_plugins/songs/test_songformat.py b/tests/functional/openlp_plugins/songs/test_songformat.py index 4573613a4..c1e674a03 100644 --- a/tests/functional/openlp_plugins/songs/test_songformat.py +++ b/tests/functional/openlp_plugins/songs/test_songformat.py @@ -39,8 +39,8 @@ class TestSongFormat(TestCase): # GIVEN: The SongFormat class # WHEN: Retrieving the format list # THEN: All SongFormats should be returned - self.assertEquals(len(SongFormat.get_format_list()), len(SongFormat.__attributes__), - "The returned SongFormats don't match the stored ones") + assert len(SongFormat.get_format_list()) == len(SongFormat.__attributes__), \ + "The returned SongFormats don't match the stored ones" def test_get_attributed_no_attributes(self): """ @@ -50,8 +50,8 @@ class TestSongFormat(TestCase): # WHEN: Retrieving all attributes of a SongFormat for song_format in SongFormat.get_format_list(): # THEN: All attributes associated with the SongFormat should be returned - self.assertEquals(SongFormat.get(song_format), SongFormat.__attributes__[song_format], - "The returned attributes don't match the stored ones") + assert SongFormat.get(song_format) == SongFormat.__attributes__[song_format], \ + "The returned attributes don't match the stored ones" def test_get_attributed_single_attribute(self): """ @@ -62,14 +62,14 @@ class TestSongFormat(TestCase): # WHEN: Retrieving an attribute that overrides the default values for attribute in SongFormat.get(song_format).keys(): # THEN: Return the attribute - self.assertEquals(SongFormat.get(song_format, attribute), SongFormat.get(song_format)[attribute], - "The returned attribute doesn't match the stored one") + assert SongFormat.get(song_format, attribute) == SongFormat.get(song_format)[attribute], \ + "The returned attribute doesn't match the stored one" # WHEN: Retrieving an attribute that was not overridden for attribute in SongFormat.__defaults__.keys(): if attribute not in SongFormat.get(song_format).keys(): # THEN: Return the default value - self.assertEquals(SongFormat.get(song_format, attribute), SongFormat.__defaults__[attribute], - "The returned attribute does not match the default values stored") + assert SongFormat.get(song_format, attribute) == SongFormat.__defaults__[attribute], \ + "The returned attribute does not match the default values stored" def test_get_attributed_multiple_attributes(self): """ @@ -79,9 +79,8 @@ class TestSongFormat(TestCase): # WHEN: Retrieving multiple attributes at the same time for song_format in SongFormat.get_format_list(): # THEN: Return all attributes that were specified - self.assertEquals(len(SongFormat.get(song_format, 'canDisable', 'availability')), 2, - "Did not return the correct number of attributes" - " when retrieving multiple attributes at once") + assert len(SongFormat.get(song_format, 'canDisable', 'availability')) == 2, \ + "Did not return the correct number of attributes when retrieving multiple attributes at once" def test_get_format_list_returns_ordered_list(self): """ @@ -91,5 +90,5 @@ class TestSongFormat(TestCase): # GIVEN: The SongFormat class # WHEN: Retrieving all formats # THEN: The returned list should be sorted according to the ordering defined in SongFormat - self.assertEquals(sorted(SongFormat.get_format_list()), SongFormat.get_format_list(), - "The list returned should be sorted according to the ordering in SongFormat") + assert sorted(SongFormat.get_format_list()) == SongFormat.get_format_list(), \ + "The list returned should be sorted according to the ordering in SongFormat" diff --git a/tests/functional/openlp_plugins/songs/test_songproimport.py b/tests/functional/openlp_plugins/songs/test_songproimport.py index 4e874165b..4b3b7884c 100644 --- a/tests/functional/openlp_plugins/songs/test_songproimport.py +++ b/tests/functional/openlp_plugins/songs/test_songproimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,14 +23,10 @@ The :mod:`songproimport` module provides the functionality for importing SongPro song files into the current installation database. """ -import os - -from openlp.core.common.path import Path - from tests.helpers.songfileimport import SongImportTestHelper +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'songprosongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'songpro' class TestSongProFileImport(SongImportTestHelper): @@ -44,5 +40,5 @@ class TestSongProFileImport(SongImportTestHelper): """ Test that loading an SongPro file works correctly """ - self.file_import(Path(TEST_PATH, 'amazing-grace.txt'), - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace.json'))) + self.file_import(TEST_PATH / 'amazing-grace.txt', + self.load_external_result_data(TEST_PATH / 'Amazing Grace.json')) diff --git a/tests/functional/openlp_plugins/songs/test_songselect.py b/tests/functional/openlp_plugins/songs/test_songselect.py index ad711a84b..aa55fca20 100644 --- a/tests/functional/openlp_plugins/songs/test_songselect.py +++ b/tests/functional/openlp_plugins/songs/test_songselect.py @@ -5,7 +5,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,7 +23,6 @@ """ This module contains tests for the CCLI SongSelect importer. """ -import os from unittest import TestCase from unittest.mock import MagicMock, patch, call from urllib.error import URLError @@ -31,16 +30,14 @@ from urllib.error import URLError from PyQt5 import QtWidgets from openlp.core.common.registry import Registry -from openlp.core.common.path import Path from openlp.plugins.songs.forms.songselectform import SongSelectForm, SearchWorker from openlp.plugins.songs.lib import Song from openlp.plugins.songs.lib.songselect import SongSelectImport, LOGOUT_URL, BASE_URL - from tests.helpers.songfileimport import SongImportTestHelper from tests.helpers.testmixin import TestMixin +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'songselect')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'songselect' class TestSongSelectImport(TestCase, TestMixin): @@ -57,10 +54,10 @@ class TestSongSelectImport(TestCase, TestMixin): importer = SongSelectImport(None) # THEN: The object should have the correct properties - self.assertIsNone(importer.db_manager, 'The db_manager should be None') - self.assertIsNotNone(importer.html_parser, 'There should be a valid html_parser object') - self.assertIsNotNone(importer.opener, 'There should be a valid opener object') - self.assertEqual(1, mocked_build_opener.call_count, 'The build_opener method should have been called once') + assert importer.db_manager is None, 'The db_manager should be None' + assert importer.html_parser is not None, 'There should be a valid html_parser object' + assert importer.opener is not None, 'There should be a valid opener object' + assert 1 == mocked_build_opener.call_count, 'The build_opener method should have been called once' @patch('openlp.plugins.songs.lib.songselect.build_opener') @patch('openlp.plugins.songs.lib.songselect.BeautifulSoup') @@ -83,11 +80,11 @@ class TestSongSelectImport(TestCase, TestMixin): result = importer.login('username', 'password', mock_callback) # THEN: callback was called 3 times, open was called twice, find was called twice, and False was returned - self.assertEqual(3, mock_callback.call_count, 'callback should have been called 3 times') - self.assertEqual(2, mocked_login_page.find.call_count, 'find should have been called twice') - self.assertEqual(1, mocked_posted_page.find.call_count, 'find should have been called once') - self.assertEqual(2, mocked_opener.open.call_count, 'opener should have been called twice') - self.assertFalse(result, 'The login method should have returned False') + assert 3 == mock_callback.call_count, 'callback should have been called 3 times' + assert 2 == mocked_login_page.find.call_count, 'find should have been called twice' + assert 1 == mocked_posted_page.find.call_count, 'find should have been called once' + assert 2 == mocked_opener.open.call_count, 'opener should have been called twice' + assert result is False, 'The login method should have returned False' @patch('openlp.plugins.songs.lib.songselect.build_opener') def test_login_except(self, mocked_build_opener): @@ -103,8 +100,8 @@ class TestSongSelectImport(TestCase, TestMixin): result = importer.login('username', 'password', mock_callback) # THEN: callback was called 1 time and False was returned - self.assertEqual(1, mock_callback.call_count, 'callback should have been called 1 times') - self.assertFalse(result, 'The login method should have returned False') + assert 1 == mock_callback.call_count, 'callback should have been called 1 times' + assert result is False, 'The login method should have returned False' @patch('openlp.plugins.songs.lib.songselect.build_opener') @patch('openlp.plugins.songs.lib.songselect.BeautifulSoup') @@ -127,11 +124,11 @@ class TestSongSelectImport(TestCase, TestMixin): result = importer.login('username', 'password', mock_callback) # THEN: callback was called 3 times, open was called twice, find was called twice, and True was returned - self.assertEqual(3, mock_callback.call_count, 'callback should have been called 3 times') - self.assertEqual(2, mocked_login_page.find.call_count, 'find should have been called twice on the login page') - self.assertEqual(1, mocked_posted_page.find.call_count, 'find should have been called once on the posted page') - self.assertEqual(2, mocked_opener.open.call_count, 'opener should have been called twice') - self.assertTrue(result, 'The login method should have returned True') + assert 3 == mock_callback.call_count, 'callback should have been called 3 times' + assert 2 == mocked_login_page.find.call_count, 'find should have been called twice on the login page' + assert 1 == mocked_posted_page.find.call_count, 'find should have been called once on the posted page' + assert 2 == mocked_opener.open.call_count, 'opener should have been called twice' + assert result is True, 'The login method should have returned True' @patch('openlp.plugins.songs.lib.songselect.build_opener') @patch('openlp.plugins.songs.lib.songselect.BeautifulSoup') @@ -156,11 +153,11 @@ class TestSongSelectImport(TestCase, TestMixin): result = importer.login('username', 'password', mock_callback) # THEN: callback was called 3 times, open was called twice, find was called twice, and True was returned - self.assertEqual(3, mock_callback.call_count, 'callback should have been called 3 times') - self.assertEqual(2, mocked_login_page.find.call_count, 'find should have been called twice on the login page') - self.assertEqual(1, mocked_posted_page.find.call_count, 'find should have been called once on the posted page') - self.assertEqual('https://profile.ccli.com/do/login', mocked_opener.open.call_args_list[1][0][0]) - self.assertTrue(result, 'The login method should have returned True') + assert 3 == mock_callback.call_count, 'callback should have been called 3 times' + assert 2 == mocked_login_page.find.call_count, 'find should have been called twice on the login page' + assert 1 == mocked_posted_page.find.call_count, 'find should have been called once on the posted page' + assert 'https://profile.ccli.com/do/login', mocked_opener.open.call_args_list[1][0][0] + assert result is True, 'The login method should have returned True' @patch('openlp.plugins.songs.lib.songselect.build_opener') def test_logout(self, mocked_build_opener): @@ -176,7 +173,7 @@ class TestSongSelectImport(TestCase, TestMixin): importer.logout() # THEN: The opener is called once with the logout url - self.assertEqual(1, mocked_opener.open.call_count, 'opener should have been called once') + assert 1 == mocked_opener.open.call_count, 'opener should have been called once' mocked_opener.open.assert_called_with(LOGOUT_URL) @patch('openlp.plugins.songs.lib.songselect.build_opener') @@ -198,11 +195,11 @@ class TestSongSelectImport(TestCase, TestMixin): results = importer.search('text', 1000, mock_callback) # THEN: callback was never called, open was called once, find_all was called once, an empty list returned - self.assertEqual(0, mock_callback.call_count, 'callback should not have been called') - self.assertEqual(1, mocked_opener.open.call_count, 'open should have been called once') - self.assertEqual(1, mocked_results_page.find_all.call_count, 'find_all should have been called once') + assert 0 == mock_callback.call_count, 'callback should not have been called' + assert 1 == mocked_opener.open.call_count, 'open should have been called once' + assert 1 == mocked_results_page.find_all.call_count, 'find_all should have been called once' mocked_results_page.find_all.assert_called_with('div', 'song-result') - self.assertEqual([], results, 'The search method should have returned an empty list') + assert [] == results, 'The search method should have returned an empty list' @patch('openlp.plugins.songs.lib.songselect.build_opener') @patch('openlp.plugins.songs.lib.songselect.BeautifulSoup') @@ -238,15 +235,15 @@ class TestSongSelectImport(TestCase, TestMixin): results = importer.search('text', 1000, mock_callback) # THEN: callback was never called, open was called once, find_all was called once, an empty list returned - self.assertEqual(2, mock_callback.call_count, 'callback should have been called twice') - self.assertEqual(2, mocked_opener.open.call_count, 'open should have been called twice') - self.assertEqual(2, mocked_results_page.find_all.call_count, 'find_all should have been called twice') + assert 2 == mock_callback.call_count, 'callback should have been called twice' + assert 2 == mocked_opener.open.call_count, 'open should have been called twice' + assert 2 == mocked_results_page.find_all.call_count, 'find_all should have been called twice' mocked_results_page.find_all.assert_called_with('div', 'song-result') expected_list = [ {'title': 'Title 1', 'authors': ['James', 'John'], 'link': BASE_URL + '/url1'}, {'title': 'Title 2', 'authors': ['Philip'], 'link': BASE_URL + '/url2'} ] - self.assertListEqual(expected_list, results, 'The search method should have returned two songs') + assert expected_list == results, 'The search method should have returned two songs' @patch('openlp.plugins.songs.lib.songselect.build_opener') @patch('openlp.plugins.songs.lib.songselect.BeautifulSoup') @@ -289,13 +286,13 @@ class TestSongSelectImport(TestCase, TestMixin): results = importer.search('text', 2, mock_callback) # THEN: callback was called twice, open was called twice, find_all was called twice, max results returned - self.assertEqual(2, mock_callback.call_count, 'callback should have been called twice') - self.assertEqual(2, mocked_opener.open.call_count, 'open should have been called twice') - self.assertEqual(2, mocked_results_page.find_all.call_count, 'find_all should have been called twice') + assert 2 == mock_callback.call_count, 'callback should have been called twice' + assert 2 == mocked_opener.open.call_count, 'open should have been called twice' + assert 2 == mocked_results_page.find_all.call_count, 'find_all should have been called twice' mocked_results_page.find_all.assert_called_with('div', 'song-result') expected_list = [{'title': 'Title 1', 'authors': ['James', 'John'], 'link': BASE_URL + '/url1'}, {'title': 'Title 2', 'authors': ['Philip'], 'link': BASE_URL + '/url2'}] - self.assertListEqual(expected_list, results, 'The search method should have returned two songs') + assert expected_list == results, 'The search method should have returned two songs' @patch('openlp.plugins.songs.lib.songselect.build_opener') @patch('openlp.plugins.songs.lib.songselect.BeautifulSoup') @@ -311,7 +308,7 @@ class TestSongSelectImport(TestCase, TestMixin): importer.stop() # THEN: Searching should have stopped - self.assertFalse(importer.run_search, 'Searching should have been stopped') + assert importer.run_search is False, 'Searching should have been stopped' @patch('openlp.plugins.songs.lib.songselect.build_opener') def test_get_song_page_raises_exception(self, mocked_build_opener): @@ -330,7 +327,7 @@ class TestSongSelectImport(TestCase, TestMixin): # THEN: The callback should have been called once and None should be returned mocked_callback.assert_called_with() - self.assertIsNone(result, 'The get_song() method should have returned None') + assert result is None, 'The get_song() method should have returned None' @patch('openlp.plugins.songs.lib.songselect.build_opener') @patch('openlp.plugins.songs.lib.songselect.BeautifulSoup') @@ -347,8 +344,8 @@ class TestSongSelectImport(TestCase, TestMixin): result = importer.get_song({'link': 'link'}, callback=mocked_callback) # THEN: The callback should have been called twice and None should be returned - self.assertEqual(2, mocked_callback.call_count, 'The callback should have been called twice') - self.assertIsNone(result, 'The get_song() method should have returned None') + assert 2 == mocked_callback.call_count, 'The callback should have been called twice' + assert result is None, 'The get_song() method should have returned None' @patch('openlp.plugins.songs.lib.songselect.build_opener') @patch('openlp.plugins.songs.lib.songselect.BeautifulSoup') @@ -384,19 +381,18 @@ class TestSongSelectImport(TestCase, TestMixin): result = importer.get_song(fake_song, callback=mocked_callback) # THEN: The callback should have been called three times and the song should be returned - self.assertEqual(3, mocked_callback.call_count, 'The callback should have been called twice') - self.assertIsNotNone(result, 'The get_song() method should have returned a song dictionary') - self.assertEqual(2, mocked_lyrics_page.find.call_count, 'The find() method should have been called twice') - self.assertEqual(2, mocked_find_all.call_count, 'The find_all() method should have been called twice') - self.assertEqual([call('div', 'song-viewer lyrics'), call('div', 'song-viewer lyrics')], - mocked_lyrics_page.find.call_args_list, - 'The find() method should have been called with the right arguments') - self.assertEqual([call('p'), call('h3')], mocked_find_all.call_args_list, - 'The find_all() method should have been called with the right arguments') - self.assertIn('copyright', result, 'The returned song should have a copyright') - self.assertIn('ccli_number', result, 'The returned song should have a CCLI number') - self.assertIn('verses', result, 'The returned song should have verses') - self.assertEqual(3, len(result['verses']), 'Three verses should have been returned') + assert 3 == mocked_callback.call_count, 'The callback should have been called twice' + assert result is not None, 'The get_song() method should have returned a song dictionary' + assert 2 == mocked_lyrics_page.find.call_count, 'The find() method should have been called twice' + assert 2 == mocked_find_all.call_count, 'The find_all() method should have been called twice' + assert [call('div', 'song-viewer lyrics'), call('div', 'song-viewer lyrics')] == \ + mocked_lyrics_page.find.call_args_list, 'The find() method should have been called with the right arguments' + assert [call('p'), call('h3')] == mocked_find_all.call_args_list, \ + 'The find_all() method should have been called with the right arguments' + assert 'copyright' in result, 'The returned song should have a copyright' + assert 'ccli_number' in result, 'The returned song should have a CCLI number' + assert 'verses' in result, 'The returned song should have verses' + assert 3 == len(result['verses']), 'Three verses should have been returned' @patch('openlp.plugins.songs.lib.songselect.clean_song') @patch('openlp.plugins.songs.lib.songselect.Topic') @@ -427,14 +423,13 @@ class TestSongSelectImport(TestCase, TestMixin): result = importer.save_song(song_dict) # THEN: The return value should be a Song class and the mocked_db_manager should have been called - self.assertIsInstance(result, Song, 'The returned value should be a Song object') + assert isinstance(result, Song), 'The returned value should be a Song object' mocked_clean_song.assert_called_with(mocked_db_manager, result) - self.assertEqual(2, mocked_db_manager.save_object.call_count, - 'The save_object() method should have been called twice') + assert 2 == mocked_db_manager.save_object.call_count, \ + 'The save_object() method should have been called twice' mocked_db_manager.get_object_filtered.assert_called_with(MockedAuthor, False) - MockedAuthor.populate.assert_called_with(first_name='Public', last_name='Domain', - display_name='Public Domain') - self.assertEqual(1, len(result.authors_songs), 'There should only be one author') + MockedAuthor.populate.assert_called_with(first_name='Public', last_name='Domain', display_name='Public Domain') + assert 1 == len(result.authors_songs), 'There should only be one author' @patch('openlp.plugins.songs.lib.songselect.clean_song') @patch('openlp.plugins.songs.lib.songselect.Author') @@ -463,13 +458,13 @@ class TestSongSelectImport(TestCase, TestMixin): result = importer.save_song(song_dict) # THEN: The return value should be a Song class and the mocked_db_manager should have been called - self.assertIsInstance(result, Song, 'The returned value should be a Song object') + assert isinstance(result, Song), 'The returned value should be a Song object' mocked_clean_song.assert_called_with(mocked_db_manager, result) - self.assertEqual(2, mocked_db_manager.save_object.call_count, - 'The save_object() method should have been called twice') + assert 2 == mocked_db_manager.save_object.call_count, \ + 'The save_object() method should have been called twice' mocked_db_manager.get_object_filtered.assert_called_with(MockedAuthor, False) - self.assertEqual(0, MockedAuthor.populate.call_count, 'A new author should not have been instantiated') - self.assertEqual(1, len(result.authors_songs), 'There should only be one author') + assert 0 == MockedAuthor.populate.call_count, 'A new author should not have been instantiated' + assert 1 == len(result.authors_songs), 'There should only be one author' @patch('openlp.plugins.songs.lib.songselect.clean_song') @patch('openlp.plugins.songs.lib.songselect.Author') @@ -498,14 +493,13 @@ class TestSongSelectImport(TestCase, TestMixin): result = importer.save_song(song_dict) # THEN: The return value should be a Song class and the mocked_db_manager should have been called - self.assertIsInstance(result, Song, 'The returned value should be a Song object') + assert isinstance(result, Song), 'The returned value should be a Song object' mocked_clean_song.assert_called_with(mocked_db_manager, result) - self.assertEqual(2, mocked_db_manager.save_object.call_count, - 'The save_object() method should have been called twice') + assert 2 == mocked_db_manager.save_object.call_count, \ + 'The save_object() method should have been called twice' mocked_db_manager.get_object_filtered.assert_called_with(MockedAuthor, False) - MockedAuthor.populate.assert_called_with(first_name='Unknown', last_name='', - display_name='Unknown') - self.assertEqual(1, len(result.authors_songs), 'There should only be one author') + MockedAuthor.populate.assert_called_with(first_name='Unknown', last_name='', display_name='Unknown') + assert 1 == len(result.authors_songs), 'There should only be one author' class TestSongSelectForm(TestCase, TestMixin): @@ -534,8 +528,8 @@ class TestSongSelectForm(TestCase, TestMixin): ssform = SongSelectForm(None, mocked_plugin, mocked_db_manager) # THEN: The correct properties should have been assigned - self.assertEqual(mocked_plugin, ssform.plugin, 'The correct plugin should have been assigned') - self.assertEqual(mocked_db_manager, ssform.db_manager, 'The correct db_manager should have been assigned') + assert mocked_plugin == ssform.plugin, 'The correct plugin should have been assigned' + assert mocked_db_manager == ssform.db_manager, 'The correct db_manager should have been assigned' @patch('openlp.plugins.songs.forms.songselectform.SongSelectImport') @patch('openlp.plugins.songs.forms.songselectform.QtWidgets.QMessageBox.critical') @@ -570,23 +564,21 @@ class TestSongSelectForm(TestCase, TestMixin): expected_login_spacer_calls = [call(False), call(True)] expected_login_progress_visible_calls = [call(True), call(False)] expected_login_progress_value_calls = [call(0), call(0)] - self.assertEqual(expected_username_calls, mocked_username_edit.setEnabled.call_args_list, - 'The username edit should be disabled then enabled') - self.assertEqual(expected_password_calls, mocked_password_edit.setEnabled.call_args_list, - 'The password edit should be disabled then enabled') - self.assertEqual(expected_save_password_calls, mocked_save_password_checkbox.setEnabled.call_args_list, - 'The save password checkbox should be disabled then enabled') - self.assertEqual(expected_login_btn_calls, mocked_login_button.setEnabled.call_args_list, - 'The login button should be disabled then enabled') - self.assertEqual(expected_login_spacer_calls, mocked_login_spacer.setVisible.call_args_list, - 'Thee login spacer should be make invisible, then visible') - self.assertEqual(expected_login_progress_visible_calls, - mocked_login_progress_bar.setVisible.call_args_list, - 'Thee login progress bar should be make visible, then invisible') - self.assertEqual(expected_login_progress_value_calls, mocked_login_progress_bar.setValue.call_args_list, - 'Thee login progress bar should have the right values set') - self.assertEqual(2, mocked_process_events.call_count, - 'The process_events() method should be called twice') + assert expected_username_calls == mocked_username_edit.setEnabled.call_args_list, \ + 'The username edit should be disabled then enabled' + assert expected_password_calls == mocked_password_edit.setEnabled.call_args_list, \ + 'The password edit should be disabled then enabled' + assert expected_save_password_calls == mocked_save_password_checkbox.setEnabled.call_args_list, \ + 'The save password checkbox should be disabled then enabled' + assert expected_login_btn_calls == mocked_login_button.setEnabled.call_args_list, \ + 'The login button should be disabled then enabled' + assert expected_login_spacer_calls == mocked_login_spacer.setVisible.call_args_list, \ + 'Thee login spacer should be make invisible, then visible' + assert expected_login_progress_visible_calls == mocked_login_progress_bar.setVisible.call_args_list, \ + 'Thee login progress bar should be make visible, then invisible' + assert expected_login_progress_value_calls == mocked_login_progress_bar.setValue.call_args_list, \ + 'Thee login progress bar should have the right values set' + assert 2 == mocked_process_events.call_count, 'The process_events() method should be called twice' mocked_critical.assert_called_with(ssform, 'Error Logging In', 'There was a problem logging in, ' 'perhaps your username or password is ' 'incorrect?') @@ -615,7 +607,7 @@ class TestSongSelectForm(TestCase, TestMixin): 'Your song has been imported, would you like to import more songs?', defaultButton=QtWidgets.QMessageBox.Yes) mocked_on_back_button_clicked.assert_called_with() - self.assertIsNone(ssform.song) + assert ssform.song is None @patch('openlp.plugins.songs.forms.songselectform.QtWidgets.QMessageBox.question') @patch('openlp.plugins.songs.forms.songselectform.translate') @@ -641,7 +633,7 @@ class TestSongSelectForm(TestCase, TestMixin): 'Your song has been imported, would you like to import more songs?', defaultButton=QtWidgets.QMessageBox.Yes) mocked_done.assert_called_with(QtWidgets.QDialog.Accepted) - self.assertIsNone(ssform.song) + assert ssform.song is None def test_on_back_button_clicked(self): """ @@ -769,8 +761,8 @@ class TestSongSelectForm(TestCase, TestMixin): # THEN: The view button, search box and search button should be enabled mocked_song_select_importer.stop.assert_called_with() - self.assertTrue(ssform.search_button.isEnabled()) - self.assertTrue(ssform.search_combobox.isEnabled()) + assert ssform.search_button.isEnabled() is True + assert ssform.search_combobox.isEnabled() is True @patch('openlp.plugins.songs.forms.songselectform.Settings') @patch('openlp.plugins.songs.forms.songselectform.run_thread') @@ -787,8 +779,8 @@ class TestSongSelectForm(TestCase, TestMixin): ssform.on_search_button_clicked() # THEN: The search box and search button should be disabled - self.assertFalse(ssform.search_button.isEnabled()) - self.assertFalse(ssform.search_combobox.isEnabled()) + assert ssform.search_button.isEnabled() is False + assert ssform.search_combobox.isEnabled() is False def test_on_search_finished(self): """ @@ -802,8 +794,8 @@ class TestSongSelectForm(TestCase, TestMixin): ssform.on_search_finished() # THEN: The search box and search button should be enabled - self.assertTrue(ssform.search_button.isEnabled()) - self.assertTrue(ssform.search_combobox.isEnabled()) + assert ssform.search_button.isEnabled() is True + assert ssform.search_combobox.isEnabled() is True class TestSongSelectFileImport(SongImportTestHelper): @@ -817,10 +809,8 @@ class TestSongSelectFileImport(SongImportTestHelper): """ Test that loading an OpenSong file works correctly on various files """ - self.file_import([Path(TEST_PATH, 'TestSong.bin')], - self.load_external_result_data(os.path.join(TEST_PATH, 'TestSong-bin.json'))) - self.file_import([Path(TEST_PATH, 'TestSong.txt')], - self.load_external_result_data(os.path.join(TEST_PATH, 'TestSong-txt.json'))) + self.file_import([TEST_PATH / 'TestSong.bin'], self.load_external_result_data(TEST_PATH / 'TestSong-bin.json')) + self.file_import([TEST_PATH / 'TestSong.txt'], self.load_external_result_data(TEST_PATH / 'TestSong-txt.json')) class TestSearchWorker(TestCase, TestMixin): @@ -839,8 +829,8 @@ class TestSearchWorker(TestCase, TestMixin): worker = SearchWorker(importer, search_text) # THEN: The correct values should be set - self.assertIs(importer, worker.importer, 'The importer should be the right object') - self.assertEqual(search_text, worker.search_text, 'The search text should be correct') + assert importer is worker.importer, 'The importer should be the right object' + assert search_text == worker.search_text, 'The search text should be correct' def test_start(self): """ diff --git a/tests/functional/openlp_plugins/songs/test_songshowplusimport.py b/tests/functional/openlp_plugins/songs/test_songshowplusimport.py index 79e8ba593..9f3df41a9 100644 --- a/tests/functional/openlp_plugins/songs/test_songshowplusimport.py +++ b/tests/functional/openlp_plugins/songs/test_songshowplusimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,18 +22,15 @@ """ This module contains tests for the SongShow Plus song importer. """ -import os from unittest import TestCase from unittest.mock import patch, MagicMock -from openlp.core.common.path import Path from openlp.plugins.songs.lib import VerseType from openlp.plugins.songs.lib.importers.songshowplus import SongShowPlusImport - from tests.helpers.songfileimport import SongImportTestHelper +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'songshowplussongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'songshowplus' class TestSongShowPlusFileImport(SongImportTestHelper): @@ -47,14 +44,14 @@ class TestSongShowPlusFileImport(SongImportTestHelper): """ Test that loading a SongShow Plus file works correctly on various files """ - self.file_import([Path(TEST_PATH, 'Amazing Grace.sbsong')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace.json'))) - self.file_import([Path(TEST_PATH, 'Beautiful Garden Of Prayer.sbsong')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Beautiful Garden Of Prayer.json'))) - self.file_import([Path(TEST_PATH, 'a mighty fortress is our god.sbsong')], - self.load_external_result_data(os.path.join(TEST_PATH, 'a mighty fortress is our god.json'))) - self.file_import([Path(TEST_PATH, 'cleanse-me.sbsong')], - self.load_external_result_data(os.path.join(TEST_PATH, 'cleanse-me.json'))) + self.file_import([TEST_PATH / 'Amazing Grace.sbsong'], + self.load_external_result_data(TEST_PATH / 'Amazing Grace.json')) + self.file_import([TEST_PATH / 'Beautiful Garden Of Prayer.sbsong'], + self.load_external_result_data(TEST_PATH / 'Beautiful Garden Of Prayer.json')) + self.file_import([TEST_PATH / 'a mighty fortress is our god.sbsong'], + self.load_external_result_data(TEST_PATH / 'a mighty fortress is our god.json')) + self.file_import([TEST_PATH / 'cleanse-me.sbsong'], + self.load_external_result_data(TEST_PATH / 'cleanse-me.json')) class TestSongShowPlusImport(TestCase): @@ -73,7 +70,7 @@ class TestSongShowPlusImport(TestCase): importer = SongShowPlusImport(mocked_manager, file_paths=[]) # THEN: The importer object should not be None - self.assertIsNotNone(importer, 'Import should not be none') + assert importer is not None, 'Import should not be none' def test_invalid_import_source(self): """ @@ -92,9 +89,9 @@ class TestSongShowPlusImport(TestCase): importer.import_source = source # THEN: do_import should return none and the progress bar maximum should not be set. - self.assertIsNone(importer.do_import(), 'do_import should return None when import_source is not a list') - self.assertEqual(mocked_import_wizard.progress_bar.setMaximum.called, False, - 'setMaximum on import_wizard.progress_bar should not have been called') + assert importer.do_import() is None, 'do_import should return None when import_source is not a list' + assert mocked_import_wizard.progress_bar.setMaximum.called is False, \ + 'setMaximum on import_wizard.progress_bar should not have been called' def test_valid_import_source(self): """ @@ -113,8 +110,8 @@ class TestSongShowPlusImport(TestCase): # THEN: do_import should return none and the progress bar setMaximum should be called with the length of # import_source. - self.assertIsNone(importer.do_import(), 'do_import should return None when import_source is a list ' - 'and stop_import_flag is True') + assert importer.do_import() is None, \ + 'do_import should return None when import_source is a list and stop_import_flag is True' mocked_import_wizard.progress_bar.setMaximum.assert_called_with(len(importer.import_source)) def test_to_openlp_verse_tag(self): @@ -141,9 +138,9 @@ class TestSongShowPlusImport(TestCase): # THEN: The returned value should should correlate with the input arguments for original_tag, openlp_tag in test_values: - self.assertEqual(importer.to_openlp_verse_tag(original_tag), openlp_tag, - 'SongShowPlusImport.to_openlp_verse_tag should return "%s" when called with "%s"' % - (openlp_tag, original_tag)) + assert importer.to_openlp_verse_tag(original_tag) == openlp_tag, \ + 'SongShowPlusImport.to_openlp_verse_tag should return "%s" when called with "%s"' % \ + (openlp_tag, original_tag) def test_to_openlp_verse_tag_verse_order(self): """ @@ -170,6 +167,6 @@ class TestSongShowPlusImport(TestCase): # THEN: The returned value should should correlate with the input arguments for original_tag, openlp_tag in test_values: - self.assertEqual(importer.to_openlp_verse_tag(original_tag, ignore_unique=True), openlp_tag, - 'SongShowPlusImport.to_openlp_verse_tag should return "%s" when called with "%s"' % - (openlp_tag, original_tag)) + assert importer.to_openlp_verse_tag(original_tag, ignore_unique=True) == openlp_tag, \ + 'SongShowPlusImport.to_openlp_verse_tag should return "%s" when called with "%s"' % \ + (openlp_tag, original_tag) diff --git a/tests/functional/openlp_plugins/songs/test_sundayplusimport.py b/tests/functional/openlp_plugins/songs/test_sundayplusimport.py index 5a5977943..05874de46 100644 --- a/tests/functional/openlp_plugins/songs/test_sundayplusimport.py +++ b/tests/functional/openlp_plugins/songs/test_sundayplusimport.py @@ -3,7 +3,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,15 +21,12 @@ """ This module contains tests for the SundayPlus song importer. """ -import os from unittest.mock import patch -from openlp.core.common.path import Path - from tests.helpers.songfileimport import SongImportTestHelper +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'sundayplussongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'sundayplus' class TestSundayPlusFileImport(SongImportTestHelper): @@ -46,5 +43,5 @@ class TestSundayPlusFileImport(SongImportTestHelper): with patch('openlp.plugins.songs.lib.importers.sundayplus.retrieve_windows_encoding') as \ mocked_retrieve_windows_encoding: mocked_retrieve_windows_encoding.return_value = 'cp1252' - self.file_import([Path(TEST_PATH, 'Amazing Grace.ptf')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace.json'))) + self.file_import([TEST_PATH / 'Amazing Grace.ptf'], + self.load_external_result_data(TEST_PATH / 'Amazing Grace.json')) diff --git a/tests/functional/openlp_plugins/songs/test_videopsalm.py b/tests/functional/openlp_plugins/songs/test_videopsalm.py index 69e4d9127..8c97ab8a0 100644 --- a/tests/functional/openlp_plugins/songs/test_videopsalm.py +++ b/tests/functional/openlp_plugins/songs/test_videopsalm.py @@ -3,7 +3,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -21,15 +21,12 @@ """ This module contains tests for the VideoPsalm song importer. """ -import os - -from openlp.core.common.path import Path - -from tests.helpers.songfileimport import SongImportTestHelper from unittest.mock import patch, MagicMock -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'videopsalmsongs')) +from tests.helpers.songfileimport import SongImportTestHelper +from tests.utils.constants import RESOURCE_PATH + +TEST_PATH = RESOURCE_PATH / 'songs' / 'videopsalm' class TestVideoPsalmFileImport(SongImportTestHelper): @@ -49,7 +46,7 @@ class TestVideoPsalmFileImport(SongImportTestHelper): mocked_returned_settings.value.side_effect = lambda value: True if value == 'songs/enable chords' else False mocked_settings.return_value = mocked_returned_settings # Do the test import - self.file_import(Path(TEST_PATH, 'videopsalm-as-safe-a-stronghold.json'), - self.load_external_result_data(os.path.join(TEST_PATH, 'as-safe-a-stronghold.json'))) - self.file_import(Path(TEST_PATH, 'videopsalm-as-safe-a-stronghold2.json'), - self.load_external_result_data(os.path.join(TEST_PATH, 'as-safe-a-stronghold2.json'))) + self.file_import(TEST_PATH / 'videopsalm-as-safe-a-stronghold.json', + self.load_external_result_data(TEST_PATH / 'as-safe-a-stronghold.json')) + self.file_import(TEST_PATH / 'videopsalm-as-safe-a-stronghold2.json', + self.load_external_result_data(TEST_PATH / 'as-safe-a-stronghold2.json')) diff --git a/tests/functional/openlp_plugins/songs/test_wordsofworshipimport.py b/tests/functional/openlp_plugins/songs/test_wordsofworshipimport.py index c0cb9b47d..445f1545f 100644 --- a/tests/functional/openlp_plugins/songs/test_wordsofworshipimport.py +++ b/tests/functional/openlp_plugins/songs/test_wordsofworshipimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,15 +22,10 @@ """ This module contains tests for the Words of Worship song importer. """ -import os - -from openlp.core.common.path import Path - from tests.helpers.songfileimport import SongImportTestHelper -from openlp.plugins.songs.lib.importers.wordsofworship import WordsOfWorshipImport +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'wordsofworshipsongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'wordsofworship' class TestWordsOfWorshipFileImport(SongImportTestHelper): @@ -44,10 +39,9 @@ class TestWordsOfWorshipFileImport(SongImportTestHelper): """ Test that loading a Words of Worship file works correctly """ - self.file_import([Path(TEST_PATH, 'Amazing Grace (6 Verses).wow-song')], - self.load_external_result_data(os.path.join(TEST_PATH, 'Amazing Grace (6 Verses).json'))) - self.file_import([Path(TEST_PATH, 'When morning gilds the skies.wsg')], - self.load_external_result_data(os.path.join(TEST_PATH, 'When morning gilds the skies.json'))) - self.file_import([Path(TEST_PATH, 'Holy Holy Holy Lord God Almighty.wow-song')], - self.load_external_result_data(os.path.join(TEST_PATH, - 'Holy Holy Holy Lord God Almighty.json'))) + self.file_import([TEST_PATH / 'Amazing Grace (6 Verses).wow-song'], + self.load_external_result_data(TEST_PATH / 'Amazing Grace (6 Verses).json')) + self.file_import([TEST_PATH / 'When morning gilds the skies.wsg'], + self.load_external_result_data(TEST_PATH / 'When morning gilds the skies.json')) + self.file_import([TEST_PATH / 'Holy Holy Holy Lord God Almighty.wow-song'], + self.load_external_result_data(TEST_PATH / 'Holy Holy Holy Lord God Almighty.json')) diff --git a/tests/functional/openlp_plugins/songs/test_worshipassistantimport.py b/tests/functional/openlp_plugins/songs/test_worshipassistantimport.py index be0179a98..c29970680 100644 --- a/tests/functional/openlp_plugins/songs/test_worshipassistantimport.py +++ b/tests/functional/openlp_plugins/songs/test_worshipassistantimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,14 +23,10 @@ The :mod:`worshipassistantimport` module provides the functionality for importing WorshipAssistant song files into the current installation database. """ -import os - -from openlp.core.common.path import Path - from tests.helpers.songfileimport import SongImportTestHelper +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'worshipassistantsongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'worshipassistant' class TestWorshipAssistantFileImport(SongImportTestHelper): @@ -44,9 +40,8 @@ class TestWorshipAssistantFileImport(SongImportTestHelper): """ Test that loading an Worship Assistant file works correctly """ - self.file_import(Path(TEST_PATH, 'du_herr.csv'), - self.load_external_result_data(os.path.join(TEST_PATH, 'du_herr.json'))) - self.file_import(Path(TEST_PATH, 'would_you_be_free.csv'), - self.load_external_result_data(os.path.join(TEST_PATH, 'would_you_be_free.json'))) - self.file_import(Path(TEST_PATH, 'would_you_be_free2.csv'), - self.load_external_result_data(os.path.join(TEST_PATH, 'would_you_be_free.json'))) + self.file_import(TEST_PATH / 'du_herr.csv', self.load_external_result_data(TEST_PATH / 'du_herr.json')) + self.file_import(TEST_PATH / 'would_you_be_free.csv', + self.load_external_result_data(TEST_PATH / 'would_you_be_free.json')) + self.file_import(TEST_PATH / 'would_you_be_free2.csv', + self.load_external_result_data(TEST_PATH / 'would_you_be_free.json')) diff --git a/tests/functional/openlp_plugins/songs/test_worshipcenterproimport.py b/tests/functional/openlp_plugins/songs/test_worshipcenterproimport.py index 56eba344b..7a78a144d 100644 --- a/tests/functional/openlp_plugins/songs/test_worshipcenterproimport.py +++ b/tests/functional/openlp_plugins/songs/test_worshipcenterproimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -156,7 +156,7 @@ class TestWorshipCenterProSongImport(TestCase): importer = WorshipCenterProImport(mocked_manager, file_paths=[]) # THEN: The importer object should not be None - self.assertIsNotNone(importer, 'Import should not be none') + assert importer is not None, 'Import should not be none' def test_pyodbc_exception(self): """ @@ -181,7 +181,7 @@ class TestWorshipCenterProSongImport(TestCase): return_value = importer.do_import() # THEN: do_import should return None, and pyodbc, translate & log_error are called with known calls - self.assertIsNone(return_value, 'do_import should return None when pyodbc raises an exception.') + assert return_value is None, 'do_import should return None when pyodbc raises an exception.' mocked_pyodbc_connect.assert_called_with('DRIVER={Microsoft Access Driver (*.mdb)};DBQ=import_source') mocked_translate.assert_called_with('SongsPlugin.WorshipCenterProImport', 'Unable to connect the WorshipCenter Pro database.') @@ -220,7 +220,7 @@ class TestWorshipCenterProSongImport(TestCase): # THEN: do_import should return None, and pyodbc, import_wizard, importer.title and add_verse are called # with known calls - self.assertIsNone(return_value, 'do_import should return None when pyodbc raises an exception.') + assert return_value is None, 'do_import should return None when pyodbc raises an exception.' mocked_pyodbc.connect.assert_called_with('DRIVER={Microsoft Access Driver (*.mdb)};DBQ=import_source') mocked_pyodbc.connect().cursor.assert_any_call() mocked_pyodbc.connect().cursor().execute.assert_called_with('SELECT ID, Field, Value FROM __SONGDATA') @@ -229,8 +229,7 @@ class TestWorshipCenterProSongImport(TestCase): add_verse_call_count = 0 for song_data in SONG_TEST_DATA: title_value = song_data['title'] - self.assertIn(title_value, importer._title_assignment_list, - 'title should have been set to %s' % title_value) + assert title_value in importer._title_assignment_list, 'title should have been set to %s' % title_value verse_calls = song_data['verses'] add_verse_call_count += len(verse_calls) for call in verse_calls: @@ -241,5 +240,4 @@ class TestWorshipCenterProSongImport(TestCase): mocked_add_comment.assert_any_call(song_data['comments']) if 'copyright' in song_data: mocked_add_copyright.assert_any_call(song_data['copyright']) - self.assertEqual(mocked_add_verse.call_count, add_verse_call_count, - 'Incorrect number of calls made to add_verse') + assert mocked_add_verse.call_count == add_verse_call_count, 'Incorrect number of calls made to add_verse' diff --git a/tests/functional/openlp_plugins/songs/test_zionworximport.py b/tests/functional/openlp_plugins/songs/test_zionworximport.py index 42991382e..0856e273e 100644 --- a/tests/functional/openlp_plugins/songs/test_zionworximport.py +++ b/tests/functional/openlp_plugins/songs/test_zionworximport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,19 +22,16 @@ """ This module contains tests for the ZionWorx song importer. """ -import os from unittest import TestCase from unittest.mock import MagicMock, patch from openlp.core.common.registry import Registry -from openlp.core.common.path import Path -from openlp.plugins.songs.lib.importers.zionworx import ZionWorxImport from openlp.plugins.songs.lib.importers.songimport import SongImport - +from openlp.plugins.songs.lib.importers.zionworx import ZionWorxImport from tests.helpers.songfileimport import SongImportTestHelper +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..', '..', '..', 'resources', 'zionworxsongs')) +TEST_PATH = RESOURCE_PATH / 'songs' / 'zionworx' class TestZionWorxImport(TestCase): @@ -59,7 +56,7 @@ class TestZionWorxImport(TestCase): importer = ZionWorxImport(mocked_manager, file_paths=[]) # THEN: The importer should be an instance of SongImport - self.assertIsInstance(importer, SongImport) + assert isinstance(importer, SongImport) class TestZionWorxFileImport(SongImportTestHelper): @@ -73,5 +70,4 @@ class TestZionWorxFileImport(SongImportTestHelper): """ Test that loading an ZionWorx file works correctly on various files """ - self.file_import(Path(TEST_PATH, 'zionworx.csv'), - self.load_external_result_data(os.path.join(TEST_PATH, 'zionworx.json'))) + self.file_import(TEST_PATH / 'zionworx.csv', self.load_external_result_data(TEST_PATH / 'zionworx.json')) diff --git a/tests/functional/openlp_plugins/songusage/__init__.py b/tests/functional/openlp_plugins/songusage/__init__.py index 624faead7..07a369a94 100644 --- a/tests/functional/openlp_plugins/songusage/__init__.py +++ b/tests/functional/openlp_plugins/songusage/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/functional/openlp_plugins/songusage/test_songusage.py b/tests/functional/openlp_plugins/songusage/test_songusage.py index 92f972271..f360efa94 100644 --- a/tests/functional/openlp_plugins/songusage/test_songusage.py +++ b/tests/functional/openlp_plugins/songusage/test_songusage.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -43,10 +43,10 @@ class TestSongUsage(TestCase): # GIVEN: The SongUsagePlugin # WHEN: Retrieving the about text # THEN: about() should return a string object - self.assertIsInstance(SongUsagePlugin.about(), str) + assert isinstance(SongUsagePlugin.about(), str) # THEN: about() should return a non-empty string - self.assertNotEquals(len(SongUsagePlugin.about()), 0) - self.assertNotEquals(len(SongUsagePlugin.about()), 0) + assert len(SongUsagePlugin.about()) is not 0 + assert len(SongUsagePlugin.about()) is not 0 @patch('openlp.plugins.songusage.songusageplugin.Manager') def test_song_usage_init(self, MockedManager): @@ -62,8 +62,8 @@ class TestSongUsage(TestCase): # THEN: It should be initialised correctly MockedManager.assert_called_with('songusage', init_schema, upgrade_mod=upgrade) - self.assertEqual(mocked_manager, song_usage.manager) - self.assertFalse(song_usage.song_usage_active) + assert mocked_manager == song_usage.manager + assert song_usage.song_usage_active is False @patch('openlp.plugins.songusage.songusageplugin.Manager') def test_check_pre_conditions(self, MockedManager): @@ -80,7 +80,7 @@ class TestSongUsage(TestCase): ret = song_usage.check_pre_conditions() # THEN: It should return True - self.assertTrue(ret) + assert ret is True @patch('openlp.plugins.songusage.songusageplugin.Manager') def test_toggle_song_usage_state(self, MockedManager): @@ -96,4 +96,4 @@ class TestSongUsage(TestCase): song_usage.toggle_song_usage_state() # THEN: song_usage_state should have been toogled - self.assertFalse(song_usage.song_usage_active) + assert song_usage.song_usage_active is False diff --git a/tests/helpers/__init__.py b/tests/helpers/__init__.py index 3cf5e4696..a37de888f 100644 --- a/tests/helpers/__init__.py +++ b/tests/helpers/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/helpers/songfileimport.py b/tests/helpers/songfileimport.py index 2128d28f9..ee41cbfec 100644 --- a/tests/helpers/songfileimport.py +++ b/tests/helpers/songfileimport.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,7 +29,6 @@ from unittest import TestCase from unittest.mock import MagicMock, patch, call from openlp.core.common.registry import Registry -from openlp.plugins.songs.lib.importers.opensong import OpenSongImport log = logging.getLogger(__name__) @@ -78,12 +77,13 @@ class SongImportTestHelper(TestCase): self.add_author_patcher.stop() self.song_import_patcher.stop() - def load_external_result_data(self, file_name): + def load_external_result_data(self, file_path): """ A method to load and return an object containing the song data from an external file. + + :param openlp.core.common.path.Path file_path: The path of the file to load """ - result_file = open(file_name, 'rb') - return json.loads(result_file.read().decode()) + return json.loads(file_path.read_bytes().decode()) def file_import(self, source_file_name, result_data): """ @@ -108,7 +108,7 @@ class SongImportTestHelper(TestCase): verse_order_list = self._get_data(result_data, 'verse_order_list') # THEN: do_import should return none, the song data should be as expected, and finish should have been called. - self.assertIsNone(importer.do_import(), 'do_import should return None when it has completed') + assert importer.do_import() is None, 'do_import should return None when it has completed' # Debug information - will be displayed when the test fails log.debug("Title imported: %s" % importer.title) @@ -122,7 +122,7 @@ class SongImportTestHelper(TestCase): log.debug("Song copyright imported: %s" % importer.song_number) log.debug("Topics imported: %s" % importer.topics) - self.assertEqual(importer.title, title, 'title for %s should be "%s"' % (source_file_name, title)) + assert importer.title == title, 'title for %s should be "%s"' % (source_file_name, title) for author in author_calls: if isinstance(author, str): self.mocked_add_author.assert_any_call(author) @@ -131,27 +131,27 @@ class SongImportTestHelper(TestCase): if song_copyright: self.mocked_add_copyright.assert_called_with(song_copyright) if ccli_number: - self.assertEqual(importer.ccli_number, ccli_number, - 'ccli_number for %s should be %s' % (source_file_name, ccli_number)) + assert importer.ccli_number == ccli_number, \ + 'ccli_number for %s should be %s' % (source_file_name, ccli_number) expected_calls = [] for verse_text, verse_tag in add_verse_calls: self.mocked_add_verse.assert_any_call(verse_text, verse_tag) expected_calls.append(call(verse_text, verse_tag)) self.mocked_add_verse.assert_has_calls(expected_calls, any_order=False) if topics: - self.assertEqual(importer.topics, topics, 'topics for %s should be %s' % (source_file_name, topics)) + assert importer.topics == topics, 'topics for %s should be %s' % (source_file_name, topics) if comments: - self.assertEqual(importer.comments, comments, - 'comments for %s should be "%s"' % (source_file_name, comments)) + assert importer.comments == comments, \ + 'comments for %s should be "%s"' % (source_file_name, comments) if song_book_name: - self.assertEqual(importer.song_book_name, song_book_name, - 'song_book_name for %s should be "%s"' % (source_file_name, song_book_name)) + assert importer.song_book_name == song_book_name, \ + 'song_book_name for %s should be "%s"' % (source_file_name, song_book_name) if song_number: - self.assertEqual(importer.song_number, song_number, - 'song_number for %s should be %s' % (source_file_name, song_number)) + assert importer.song_number == song_number, \ + 'song_number for %s should be %s' % (source_file_name, song_number) if verse_order_list: - self.assertEqual(importer.verse_order_list, verse_order_list, - 'verse_order_list for %s should be %s' % (source_file_name, verse_order_list)) + assert importer.verse_order_list == verse_order_list, \ + 'verse_order_list for %s should be %s' % (source_file_name, verse_order_list) self.mocked_finish.assert_called_with() def _get_data(self, data, key): diff --git a/tests/helpers/testmixin.py b/tests/helpers/testmixin.py index facd949f9..73c8f4130 100644 --- a/tests/helpers/testmixin.py +++ b/tests/helpers/testmixin.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -26,6 +26,7 @@ import os from tempfile import mkstemp from PyQt5 import QtCore, QtWidgets + from openlp.core.common.settings import Settings diff --git a/tests/interfaces/__init__.py b/tests/interfaces/__init__.py index 14e1634ea..615fa43e9 100644 --- a/tests/interfaces/__init__.py +++ b/tests/interfaces/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_core/__init__.py b/tests/interfaces/openlp_core/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_core/__init__.py +++ b/tests/interfaces/openlp_core/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_core/api/__init__.py b/tests/interfaces/openlp_core/api/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_core/api/__init__.py +++ b/tests/interfaces/openlp_core/api/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_core/common/__init__.py b/tests/interfaces/openlp_core/common/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_core/common/__init__.py +++ b/tests/interfaces/openlp_core/common/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_core/common/test_utils.py b/tests/interfaces/openlp_core/common/test_utils.py index 9669e3038..300eb2c0b 100644 --- a/tests/interfaces/openlp_core/common/test_utils.py +++ b/tests/interfaces/openlp_core/common/test_utils.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -26,7 +26,8 @@ from unittest import TestCase from openlp.core.common import is_not_image_file from openlp.core.common.path import Path -from tests.utils.constants import TEST_RESOURCES_PATH + +from tests.utils.constants import RESOURCE_PATH from tests.helpers.testmixin import TestMixin @@ -59,10 +60,10 @@ class TestUtils(TestCase, TestMixin): Test the method handles an image file """ # Given and empty string - file_name = Path(TEST_RESOURCES_PATH, 'church.jpg') + file_path = RESOURCE_PATH / 'church.jpg' # WHEN testing for it - result = is_not_image_file(file_name) + result = is_not_image_file(file_path) # THEN the result is false assert result is False, 'The file is present so the test should return False' @@ -72,10 +73,10 @@ class TestUtils(TestCase, TestMixin): Test the method handles a non image file """ # Given and empty string - file_name = Path(TEST_RESOURCES_PATH, 'serviceitem_custom_1.osj') + file_path = RESOURCE_PATH / 'serviceitem_custom_1.osj' # WHEN testing for it - result = is_not_image_file(file_name) + result = is_not_image_file(file_path) # THEN the result is false assert result is True, 'The file is not an image file so the test should return True' diff --git a/tests/interfaces/openlp_core/lib/__init__.py b/tests/interfaces/openlp_core/lib/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_core/lib/__init__.py +++ b/tests/interfaces/openlp_core/lib/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_core/lib/test_pluginmanager.py b/tests/interfaces/openlp_core/lib/test_pluginmanager.py index 588c15520..13478c21c 100644 --- a/tests/interfaces/openlp_core/lib/test_pluginmanager.py +++ b/tests/interfaces/openlp_core/lib/test_pluginmanager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,19 +22,18 @@ """ Package to test the openlp.core.lib.pluginmanager package. """ -import sys import gc +import sys from tempfile import mkdtemp from unittest import TestCase from unittest.mock import MagicMock, patch from PyQt5 import QtWidgets +from openlp.core.common.path import Path from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings -from openlp.core.common.path import Path from openlp.core.lib.pluginmanager import PluginManager - from tests.helpers.testmixin import TestMixin @@ -86,11 +85,11 @@ class TestPluginManager(TestCase, TestMixin): # THEN: We should find the "Songs", "Bibles", etc in the plugins list plugin_names = [plugin.name for plugin in plugin_manager.plugins] - self.assertIn('songs', plugin_names, 'There should be a "songs" plugin') - self.assertIn('bibles', plugin_names, 'There should be a "bibles" plugin') - self.assertIn('presentations', plugin_names, 'There should be a "presentations" plugin') - self.assertIn('images', plugin_names, 'There should be a "images" plugin') - self.assertIn('media', plugin_names, 'There should be a "media" plugin') - self.assertIn('custom', plugin_names, 'There should be a "custom" plugin') - self.assertIn('songusage', plugin_names, 'There should be a "songusage" plugin') - self.assertIn('alerts', plugin_names, 'There should be a "alerts" plugin') + assert 'songs' in plugin_names, 'There should be a "songs" plugin' + assert 'bibles' in plugin_names, 'There should be a "bibles" plugin' + assert 'presentations' in plugin_names, 'There should be a "presentations" plugin' + assert 'images' in plugin_names, 'There should be a "images" plugin' + assert 'media' in plugin_names, 'There should be a "media" plugin' + assert 'custom' in plugin_names, 'There should be a "custom" plugin' + assert 'songusage'in plugin_names, 'There should be a "songusage" plugin' + assert 'alerts' in plugin_names, 'There should be a "alerts" plugin' diff --git a/tests/interfaces/openlp_core/ui/__init__.py b/tests/interfaces/openlp_core/ui/__init__.py index 7efaa18af..27683018c 100644 --- a/tests/interfaces/openlp_core/ui/__init__.py +++ b/tests/interfaces/openlp_core/ui/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_core/ui/lib/__init__.py b/tests/interfaces/openlp_core/ui/lib/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_core/ui/lib/__init__.py +++ b/tests/interfaces/openlp_core/ui/lib/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_core/ui/media/__init__.py b/tests/interfaces/openlp_core/ui/media/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_core/ui/media/__init__.py +++ b/tests/interfaces/openlp_core/ui/media/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_core/ui/media/vendor/__init__.py b/tests/interfaces/openlp_core/ui/media/vendor/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_core/ui/media/vendor/__init__.py +++ b/tests/interfaces/openlp_core/ui/media/vendor/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_core/ui/media/vendor/test_mediainfoWrapper.py b/tests/interfaces/openlp_core/ui/media/vendor/test_mediainfoWrapper.py index 6ec2431b9..1d106e1d4 100644 --- a/tests/interfaces/openlp_core/ui/media/vendor/test_mediainfoWrapper.py +++ b/tests/interfaces/openlp_core/ui/media/vendor/test_mediainfoWrapper.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,13 +22,12 @@ """ Package to test the openlp.core.ui.media package. """ - -import os from unittest import TestCase from openlp.core.ui.media.vendor.mediainfoWrapper import MediaInfoWrapper +from tests.utils.constants import RESOURCE_PATH -TEST_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), '..', '..', '..', '..', '..', 'resources', 'media')) +TEST_PATH = RESOURCE_PATH / 'media' TEST_MEDIA = [['avi_file.avi', 61495], ['mp3_file.mp3', 134426], ['mpg_file.mpg', 9404], ['mp4_file.mp4', 188336]] @@ -40,11 +39,10 @@ class TestMediainfoWrapper(TestCase): """ for test_data in TEST_MEDIA: # GIVEN: a media file - full_path = os.path.normpath(os.path.join(TEST_PATH, test_data[0])) + full_path = str(TEST_PATH / test_data[0]) # WHEN the media data is retrieved results = MediaInfoWrapper.parse(full_path) # THEN you can determine the run time - self.assertEqual(results.tracks[0].duration, test_data[1], 'The correct duration is returned for ' + - test_data[0]) + assert results.tracks[0].duration == test_data[1], 'The correct duration is returned for ' + test_data[0] diff --git a/tests/interfaces/openlp_core/ui/test_filerenamedialog.py b/tests/interfaces/openlp_core/ui/test_filerenamedialog.py index cb074af1a..e268aef2f 100644 --- a/tests/interfaces/openlp_core/ui/test_filerenamedialog.py +++ b/tests/interfaces/openlp_core/ui/test_filerenamedialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,7 +29,6 @@ from PyQt5 import QtTest, QtWidgets from openlp.core.common.registry import Registry from openlp.core.ui import filerenameform - from tests.helpers.testmixin import TestMixin @@ -63,19 +62,19 @@ class TestStartFileRenameForm(TestCase, TestMixin): self.form.exec() # THEN: the window title is set correctly - self.assertEqual(self.form.windowTitle(), 'File Rename', 'The window title should be "File Rename"') + assert self.form.windowTitle() == 'File Rename', 'The window title should be "File Rename"' # WHEN: The form is executed with False arg self.form.exec(False) # THEN: the window title is set correctly - self.assertEqual(self.form.windowTitle(), 'File Rename', 'The window title should be "File Rename"') + assert self.form.windowTitle() == 'File Rename', 'The window title should be "File Rename"' # WHEN: The form is executed with True arg self.form.exec(True) # THEN: the window title is set correctly - self.assertEqual(self.form.windowTitle(), 'File Copy', 'The window title should be "File Copy"') + assert self.form.windowTitle() == 'File Copy', 'The window title should be "File Copy"' def test_line_edit_focus(self): """ @@ -104,4 +103,4 @@ class TestStartFileRenameForm(TestCase, TestMixin): # THEN: The text in the QLineEdit should be the same as the input string with the invalid characters filtered # out. - self.assertEqual(self.form.file_name_edit.text(), 'Invalid File Name') + assert self.form.file_name_edit.text() == 'Invalid File Name' diff --git a/tests/interfaces/openlp_core/ui/test_mainwindow.py b/tests/interfaces/openlp_core/ui/test_mainwindow.py index 4a8ced265..e48be9101 100644 --- a/tests/interfaces/openlp_core/ui/test_mainwindow.py +++ b/tests/interfaces/openlp_core/ui/test_mainwindow.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -27,7 +27,6 @@ from unittest.mock import MagicMock, patch from openlp.core.common.registry import Registry from openlp.core.ui.mainwindow import MainWindow - from tests.helpers.testmixin import TestMixin diff --git a/tests/interfaces/openlp_core/ui/test_projectoreditform.py b/tests/interfaces/openlp_core/ui/test_projectoreditform.py index ec2539a29..0cb33afe2 100644 --- a/tests/interfaces/openlp_core/ui/test_projectoreditform.py +++ b/tests/interfaces/openlp_core/ui/test_projectoreditform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -30,10 +30,8 @@ from unittest.mock import patch from openlp.core.common.registry import Registry from openlp.core.projectors.db import Projector, ProjectorDB from openlp.core.projectors.editform import ProjectorEditForm -from openlp.core.projectors.manager import ProjectorManager - from tests.helpers.testmixin import TestMixin -from tests.resources.projector.data import TEST_DB, TEST1_DATA, TEST2_DATA +from tests.resources.projector.data import TEST_DB, TEST1_DATA class TestProjectorEditForm(TestCase, TestMixin): diff --git a/tests/interfaces/openlp_core/ui/test_projectormanager.py b/tests/interfaces/openlp_core/ui/test_projectormanager.py index 484d4d68a..4fc6ec791 100644 --- a/tests/interfaces/openlp_core/ui/test_projectormanager.py +++ b/tests/interfaces/openlp_core/ui/test_projectormanager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -30,7 +30,6 @@ from openlp.core.common.registry import Registry from openlp.core.projectors.db import ProjectorDB from openlp.core.projectors.editform import ProjectorEditForm from openlp.core.projectors.manager import ProjectorManager - from tests.helpers.testmixin import TestMixin from tests.resources.projector.data import TEST_DB @@ -70,8 +69,8 @@ class TestProjectorManager(TestCase, TestMixin): # WHEN: we call bootstrap_initialise self.projector_manager.bootstrap_initialise() # THEN: ProjectorDB is setup - self.assertEqual(type(self.projector_manager.projectordb), ProjectorDB, - 'Initialization should have created a ProjectorDB() instance') + assert type(self.projector_manager.projectordb) == ProjectorDB, \ + 'Initialization should have created a ProjectorDB() instance' def test_bootstrap_post_set_up(self): """ @@ -85,10 +84,9 @@ class TestProjectorManager(TestCase, TestMixin): self.projector_manager.bootstrap_post_set_up() # THEN: verify calls to retrieve saved projectors and edit page initialized - self.assertEqual(1, self.projector_manager._load_projectors.call_count, - 'Initialization should have called load_projectors()') - self.assertEqual(type(self.projector_manager.projector_form), ProjectorEditForm, - 'Initialization should have created a Projector Edit Form') - self.assertIs(self.projector_manager.projectordb, - self.projector_manager.projector_form.projectordb, - 'ProjectorEditForm should be using same ProjectorDB() instance as ProjectorManager') + assert 1 == self.projector_manager._load_projectors.call_count, \ + 'Initialization should have called load_projectors()' + assert type(self.projector_manager.projector_form) == ProjectorEditForm, \ + 'Initialization should have created a Projector Edit Form' + assert self.projector_manager.projectordb is self.projector_manager.projector_form.projectordb, \ + 'ProjectorEditForm should be using same ProjectorDB() instance as ProjectorManager' diff --git a/tests/interfaces/openlp_core/ui/test_projectorsourceform.py b/tests/interfaces/openlp_core/ui/test_projectorsourceform.py index 815fe6ded..5ddf5641a 100644 --- a/tests/interfaces/openlp_core/ui/test_projectorsourceform.py +++ b/tests/interfaces/openlp_core/ui/test_projectorsourceform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -32,10 +32,9 @@ from unittest.mock import patch from PyQt5.QtWidgets import QDialog from openlp.core.common.registry import Registry -from openlp.core.projectors.db import ProjectorDB, Projector from openlp.core.projectors.constants import PJLINK_DEFAULT_CODES, PJLINK_DEFAULT_SOURCES +from openlp.core.projectors.db import ProjectorDB, Projector from openlp.core.projectors.sourceselectform import source_group, SourceSelectSingle - from tests.helpers.testmixin import TestMixin from tests.resources.projector.data import TEST_DB, TEST1_DATA @@ -111,8 +110,7 @@ class ProjectorSourceFormTest(TestCase, TestMixin): check = source_group(codes, PJLINK_DEFAULT_CODES) # THEN: return dictionary should match test dictionary - self.assertEquals(check, build_source_dict(), - "Source group dictionary should match test dictionary") + assert check == build_source_dict(), "Source group dictionary should match test dictionary" @patch.object(QDialog, 'exec') def test_source_select_edit_button(self, mocked_qdialog): @@ -130,9 +128,8 @@ class ProjectorSourceFormTest(TestCase, TestMixin): projector = select_form.projector # THEN: Verify all 4 buttons are available - self.assertEquals(len(select_form.button_box.buttons()), 4, - 'SourceSelect dialog box should have "OK", "Cancel" ' - '"Rest", and "Revert" buttons available') + assert len(select_form.button_box.buttons()) == 4, \ + 'SourceSelect dialog box should have "OK", "Cancel", "Rest", and "Revert" buttons available' @patch.object(QDialog, 'exec') def test_source_select_noedit_button(self, mocked_qdialog): @@ -150,6 +147,5 @@ class ProjectorSourceFormTest(TestCase, TestMixin): projector = select_form.projector # THEN: Verify only 2 buttons are available - self.assertEquals(len(select_form.button_box.buttons()), 2, - 'SourceSelect dialog box should only have "OK" ' - 'and "Cancel" buttons available') + assert len(select_form.button_box.buttons()) == 2, \ + 'SourceSelect dialog box should only have "OK" and "Cancel" buttons available' diff --git a/tests/interfaces/openlp_core/ui/test_servicemanager.py b/tests/interfaces/openlp_core/ui/test_servicemanager.py index 3426fffcb..04a960c72 100644 --- a/tests/interfaces/openlp_core/ui/test_servicemanager.py +++ b/tests/interfaces/openlp_core/ui/test_servicemanager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -30,7 +30,6 @@ from PyQt5 import QtCore, QtGui, QtWidgets from openlp.core.common.registry import Registry from openlp.core.lib import ServiceItem, ItemCapabilities from openlp.core.ui.servicemanager import ServiceManager - from tests.helpers.testmixin import TestMixin @@ -79,8 +78,8 @@ class TestServiceManager(TestCase, TestMixin): self.service_manager.setup_ui(self.service_manager) # THEN the count of items should be zero - self.assertEqual(self.service_manager.service_manager_list.topLevelItemCount(), 0, - 'The service manager list should be empty ') + assert self.service_manager.service_manager_list.topLevelItemCount() == 0, \ + 'The service manager list should be empty ' @patch('openlp.core.ui.servicemanager.QtWidgets.QTreeWidget.itemAt') @patch('openlp.core.ui.servicemanager.QtWidgets.QWidget.mapToGlobal') @@ -447,8 +446,8 @@ class TestServiceManager(TestCase, TestMixin): # THEN selection should be expanded selected_index = self.service_manager.service_manager_list.currentIndex() above_selected_index = self.service_manager.service_manager_list.indexAbove(selected_index) - self.assertTrue(self.service_manager.service_manager_list.isExpanded(above_selected_index), - 'Item should have been expanded') + assert self.service_manager.service_manager_list.isExpanded(above_selected_index) is True, \ + 'Item should have been expanded' self.service_manager.expanded.assert_called_once_with(song_item) def test_on_collapse_selection_with_parent_selected(self): @@ -468,10 +467,10 @@ class TestServiceManager(TestCase, TestMixin): # THEN selection should be expanded selected_index = self.service_manager.service_manager_list.currentIndex() - self.assertFalse(self.service_manager.service_manager_list.isExpanded(selected_index), - 'Item should have been collapsed') - self.assertTrue(self.service_manager.service_manager_list.currentItem() == song_item, - 'Top item should have been selected') + assert self.service_manager.service_manager_list.isExpanded(selected_index) is False, \ + 'Item should have been collapsed' + assert self.service_manager.service_manager_list.currentItem() == song_item, \ + 'Top item should have been selected' self.service_manager.collapsed.assert_called_once_with(song_item) def test_on_collapse_selection_with_child_selected(self): @@ -491,8 +490,8 @@ class TestServiceManager(TestCase, TestMixin): # THEN selection should be expanded selected_index = self.service_manager.service_manager_list.currentIndex() - self.assertFalse(self.service_manager.service_manager_list.isExpanded(selected_index), - 'Item should have been collapsed') - self.assertTrue(self.service_manager.service_manager_list.currentItem() == song_item, - 'Top item should have been selected') + assert self.service_manager.service_manager_list.isExpanded(selected_index) is False, \ + 'Item should have been collapsed' + assert self.service_manager.service_manager_list.currentItem() == song_item, \ + 'Top item should have been selected' self.service_manager.collapsed.assert_called_once_with(song_item) diff --git a/tests/interfaces/openlp_core/ui/test_servicenotedialog.py b/tests/interfaces/openlp_core/ui/test_servicenotedialog.py index 94e34be44..065b35198 100644 --- a/tests/interfaces/openlp_core/ui/test_servicenotedialog.py +++ b/tests/interfaces/openlp_core/ui/test_servicenotedialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,7 +29,6 @@ from PyQt5 import QtCore, QtTest, QtWidgets from openlp.core.common.registry import Registry from openlp.core.ui import servicenoteform - from tests.helpers.testmixin import TestMixin @@ -66,7 +65,7 @@ class TestStartNoteDialog(TestCase, TestMixin): QtTest.QTest.mouseClick(ok_widget, QtCore.Qt.LeftButton) # THEN the following input text is returned - self.assertEqual(self.form.text_edit.toPlainText(), '', 'The returned text should be empty') + assert self.form.text_edit.toPlainText() == '', 'The returned text should be empty' # WHEN displaying the UI, having set the text and pressing enter text = 'OpenLP is the best worship software' @@ -77,7 +76,7 @@ class TestStartNoteDialog(TestCase, TestMixin): QtTest.QTest.mouseClick(ok_widget, QtCore.Qt.LeftButton) # THEN the following text is returned - self.assertEqual(self.form.text_edit.toPlainText(), text, 'The text originally entered should still be there') + assert self.form.text_edit.toPlainText() == text, 'The text originally entered should still be there' # WHEN displaying the UI, having set the text and pressing enter self.form.text_edit.setPlainText('') @@ -88,4 +87,4 @@ class TestStartNoteDialog(TestCase, TestMixin): QtTest.QTest.mouseClick(ok_widget, QtCore.Qt.LeftButton) # THEN the following text is returned - self.assertEqual(self.form.text_edit.toPlainText(), text, 'The new text should be returned') + assert self.form.text_edit.toPlainText() == text, 'The new text should be returned' diff --git a/tests/interfaces/openlp_core/ui/test_settings_form.py b/tests/interfaces/openlp_core/ui/test_settings_form.py index f4ec5ccbc..39cb783f0 100644 --- a/tests/interfaces/openlp_core/ui/test_settings_form.py +++ b/tests/interfaces/openlp_core/ui/test_settings_form.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -28,9 +28,8 @@ from unittest.mock import MagicMock, patch from PyQt5 import QtCore, QtTest from openlp.core.common.registry import Registry -from openlp.core.ui import settingsform from openlp.core.display.screens import ScreenList - +from openlp.core.ui import settingsform from tests.helpers.testmixin import TestMixin SCREEN = { diff --git a/tests/interfaces/openlp_core/ui/test_shortcutlistform.py b/tests/interfaces/openlp_core/ui/test_shortcutlistform.py index a95390236..ff1a76555 100644 --- a/tests/interfaces/openlp_core/ui/test_shortcutlistform.py +++ b/tests/interfaces/openlp_core/ui/test_shortcutlistform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,7 +29,6 @@ from PyQt5 import QtCore, QtWidgets from openlp.core.common.registry import Registry from openlp.core.ui.shortcutlistform import ShortcutListForm - from tests.helpers.testmixin import TestMixin @@ -67,9 +66,9 @@ class TestShortcutform(TestCase, TestMixin): self.form._adjust_button(button, checked, enabled, text) # THEN: The button should be changed. - self.assertEqual(button.text(), text, 'The text should match.') + assert button.text() == text, 'The text should match.' mocked_check_method.assert_called_once_with(True) - self.assertEqual(button.isEnabled(), enabled, 'The button should be disabled.') + assert button.isEnabled() == enabled, 'The button should be disabled.' def test_space_key_press_event(self): """ @@ -85,7 +84,7 @@ class TestShortcutform(TestCase, TestMixin): # THEN: The key should be released mocked_key_release_event.assert_called_with(mocked_event) - self.assertEqual(0, mocked_event.accept.call_count) + assert 0 == mocked_event.accept.call_count def test_primary_push_button_checked_key_press_event(self): """ @@ -102,7 +101,7 @@ class TestShortcutform(TestCase, TestMixin): # THEN: The key should be released mocked_key_release_event.assert_called_with(mocked_event) - self.assertEqual(0, mocked_event.accept.call_count) + assert 0 == mocked_event.accept.call_count def test_alternate_push_button_checked_key_press_event(self): """ @@ -119,7 +118,7 @@ class TestShortcutform(TestCase, TestMixin): # THEN: The key should be released mocked_key_release_event.assert_called_with(mocked_event) - self.assertEqual(0, mocked_event.accept.call_count) + assert 0 == mocked_event.accept.call_count def test_escape_key_press_event(self): """ @@ -148,7 +147,7 @@ class TestShortcutform(TestCase, TestMixin): self.form.on_default_radio_button_clicked(False) # THEN: The method should exit early (i.e. the rest of the methods are not called) - self.assertEqual(0, mocked_current_item_action.call_count) + assert 0 == mocked_current_item_action.call_count def test_on_default_radio_button_clicked_no_action(self): """ @@ -164,7 +163,7 @@ class TestShortcutform(TestCase, TestMixin): # THEN: The method should exit early (i.e. the rest of the methods are not called) mocked_current_item_action.assert_called_with() - self.assertEqual(0, mocked_action_shortcuts.call_count) + assert 0 == mocked_action_shortcuts.call_count def test_on_default_radio_button_clicked(self): """ @@ -202,7 +201,7 @@ class TestShortcutform(TestCase, TestMixin): self.form.on_custom_radio_button_clicked(False) # THEN: The method should exit early (i.e. the rest of the methods are not called) - self.assertEqual(0, mocked_current_item_action.call_count) + assert 0 == mocked_current_item_action.call_count def test_on_custom_radio_button_clicked(self): """ diff --git a/tests/interfaces/openlp_core/ui/test_starttimedialog.py b/tests/interfaces/openlp_core/ui/test_starttimedialog.py index 5d0140e0d..f830bba28 100644 --- a/tests/interfaces/openlp_core/ui/test_starttimedialog.py +++ b/tests/interfaces/openlp_core/ui/test_starttimedialog.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,7 +29,6 @@ from PyQt5 import QtCore, QtTest, QtWidgets from openlp.core.common.registry import Registry from openlp.core.ui import starttimeform - from tests.helpers.testmixin import TestMixin @@ -56,28 +55,24 @@ class TestStartTimeDialog(TestCase, TestMixin): """ Test StartTimeDialog are defaults correct """ - self.assertEqual(self.form.hour_spin_box.minimum(), 0, 'The minimum hour should stay the same as the dialog') - self.assertEqual(self.form.hour_spin_box.maximum(), 4, 'The maximum hour should stay the same as the dialog') - self.assertEqual(self.form.minute_spin_box.minimum(), 0, - 'The minimum minute should stay the same as the dialog') - self.assertEqual(self.form.minute_spin_box.maximum(), 59, - 'The maximum minute should stay the same as the dialog') - self.assertEqual(self.form.second_spin_box.minimum(), 0, - 'The minimum second should stay the same as the dialog') - self.assertEqual(self.form.second_spin_box.maximum(), 59, - 'The maximum second should stay the same as the dialog') - self.assertEqual(self.form.hour_finish_spin_box.minimum(), 0, - 'The minimum finish hour should stay the same as the dialog') - self.assertEqual(self.form.hour_finish_spin_box.maximum(), 4, - 'The maximum finish hour should stay the same as the dialog') - self.assertEqual(self.form.minute_finish_spin_box.minimum(), 0, - 'The minimum finish minute should stay the same as the dialog') - self.assertEqual(self.form.minute_finish_spin_box.maximum(), 59, - 'The maximum finish minute should stay the same as the dialog') - self.assertEqual(self.form.second_finish_spin_box.minimum(), 0, - 'The minimum finish second should stay the same as the dialog') - self.assertEqual(self.form.second_finish_spin_box.maximum(), 59, - 'The maximum finish second should stay the same as the dialog') + assert self.form.hour_spin_box.minimum() == 0, 'The minimum hour should stay the same as the dialog' + assert self.form.hour_spin_box.maximum() == 4, 'The maximum hour should stay the same as the dialog' + assert self.form.minute_spin_box.minimum() == 0, 'The minimum minute should stay the same as the dialog' + assert self.form.minute_spin_box.maximum() == 59, 'The maximum minute should stay the same as the dialog' + assert self.form.second_spin_box.minimum() == 0, 'The minimum second should stay the same as the dialog' + assert self.form.second_spin_box.maximum() == 59, 'The maximum second should stay the same as the dialog' + assert self.form.hour_finish_spin_box.minimum() == 0, \ + 'The minimum finish hour should stay the same as the dialog' + assert self.form.hour_finish_spin_box.maximum() == 4, \ + 'The maximum finish hour should stay the same as the dialog' + assert self.form.minute_finish_spin_box.minimum() == 0, \ + 'The minimum finish minute should stay the same as the dialog' + assert self.form.minute_finish_spin_box.maximum() == 59, \ + 'The maximum finish minute should stay the same as the dialog' + assert self.form.second_finish_spin_box.minimum() == 0, \ + 'The minimum finish second should stay the same as the dialog' + assert self.form.second_finish_spin_box.maximum() == 59, \ + 'The maximum finish second should stay the same as the dialog' def test_time_display(self): """ @@ -97,10 +92,10 @@ class TestStartTimeDialog(TestCase, TestMixin): QtTest.QTest.mouseClick(ok_widget, QtCore.Qt.LeftButton) # THEN the following input values are returned - self.assertEqual(self.form.hour_spin_box.value(), 0) - self.assertEqual(self.form.minute_spin_box.value(), 1) - self.assertEqual(self.form.second_spin_box.value(), 1) - self.assertEqual(self.form.item['service_item'].start_time, 61, 'The start time should stay the same') + assert self.form.hour_spin_box.value() == 0 + assert self.form.minute_spin_box.value() == 1 + assert self.form.second_spin_box.value() == 1 + assert self.form.item['service_item'].start_time == 61, 'The start time should stay the same' # WHEN displaying the UI, changing the time to 2min 3secs and pressing enter self.form.item = {'service_item': mocked_serviceitem} @@ -112,7 +107,7 @@ class TestStartTimeDialog(TestCase, TestMixin): QtTest.QTest.mouseClick(ok_widget, QtCore.Qt.LeftButton) # THEN the following values are returned - self.assertEqual(self.form.hour_spin_box.value(), 0) - self.assertEqual(self.form.minute_spin_box.value(), 2) - self.assertEqual(self.form.second_spin_box.value(), 3) - self.assertEqual(self.form.item['service_item'].start_time, 123, 'The start time should have changed') + assert self.form.hour_spin_box.value() == 0 + assert self.form.minute_spin_box.value() == 2 + assert self.form.second_spin_box.value() == 3 + assert self.form.item['service_item'].start_time == 123, 'The start time should have changed' diff --git a/tests/interfaces/openlp_core/ui/test_thememanager.py b/tests/interfaces/openlp_core/ui/test_thememanager.py index 0808b12d0..e308ae00e 100644 --- a/tests/interfaces/openlp_core/ui/test_thememanager.py +++ b/tests/interfaces/openlp_core/ui/test_thememanager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -25,11 +25,10 @@ Interface tests to test the themeManager class and related methods. from unittest import TestCase from unittest.mock import patch, MagicMock +from openlp.core.common.path import Path from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings -from openlp.core.common.path import Path from openlp.core.ui import ThemeManager - from tests.helpers.testmixin import TestMixin @@ -121,4 +120,4 @@ class TestThemeManager(TestCase, TestMixin): self.theme_manager.bootstrap_post_set_up() # THEN: - self.assertEqual(1, self.theme_manager.load_themes.call_count, "load_themes should have been called once") + assert 1 == self.theme_manager.load_themes.call_count, "load_themes should have been called once" diff --git a/tests/interfaces/openlp_core/widgets/__init__.py b/tests/interfaces/openlp_core/widgets/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_core/widgets/__init__.py +++ b/tests/interfaces/openlp_core/widgets/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_core/widgets/test_edits.py b/tests/interfaces/openlp_core/widgets/test_edits.py index 3951e5f80..373b54d35 100644 --- a/tests/interfaces/openlp_core/widgets/test_edits.py +++ b/tests/interfaces/openlp_core/widgets/test_edits.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,7 +29,6 @@ from PyQt5 import QtCore, QtGui, QtTest, QtWidgets from openlp.core.common.registry import Registry from openlp.core.widgets.edits import SearchEdit, HistoryComboBox - from tests.helpers.testmixin import TestMixin @@ -86,8 +85,8 @@ class TestSearchEdit(TestCase, TestMixin): # THEN: The first search type should be the first one in the list. The selected type should be saved in the # settings - self.assertEqual(self.search_edit.current_search_type(), SearchTypes.First, - "The first search type should be selected.") + assert self.search_edit.current_search_type() == SearchTypes.First, \ + "The first search type should be selected." self.mocked_settings().setValue.assert_called_once_with('settings_section/last used search type', 0) def test_set_current_search_type(self): @@ -99,11 +98,11 @@ class TestSearchEdit(TestCase, TestMixin): result = self.search_edit.set_current_search_type(SearchTypes.Second) # THEN: - self.assertTrue(result, "The call should return success (True).") - self.assertEqual(self.search_edit.current_search_type(), SearchTypes.Second, - "The search type should be SearchTypes.Second") - self.assertEqual(self.search_edit.placeholderText(), SECOND_PLACEHOLDER_TEXT, - "The correct placeholder text should be 'Second Placeholder Text'.") + assert result is True, "The call should return success (True)." + assert self.search_edit.current_search_type() == SearchTypes.Second, \ + "The search type should be SearchTypes.Second" + assert self.search_edit.placeholderText() == SECOND_PLACEHOLDER_TEXT, \ + "The correct placeholder text should be 'Second Placeholder Text'." self.mocked_settings().setValue.assert_has_calls( [call('settings_section/last used search type', 0), call('settings_section/last used search type', 1)]) @@ -166,4 +165,4 @@ class TestHistoryComboBox(TestCase, TestMixin): self.combo.addItem('test2') # THEN: The list of items should contain both strings. - self.assertEqual(self.combo.getItems(), ['test1', 'test2']) + assert self.combo.getItems() == ['test1', 'test2'] diff --git a/tests/interfaces/openlp_core/widgets/test_views.py b/tests/interfaces/openlp_core/widgets/test_views.py index f4a493f4d..a4b0cb4fb 100644 --- a/tests/interfaces/openlp_core/widgets/test_views.py +++ b/tests/interfaces/openlp_core/widgets/test_views.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -30,9 +30,8 @@ from PyQt5 import QtGui, QtWidgets from openlp.core.common.registry import Registry from openlp.core.lib import ServiceItem from openlp.core.widgets.views import ListPreviewWidget - -from tests.utils.osdinteraction import read_service_from_file from tests.helpers.testmixin import TestMixin +from tests.utils.osdinteraction import read_service_from_file class TestListPreviewWidget(TestCase, TestMixin): @@ -64,7 +63,7 @@ class TestListPreviewWidget(TestCase, TestMixin): # GIVEN: A new ListPreviewWidget instance. # WHEN: No SlideItem has been added yet. # THEN: The count of items should be zero. - self.assertEqual(self.preview_widget.slide_count(), 0, 'The slide list should be empty.') + assert self.preview_widget.slide_count() == 0, 'The slide list should be empty.' def test_initial_slide_number(self): """ @@ -73,7 +72,7 @@ class TestListPreviewWidget(TestCase, TestMixin): # GIVEN: A new ListPreviewWidget instance. # WHEN: No SlideItem has been added yet. # THEN: The number of the current item should be -1. - self.assertEqual(self.preview_widget.current_slide_number(), -1, 'The slide number should be -1.') + assert self.preview_widget.current_slide_number() == -1, 'The slide number should be -1.' def test_replace_service_item(self): """ @@ -87,8 +86,8 @@ class TestListPreviewWidget(TestCase, TestMixin): # WHEN: Added to the preview widget. self.preview_widget.replace_service_item(service_item, 1, 1) # THEN: The slide count and number should fit. - self.assertEqual(self.preview_widget.slide_count(), 2, 'The slide count should be 2.') - self.assertEqual(self.preview_widget.current_slide_number(), 1, 'The current slide number should be 1.') + assert self.preview_widget.slide_count() == 2, 'The slide count should be 2.' + assert self.preview_widget.current_slide_number() == 1, 'The current slide number should be 1.' def test_change_slide(self): """ @@ -103,4 +102,4 @@ class TestListPreviewWidget(TestCase, TestMixin): self.preview_widget.replace_service_item(service_item, 1, 0) self.preview_widget.change_slide(1) # THEN: The current_slide_number should reflect the change. - self.assertEqual(self.preview_widget.current_slide_number(), 1, 'The current slide number should be 1.') + assert self.preview_widget.current_slide_number() == 1, 'The current slide number should be 1.' diff --git a/tests/interfaces/openlp_plugins/__init__.py b/tests/interfaces/openlp_plugins/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_plugins/__init__.py +++ b/tests/interfaces/openlp_plugins/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_plugins/bibles/__init__.py b/tests/interfaces/openlp_plugins/bibles/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_plugins/bibles/__init__.py +++ b/tests/interfaces/openlp_plugins/bibles/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_plugins/bibles/forms/__init__.py b/tests/interfaces/openlp_plugins/bibles/forms/__init__.py index e69de29bb..711ded4ae 100644 --- a/tests/interfaces/openlp_plugins/bibles/forms/__init__.py +++ b/tests/interfaces/openlp_plugins/bibles/forms/__init__.py @@ -0,0 +1,21 @@ +# -*- coding: utf-8 -*- +# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4 + +############################################################################### +# OpenLP - Open Source Lyrics Projection # +# --------------------------------------------------------------------------- # +# Copyright (c) 2008-2018 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 # +############################################################################### diff --git a/tests/interfaces/openlp_plugins/bibles/forms/test_bibleimportform.py b/tests/interfaces/openlp_plugins/bibles/forms/test_bibleimportform.py index cbbef1372..840039fbe 100644 --- a/tests/interfaces/openlp_plugins/bibles/forms/test_bibleimportform.py +++ b/tests/interfaces/openlp_plugins/bibles/forms/test_bibleimportform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -28,8 +28,7 @@ from unittest.mock import MagicMock, patch from PyQt5 import QtWidgets from openlp.core.common.registry import Registry -from openlp.plugins.bibles.forms.bibleimportform import BibleImportForm, PYSWORD_AVAILABLE - +from openlp.plugins.bibles.forms.bibleimportform import BibleImportForm from tests.helpers.testmixin import TestMixin @@ -78,7 +77,7 @@ class TestBibleImportForm(TestCase, TestMixin): self.form.on_web_update_button_clicked() # THEN: The webbible list should still be empty - self.assertEqual(self.form.web_bible_list, {}, 'The webbible list should be empty') + assert self.form.web_bible_list == {}, 'The webbible list should be empty' def test_custom_init(self): """ diff --git a/tests/interfaces/openlp_plugins/bibles/test_lib_http.py b/tests/interfaces/openlp_plugins/bibles/test_lib_http.py index 1ec6cb8ba..3160a2ad6 100644 --- a/tests/interfaces/openlp_plugins/bibles/test_lib_http.py +++ b/tests/interfaces/openlp_plugins/bibles/test_lib_http.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -53,8 +53,8 @@ class TestBibleHTTP(TestCase): books = handler.get_books_from_http('NIV') # THEN: We should get back a valid service item - self.assertEqual(len(books), 66, 'The bible should not have had any books added or removed') - self.assertEqual(books[0], 'Genesis', 'The first bible book should be Genesis') + assert len(books) == 66, 'The bible should not have had any books added or removed' + assert books[0] == 'Genesis', 'The first bible book should be Genesis' def test_bible_gateway_extract_books_support_redirect(self): """ @@ -67,7 +67,7 @@ class TestBibleHTTP(TestCase): books = handler.get_books_from_http('DN1933') # THEN: We should get back a valid service item - self.assertEqual(len(books), 66, 'This bible should have 66 books') + assert len(books) == 66, 'This bible should have 66 books' def test_bible_gateway_extract_verse(self): """ @@ -80,8 +80,7 @@ class TestBibleHTTP(TestCase): results = handler.get_bible_chapter('NIV', 'John', 3) # THEN: We should get back a valid service item - self.assertEqual(len(results.verse_list), 36, - 'The book of John should not have had any verses added or removed') + assert len(results.verse_list) == 36, 'The book of John should not have had any verses added or removed' def test_bible_gateway_extract_verse_nkjv(self): """ @@ -94,8 +93,7 @@ class TestBibleHTTP(TestCase): results = handler.get_bible_chapter('NKJV', 'John', 3) # THEN: We should get back a valid service item - self.assertEqual(len(results.verse_list), 36, - 'The book of John should not have had any verses added or removed') + assert len(results.verse_list) == 36, 'The book of John should not have had any verses added or removed' def test_crosswalk_extract_books(self): """ @@ -108,7 +106,7 @@ class TestBibleHTTP(TestCase): books = handler.get_books_from_http('niv') # THEN: We should get back a valid service item - self.assertEqual(len(books), 66, 'The bible should not have had any books added or removed') + assert len(books) == 66, 'The bible should not have had any books added or removed' def test_crosswalk_extract_verse(self): """ @@ -121,8 +119,7 @@ class TestBibleHTTP(TestCase): results = handler.get_bible_chapter('niv', 'john', 3) # THEN: We should get back a valid service item - self.assertEqual(len(results.verse_list), 36, - 'The book of John should not have had any verses added or removed') + assert len(results.verse_list) == 36, 'The book of John should not have had any verses added or removed' def test_bibleserver_get_bibles(self): """ @@ -135,9 +132,9 @@ class TestBibleHTTP(TestCase): bibles = handler.get_bibles_from_http() # THEN: The list should not be None, and some known bibles should be there - self.assertIsNotNone(bibles) - self.assertIn(('New Int. Readers Version', 'NIRV', 'en'), bibles) - self.assertIn(('Священное Писание, Восточный перевод', 'CARS', 'ru'), bibles) + assert bibles is not None + assert ('New Int. Readers Version', 'NIRV', 'en') in bibles + assert ('Священное Писание, Восточный перевод', 'CARS', 'ru') in bibles def test_biblegateway_get_bibles(self): """ @@ -150,8 +147,8 @@ class TestBibleHTTP(TestCase): bibles = handler.get_bibles_from_http() # THEN: The list should not be None, and some known bibles should be there - self.assertIsNotNone(bibles) - self.assertIn(('Holman Christian Standard Bible (HCSB)', 'HCSB', 'en'), bibles) + assert bibles is not None + assert ('Holman Christian Standard Bible (HCSB)', 'HCSB', 'en') in bibles def test_crosswalk_get_bibles(self): """ @@ -164,8 +161,8 @@ class TestBibleHTTP(TestCase): bibles = handler.get_bibles_from_http() # THEN: The list should not be None, and some known bibles should be there - self.assertIsNotNone(bibles) - self.assertIn(('Giovanni Diodati 1649 (Italian)', 'gdb', 'it'), bibles) + assert bibles is not None + assert ('Giovanni Diodati 1649 (Italian)', 'gdb', 'it') in bibles def test_crosswalk_get_verse_text(self): """ @@ -178,7 +175,6 @@ class TestBibleHTTP(TestCase): niv_genesis_chapter_one = handler.get_bible_chapter('niv', 'Genesis', 1) # THEN: The verse list should contain the verses - self.assertTrue(niv_genesis_chapter_one.has_verse_list()) - self.assertEquals('In the beginning God created the heavens and the earth.', - niv_genesis_chapter_one.verse_list[1], - 'The first chapter of genesis should have been fetched.') + assert niv_genesis_chapter_one.has_verse_list() is True + assert 'In the beginning God created the heavens and the earth.' == niv_genesis_chapter_one.verse_list[1], \ + 'The first chapter of genesis should have been fetched.' diff --git a/tests/interfaces/openlp_plugins/bibles/test_lib_manager.py b/tests/interfaces/openlp_plugins/bibles/test_lib_manager.py index 45e68a572..4252a2064 100644 --- a/tests/interfaces/openlp_plugins/bibles/test_lib_manager.py +++ b/tests/interfaces/openlp_plugins/bibles/test_lib_manager.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -28,9 +28,8 @@ from unittest.mock import MagicMock, patch from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings from openlp.plugins.bibles.lib import BibleManager, LanguageSelection - -from tests.utils.constants import TEST_RESOURCES_PATH from tests.helpers.testmixin import TestMixin +from tests.utils.constants import TEST_RESOURCES_PATH class TestBibleManager(TestCase, TestMixin): @@ -79,7 +78,7 @@ class TestBibleManager(TestCase, TestMixin): # WHEN asking for the books of the bible books = self.manager.get_books('tests') # THEN a list of books should be returned - self.assertEqual(66, len(books), 'There should be 66 books in the bible') + assert 66 == len(books), 'There should be 66 books in the bible' def test_get_book_by_id(self): """ @@ -89,7 +88,7 @@ class TestBibleManager(TestCase, TestMixin): # WHEN asking for the book of the bible book = self.manager.get_book_by_id('tests', 54) # THEN a book should be returned - self.assertEqual('1 Timothy', book.name, '1 Timothy should have been returned from the bible') + assert '1 Timothy' == book.name, '1 Timothy should have been returned from the bible' def test_get_chapter_count(self): """ @@ -100,7 +99,7 @@ class TestBibleManager(TestCase, TestMixin): book = self.manager.get_book_by_id('tests', 54) chapter = self.manager.get_chapter_count('tests', book) # THEN the chapter count should be returned - self.assertEqual(6, chapter, '1 Timothy should have 6 chapters returned from the bible') + assert 6 == chapter, '1 Timothy should have 6 chapters returned from the bible' def test_get_verse_count_by_book_ref_id(self): """ @@ -110,4 +109,4 @@ class TestBibleManager(TestCase, TestMixin): # WHEN asking for the number of verses in a book of the bible verses = self.manager.get_verse_count_by_book_ref_id('tests', 54, 3) # THEN the chapter count should be returned - self.assertEqual(16, verses, '1 Timothy v3 should have 16 verses returned from the bible') + assert 16 == verses, '1 Timothy v3 should have 16 verses returned from the bible' diff --git a/tests/interfaces/openlp_plugins/bibles/test_lib_parse_reference.py b/tests/interfaces/openlp_plugins/bibles/test_lib_parse_reference.py index 18f5f5762..bf1057667 100644 --- a/tests/interfaces/openlp_plugins/bibles/test_lib_parse_reference.py +++ b/tests/interfaces/openlp_plugins/bibles/test_lib_parse_reference.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -28,9 +28,8 @@ from unittest.mock import MagicMock, patch from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings from openlp.plugins.bibles.lib import BibleManager, parse_reference, LanguageSelection - -from tests.utils.constants import TEST_RESOURCES_PATH from tests.helpers.testmixin import TestMixin +from tests.utils.constants import TEST_RESOURCES_PATH class TestBibleManager(TestCase, TestMixin): @@ -79,7 +78,7 @@ class TestBibleManager(TestCase, TestMixin): # WHEN asking to parse the bible reference results = parse_reference('1 Timothy 1', self.manager.db_cache['tests'], MagicMock(), 54) # THEN a verse array should be returned - self.assertEqual([(54, 1, 1, -1)], results, "The bible verses should matches the expected results") + assert [(54, 1, 1, -1)] == results, "The bible verses should matches the expected results" def test_parse_reference_two(self): """ @@ -89,7 +88,7 @@ class TestBibleManager(TestCase, TestMixin): # WHEN asking to parse the bible reference results = parse_reference('1 Timothy 1:1-2', self.manager.db_cache['tests'], MagicMock(), 54) # THEN a verse array should be returned - self.assertEqual([(54, 1, 1, 2)], results, "The bible verses should matches the expected results") + assert [(54, 1, 1, 2)] == results, "The bible verses should matches the expected results" def test_parse_reference_three(self): """ @@ -99,8 +98,8 @@ class TestBibleManager(TestCase, TestMixin): # WHEN asking to parse the bible reference results = parse_reference('1 Timothy 1:1-2:1', self.manager.db_cache['tests'], MagicMock(), 54) # THEN a verse array should be returned - self.assertEqual([(54, 1, 1, -1), (54, 2, 1, 1)], results, - "The bible verses should match the expected results") + assert [(54, 1, 1, -1), (54, 2, 1, 1)] == results, \ + "The bible verses should match the expected results" def test_parse_reference_four(self): """ @@ -110,7 +109,7 @@ class TestBibleManager(TestCase, TestMixin): # WHEN asking to parse the bible reference results = parse_reference('Raoul 1', self.manager.db_cache['tests'], MagicMock()) # THEN a verse array should be returned - self.assertEqual([], results, "The bible Search should return an empty list") + assert [] == results, "The bible Search should return an empty list" def test_parse_reference_five(self): """ @@ -120,4 +119,4 @@ class TestBibleManager(TestCase, TestMixin): # WHEN asking to parse the bible reference results = parse_reference('1 Timothy 1:3-end', self.manager.db_cache['tests'], MagicMock(), 54) # THEN a verse array should be returned - self.assertEqual([(54, 1, 3, -1)], results, "The bible verses should matches the expected results") + assert [(54, 1, 3, -1)] == results, "The bible verses should matches the expected results" diff --git a/tests/interfaces/openlp_plugins/custom/__init__.py b/tests/interfaces/openlp_plugins/custom/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_plugins/custom/__init__.py +++ b/tests/interfaces/openlp_plugins/custom/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_plugins/custom/forms/__init__.py b/tests/interfaces/openlp_plugins/custom/forms/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_plugins/custom/forms/__init__.py +++ b/tests/interfaces/openlp_plugins/custom/forms/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_plugins/custom/forms/test_customform.py b/tests/interfaces/openlp_plugins/custom/forms/test_customform.py index 5f486a219..96f265970 100644 --- a/tests/interfaces/openlp_plugins/custom/forms/test_customform.py +++ b/tests/interfaces/openlp_plugins/custom/forms/test_customform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -28,9 +28,7 @@ from unittest.mock import MagicMock, patch from PyQt5 import QtTest, QtCore, QtWidgets from openlp.core.common.registry import Registry -from openlp.plugins.custom.lib.mediaitem import CustomMediaItem from openlp.plugins.custom.forms.editcustomform import EditCustomForm - from tests.helpers.testmixin import TestMixin @@ -78,8 +76,8 @@ class TestEditCustomForm(TestCase, TestMixin): self.form.load_custom(0) # THEN: The line edits should not contain any text. - self.assertEqual(self.form.title_edit.text(), '', 'The title edit should be empty') - self.assertEqual(self.form.credit_edit.text(), '', 'The credit edit should be empty') + assert self.form.title_edit.text() == '', 'The title edit should be empty' + assert self.form.credit_edit.text() == '', 'The credit edit should be empty' def test_on_add_button_clicked(self): """ diff --git a/tests/interfaces/openlp_plugins/custom/forms/test_customslideform.py b/tests/interfaces/openlp_plugins/custom/forms/test_customslideform.py index 97d9bb652..f7d5abdd7 100644 --- a/tests/interfaces/openlp_plugins/custom/forms/test_customslideform.py +++ b/tests/interfaces/openlp_plugins/custom/forms/test_customslideform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -29,7 +29,6 @@ from PyQt5 import QtWidgets from openlp.core.common.registry import Registry from openlp.plugins.custom.forms.editcustomslideform import EditCustomSlideForm - from tests.helpers.testmixin import TestMixin diff --git a/tests/interfaces/openlp_plugins/media/__init__.py b/tests/interfaces/openlp_plugins/media/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_plugins/media/__init__.py +++ b/tests/interfaces/openlp_plugins/media/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_plugins/media/forms/__init__.py b/tests/interfaces/openlp_plugins/media/forms/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_plugins/media/forms/__init__.py +++ b/tests/interfaces/openlp_plugins/media/forms/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_plugins/media/forms/test_mediaclipselectorform.py b/tests/interfaces/openlp_plugins/media/forms/test_mediaclipselectorform.py index a49a35d48..69e98da5d 100644 --- a/tests/interfaces/openlp_plugins/media/forms/test_mediaclipselectorform.py +++ b/tests/interfaces/openlp_plugins/media/forms/test_mediaclipselectorform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_plugins/songs/__init__.py b/tests/interfaces/openlp_plugins/songs/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_plugins/songs/__init__.py +++ b/tests/interfaces/openlp_plugins/songs/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_plugins/songs/forms/__init__.py b/tests/interfaces/openlp_plugins/songs/forms/__init__.py index ea62548f4..711ded4ae 100644 --- a/tests/interfaces/openlp_plugins/songs/forms/__init__.py +++ b/tests/interfaces/openlp_plugins/songs/forms/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # diff --git a/tests/interfaces/openlp_plugins/songs/forms/test_authorsform.py b/tests/interfaces/openlp_plugins/songs/forms/test_authorsform.py index a2de38693..85523d541 100644 --- a/tests/interfaces/openlp_plugins/songs/forms/test_authorsform.py +++ b/tests/interfaces/openlp_plugins/songs/forms/test_authorsform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -58,9 +58,9 @@ class TestAuthorsForm(TestCase, TestMixin): """ Test the AuthorForm defaults are correct """ - self.assertEqual(self.form.first_name_edit.text(), '', 'The first name edit should be empty') - self.assertEqual(self.form.last_name_edit.text(), '', 'The last name edit should be empty') - self.assertEqual(self.form.display_edit.text(), '', 'The display name edit should be empty') + assert self.form.first_name_edit.text() == '', 'The first name edit should be empty' + assert self.form.last_name_edit.text() == '', 'The last name edit should be empty' + assert self.form.display_edit.text() == '', 'The display name edit should be empty' def test_get_first_name_property(self): """ @@ -73,7 +73,7 @@ class TestAuthorsForm(TestCase, TestMixin): self.form.first_name_edit.setText(first_name) # THEN: The first_name property should have the correct value - self.assertEqual(self.form.first_name, first_name, 'The first name property should be correct') + assert self.form.first_name == first_name, 'The first name property should be correct' def test_set_first_name_property(self): """ @@ -86,7 +86,7 @@ class TestAuthorsForm(TestCase, TestMixin): self.form.first_name = first_name # THEN: The first_name_edit should have the correct value - self.assertEqual(self.form.first_name_edit.text(), first_name, 'The first name should be set correctly') + assert self.form.first_name_edit.text() == first_name, 'The first name should be set correctly' def test_get_last_name_property(self): """ @@ -99,7 +99,7 @@ class TestAuthorsForm(TestCase, TestMixin): self.form.last_name_edit.setText(last_name) # THEN: The last_name property should have the correct value - self.assertEqual(self.form.last_name, last_name, 'The last name property should be correct') + assert self.form.last_name == last_name, 'The last name property should be correct' def test_set_last_name_property(self): """ @@ -112,7 +112,7 @@ class TestAuthorsForm(TestCase, TestMixin): self.form.last_name = last_name # THEN: The last_name_edit should have the correct value - self.assertEqual(self.form.last_name_edit.text(), last_name, 'The last name should be set correctly') + assert self.form.last_name_edit.text() == last_name, 'The last name should be set correctly' def test_get_display_name_property(self): """ @@ -125,7 +125,7 @@ class TestAuthorsForm(TestCase, TestMixin): self.form.display_edit.setText(display_name) # THEN: The display_name property should have the correct value - self.assertEqual(self.form.display_name, display_name, 'The display name property should be correct') + assert self.form.display_name == display_name, 'The display name property should be correct' def test_set_display_name_property(self): """ @@ -138,7 +138,7 @@ class TestAuthorsForm(TestCase, TestMixin): self.form.display_name = display_name # THEN: The display_name_edit should have the correct value - self.assertEqual(self.form.display_edit.text(), display_name, 'The display name should be set correctly') + assert self.form.display_edit.text() == display_name, 'The display name should be set correctly' @patch('openlp.plugins.songs.forms.authorsform.QtWidgets.QDialog.exec') def test_exec(self, mocked_exec): diff --git a/tests/interfaces/openlp_plugins/songs/forms/test_editsongform.py b/tests/interfaces/openlp_plugins/songs/forms/test_editsongform.py index 446368373..ab9384863 100644 --- a/tests/interfaces/openlp_plugins/songs/forms/test_editsongform.py +++ b/tests/interfaces/openlp_plugins/songs/forms/test_editsongform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -31,7 +31,6 @@ from openlp.core.common.i18n import UiStrings from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings from openlp.plugins.songs.forms.editsongform import EditSongForm - from tests.helpers.testmixin import TestMixin __default_settings__ = { @@ -69,10 +68,10 @@ class TestEditSongForm(TestCase, TestMixin): """ Test that the EditSongForm defaults are correct """ - self.assertFalse(self.form.verse_edit_button.isEnabled(), 'The verse edit button should not be enabled') - self.assertFalse(self.form.verse_delete_button.isEnabled(), 'The verse delete button should not be enabled') - self.assertFalse(self.form.author_remove_button.isEnabled(), 'The author remove button should not be enabled') - self.assertFalse(self.form.topic_remove_button.isEnabled(), 'The topic remove button should not be enabled') + assert self.form.verse_edit_button.isEnabled() is False, 'The verse edit button should not be enabled' + assert self.form.verse_delete_button.isEnabled() is False, 'The verse delete button should not be enabled' + assert self.form.author_remove_button.isEnabled() is False, 'The author remove button should not be enabled' + assert self.form.topic_remove_button.isEnabled() is False, 'The topic remove button should not be enabled' def test_is_verse_edit_form_executed(self): pass @@ -147,10 +146,10 @@ class TestEditSongForm(TestCase, TestMixin): # GIVEN; Mocked methods form = self.form # THEN: CCLI label should be CCLI song label - self.assertNotEquals(form.ccli_label.text(), UiStrings().CCLINumberLabel, - 'CCLI label should not be "{}"'.format(UiStrings().CCLINumberLabel)) - self.assertEquals(form.ccli_label.text(), UiStrings().CCLISongNumberLabel, - 'CCLI label text should be "{}"'.format(UiStrings().CCLISongNumberLabel)) + assert form.ccli_label.text() is not UiStrings().CCLINumberLabel, \ + 'CCLI label should not be "{}"'.format(UiStrings().CCLINumberLabel) + assert form.ccli_label.text() == UiStrings().CCLISongNumberLabel, \ + 'CCLI label text should be "{}"'.format(UiStrings().CCLISongNumberLabel) def test_verse_order_lowercase(self): """ @@ -165,4 +164,4 @@ class TestEditSongForm(TestCase, TestMixin): form.on_verse_order_text_changed(form.verse_order_edit.text()) # THEN: The verse order should be converted to uppercase - self.assertEqual(form.verse_order_edit.text(), 'V1 V2 C1 V3 C1 V4 C1') + assert form.verse_order_edit.text() == 'V1 V2 C1 V3 C1 V4 C1' diff --git a/tests/interfaces/openlp_plugins/songs/forms/test_editverseform.py b/tests/interfaces/openlp_plugins/songs/forms/test_editverseform.py index d12305089..500d52af3 100644 --- a/tests/interfaces/openlp_plugins/songs/forms/test_editverseform.py +++ b/tests/interfaces/openlp_plugins/songs/forms/test_editverseform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -68,7 +68,7 @@ class TestEditVerseForm(TestCase, TestMixin): # GIVEN: An EditVerseForm instance # WHEN: The form is shown # THEN: The default value is correct - self.assertEqual(self.form.verse_text_edit.toPlainText(), '', 'The verse edit box is empty.') + assert self.form.verse_text_edit.toPlainText() == '', 'The verse edit box is empty.' def test_type_verse_text(self): """ @@ -81,8 +81,8 @@ class TestEditVerseForm(TestCase, TestMixin): QtTest.QTest.keyClicks(self.form.verse_text_edit, text) # THEN: The verse text edit should have the verse text in it - self.assertEqual(text, self.form.verse_text_edit.toPlainText(), - 'The verse text edit should have the typed out verse') + assert text == self.form.verse_text_edit.toPlainText(), \ + 'The verse text edit should have the typed out verse' def test_insert_verse(self): """ @@ -93,8 +93,8 @@ class TestEditVerseForm(TestCase, TestMixin): QtTest.QTest.mouseClick(self.form.insert_button, QtCore.Qt.LeftButton) # THEN: The verse text edit should have a Verse:1 in it - self.assertIn('---[Verse:1]---', self.form.verse_text_edit.toPlainText(), - 'The verse text edit should have a verse marker') + assert '---[Verse:1]---' in self.form.verse_text_edit.toPlainText(), \ + 'The verse text edit should have a verse marker' def test_insert_verse_2(self): """ @@ -106,8 +106,8 @@ class TestEditVerseForm(TestCase, TestMixin): QtTest.QTest.mouseClick(self.form.insert_button, QtCore.Qt.LeftButton) # THEN: The verse text edit should have a Verse:1 in it - self.assertIn('---[Verse:2]---', self.form.verse_text_edit.toPlainText(), - 'The verse text edit should have a "Verse 2" marker') + assert '---[Verse:2]---' in self.form.verse_text_edit.toPlainText(), \ + 'The verse text edit should have a "Verse 2" marker' def test_insert_chorus(self): """ @@ -119,5 +119,5 @@ class TestEditVerseForm(TestCase, TestMixin): QtTest.QTest.mouseClick(self.form.insert_button, QtCore.Qt.LeftButton) # THEN: The verse text edit should have a Chorus:1 in it - self.assertIn('---[Chorus:1]---', self.form.verse_text_edit.toPlainText(), - 'The verse text edit should have a "Chorus 1" marker') + assert '---[Chorus:1]---' in self.form.verse_text_edit.toPlainText(), \ + 'The verse text edit should have a "Chorus 1" marker' diff --git a/tests/interfaces/openlp_plugins/songs/forms/test_songmaintenanceform.py b/tests/interfaces/openlp_plugins/songs/forms/test_songmaintenanceform.py index d9786db7a..6b1788690 100644 --- a/tests/interfaces/openlp_plugins/songs/forms/test_songmaintenanceform.py +++ b/tests/interfaces/openlp_plugins/songs/forms/test_songmaintenanceform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -30,7 +30,6 @@ from PyQt5 import QtCore, QtWidgets from openlp.core.common.i18n import UiStrings from openlp.core.common.registry import Registry from openlp.plugins.songs.forms.songmaintenanceform import SongMaintenanceForm - from tests.helpers.testmixin import TestMixin diff --git a/tests/interfaces/openlp_plugins/songs/forms/test_topicsform.py b/tests/interfaces/openlp_plugins/songs/forms/test_topicsform.py index 07808339f..a5449b26a 100644 --- a/tests/interfaces/openlp_plugins/songs/forms/test_topicsform.py +++ b/tests/interfaces/openlp_plugins/songs/forms/test_topicsform.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -57,7 +57,7 @@ class TestTopicsForm(TestCase, TestMixin): """ Test the TopicsForm defaults are correct """ - self.assertEqual(self.form.name_edit.text(), '', 'The first name edit should be empty') + assert self.form.name_edit.text() == '', 'The first name edit should be empty' def test_get_name_property(self): """ @@ -70,7 +70,7 @@ class TestTopicsForm(TestCase, TestMixin): self.form.name_edit.setText(topic_name) # THEN: The name property should have the correct value - self.assertEqual(self.form.name, topic_name, 'The name property should be correct') + assert self.form.name == topic_name, 'The name property should be correct' def test_set_name_property(self): """ @@ -83,4 +83,4 @@ class TestTopicsForm(TestCase, TestMixin): self.form.name = topic_name # THEN: The name_edit should have the correct value - self.assertEqual(self.form.name_edit.text(), topic_name, 'The topic name should be set correctly') + assert self.form.name_edit.text() == topic_name, 'The topic name should be set correctly' diff --git a/tests/resources/projector/data.py b/tests/resources/projector/data.py index d9baa80d0..acfb51df9 100644 --- a/tests/resources/projector/data.py +++ b/tests/resources/projector/data.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,9 +23,6 @@ The :mod:`tests.resources.projector.data file contains test data """ -import os -from tempfile import gettempdir - # Test data TEST_DB_PJLINK1 = 'projector_pjlink1.sqlite' diff --git a/tests/resources/chordprosongs/swing-low.chordpro b/tests/resources/songs/chordpro/swing-low.chordpro similarity index 100% rename from tests/resources/chordprosongs/swing-low.chordpro rename to tests/resources/songs/chordpro/swing-low.chordpro diff --git a/tests/resources/chordprosongs/swing-low.json b/tests/resources/songs/chordpro/swing-low.json similarity index 100% rename from tests/resources/chordprosongs/swing-low.json rename to tests/resources/songs/chordpro/swing-low.json diff --git a/tests/resources/easyslidessongs/Amazing Grace.json b/tests/resources/songs/easyslides/Amazing Grace.json similarity index 100% rename from tests/resources/easyslidessongs/Amazing Grace.json rename to tests/resources/songs/easyslides/Amazing Grace.json diff --git a/tests/resources/easyslidessongs/Export_2017-01-12_BB.json b/tests/resources/songs/easyslides/Export_2017-01-12_BB.json similarity index 100% rename from tests/resources/easyslidessongs/Export_2017-01-12_BB.json rename to tests/resources/songs/easyslides/Export_2017-01-12_BB.json diff --git a/tests/resources/easyslidessongs/Export_2017-01-12_BB.xml b/tests/resources/songs/easyslides/Export_2017-01-12_BB.xml similarity index 100% rename from tests/resources/easyslidessongs/Export_2017-01-12_BB.xml rename to tests/resources/songs/easyslides/Export_2017-01-12_BB.xml diff --git a/tests/resources/easyslidessongs/amazing-grace.xml b/tests/resources/songs/easyslides/amazing-grace.xml similarity index 100% rename from tests/resources/easyslidessongs/amazing-grace.xml rename to tests/resources/songs/easyslides/amazing-grace.xml diff --git a/tests/resources/easyworshipsongs/Songs.DB b/tests/resources/songs/easyworship/Songs.DB similarity index 100% rename from tests/resources/easyworshipsongs/Songs.DB rename to tests/resources/songs/easyworship/Songs.DB diff --git a/tests/resources/easyworshipsongs/Songs.MB b/tests/resources/songs/easyworship/Songs.MB similarity index 100% rename from tests/resources/easyworshipsongs/Songs.MB rename to tests/resources/songs/easyworship/Songs.MB diff --git a/tests/resources/easyworshipsongs/ew6/Databases/Data/SongWords.db b/tests/resources/songs/easyworship/ew6/Databases/Data/SongWords.db similarity index 100% rename from tests/resources/easyworshipsongs/ew6/Databases/Data/SongWords.db rename to tests/resources/songs/easyworship/ew6/Databases/Data/SongWords.db diff --git a/tests/resources/easyworshipsongs/ew6/Databases/Data/Songs.db b/tests/resources/songs/easyworship/ew6/Databases/Data/Songs.db similarity index 100% rename from tests/resources/easyworshipsongs/ew6/Databases/Data/Songs.db rename to tests/resources/songs/easyworship/ew6/Databases/Data/Songs.db diff --git a/tests/resources/easyworshipsongs/test1.ews b/tests/resources/songs/easyworship/test1.ews similarity index 100% rename from tests/resources/easyworshipsongs/test1.ews rename to tests/resources/songs/easyworship/test1.ews diff --git a/tests/resources/lyrixsongs/A002.TXT b/tests/resources/songs/lyrix/A002.TXT similarity index 100% rename from tests/resources/lyrixsongs/A002.TXT rename to tests/resources/songs/lyrix/A002.TXT diff --git a/tests/resources/lyrixsongs/A06.TXT b/tests/resources/songs/lyrix/A06.TXT similarity index 100% rename from tests/resources/lyrixsongs/A06.TXT rename to tests/resources/songs/lyrix/A06.TXT diff --git a/tests/resources/lyrixsongs/AO05.TXT b/tests/resources/songs/lyrix/AO05.TXT similarity index 100% rename from tests/resources/lyrixsongs/AO05.TXT rename to tests/resources/songs/lyrix/AO05.TXT diff --git a/tests/resources/lyrixsongs/Amazing Grace.json b/tests/resources/songs/lyrix/Amazing Grace.json similarity index 100% rename from tests/resources/lyrixsongs/Amazing Grace.json rename to tests/resources/songs/lyrix/Amazing Grace.json diff --git a/tests/resources/lyrixsongs/Amazing Grace2.json b/tests/resources/songs/lyrix/Amazing Grace2.json similarity index 100% rename from tests/resources/lyrixsongs/Amazing Grace2.json rename to tests/resources/songs/lyrix/Amazing Grace2.json diff --git a/tests/resources/lyrixsongs/in die regterhand.json b/tests/resources/songs/lyrix/in die regterhand.json similarity index 100% rename from tests/resources/lyrixsongs/in die regterhand.json rename to tests/resources/songs/lyrix/in die regterhand.json diff --git a/tests/resources/openlyricssongs/What a friend we have in Jesus.xml b/tests/resources/songs/openlyrics/What a friend we have in Jesus.xml similarity index 100% rename from tests/resources/openlyricssongs/What a friend we have in Jesus.xml rename to tests/resources/songs/openlyrics/What a friend we have in Jesus.xml diff --git a/tests/resources/openlyricssongs/duchu-tags.xml b/tests/resources/songs/openlyrics/duchu-tags.xml similarity index 100% rename from tests/resources/openlyricssongs/duchu-tags.xml rename to tests/resources/songs/openlyrics/duchu-tags.xml diff --git a/tests/resources/opensongsongs/Amazing Grace b/tests/resources/songs/opensong/Amazing Grace similarity index 100% rename from tests/resources/opensongsongs/Amazing Grace rename to tests/resources/songs/opensong/Amazing Grace diff --git a/tests/resources/opensongsongs/Amazing Grace with bad CCLI b/tests/resources/songs/opensong/Amazing Grace with bad CCLI similarity index 100% rename from tests/resources/opensongsongs/Amazing Grace with bad CCLI rename to tests/resources/songs/opensong/Amazing Grace with bad CCLI diff --git a/tests/resources/opensongsongs/Amazing Grace without CCLI.json b/tests/resources/songs/opensong/Amazing Grace without CCLI.json similarity index 100% rename from tests/resources/opensongsongs/Amazing Grace without CCLI.json rename to tests/resources/songs/opensong/Amazing Grace without CCLI.json diff --git a/tests/resources/opensongsongs/Amazing Grace.json b/tests/resources/songs/opensong/Amazing Grace.json similarity index 100% rename from tests/resources/opensongsongs/Amazing Grace.json rename to tests/resources/songs/opensong/Amazing Grace.json diff --git a/tests/resources/opensongsongs/Amazing Grace2 b/tests/resources/songs/opensong/Amazing Grace2 similarity index 100% rename from tests/resources/opensongsongs/Amazing Grace2 rename to tests/resources/songs/opensong/Amazing Grace2 diff --git a/tests/resources/opensongsongs/Beautiful Garden Of Prayer b/tests/resources/songs/opensong/Beautiful Garden Of Prayer similarity index 100% rename from tests/resources/opensongsongs/Beautiful Garden Of Prayer rename to tests/resources/songs/opensong/Beautiful Garden Of Prayer diff --git a/tests/resources/opensongsongs/Beautiful Garden Of Prayer.json b/tests/resources/songs/opensong/Beautiful Garden Of Prayer.json similarity index 100% rename from tests/resources/opensongsongs/Beautiful Garden Of Prayer.json rename to tests/resources/songs/opensong/Beautiful Garden Of Prayer.json diff --git a/tests/resources/opensongsongs/One, Two, Three, Four, Five b/tests/resources/songs/opensong/One, Two, Three, Four, Five similarity index 100% rename from tests/resources/opensongsongs/One, Two, Three, Four, Five rename to tests/resources/songs/opensong/One, Two, Three, Four, Five diff --git a/tests/resources/opensongsongs/One, Two, Three, Four, Five.json b/tests/resources/songs/opensong/One, Two, Three, Four, Five.json similarity index 100% rename from tests/resources/opensongsongs/One, Two, Three, Four, Five.json rename to tests/resources/songs/opensong/One, Two, Three, Four, Five.json diff --git a/tests/resources/opsprosongs/Amazing Grace.json b/tests/resources/songs/opspro/Amazing Grace.json similarity index 100% rename from tests/resources/opsprosongs/Amazing Grace.json rename to tests/resources/songs/opspro/Amazing Grace.json diff --git a/tests/resources/opsprosongs/Amazing Grace3.json b/tests/resources/songs/opspro/Amazing Grace3.json similarity index 100% rename from tests/resources/opsprosongs/Amazing Grace3.json rename to tests/resources/songs/opspro/Amazing Grace3.json diff --git a/tests/resources/opsprosongs/You are so faithful.json b/tests/resources/songs/opspro/You are so faithful.json similarity index 100% rename from tests/resources/opsprosongs/You are so faithful.json rename to tests/resources/songs/opspro/You are so faithful.json diff --git a/tests/resources/opsprosongs/amazing grace.txt b/tests/resources/songs/opspro/amazing grace.txt similarity index 100% rename from tests/resources/opsprosongs/amazing grace.txt rename to tests/resources/songs/opspro/amazing grace.txt diff --git a/tests/resources/opsprosongs/amazing grace2.txt b/tests/resources/songs/opspro/amazing grace2.txt similarity index 100% rename from tests/resources/opsprosongs/amazing grace2.txt rename to tests/resources/songs/opspro/amazing grace2.txt diff --git a/tests/resources/opsprosongs/amazing grace3.txt b/tests/resources/songs/opspro/amazing grace3.txt similarity index 100% rename from tests/resources/opsprosongs/amazing grace3.txt rename to tests/resources/songs/opspro/amazing grace3.txt diff --git a/tests/resources/opsprosongs/you are so faithfull.txt b/tests/resources/songs/opspro/you are so faithfull.txt similarity index 100% rename from tests/resources/opsprosongs/you are so faithfull.txt rename to tests/resources/songs/opspro/you are so faithfull.txt diff --git a/tests/resources/powerpraisesongs/Naher, mein Gott zu Dir.json b/tests/resources/songs/powerpraise/Naher, mein Gott zu Dir.json similarity index 100% rename from tests/resources/powerpraisesongs/Naher, mein Gott zu Dir.json rename to tests/resources/songs/powerpraise/Naher, mein Gott zu Dir.json diff --git a/tests/resources/powerpraisesongs/Naher, mein Gott zu Dir.ppl b/tests/resources/songs/powerpraise/Naher, mein Gott zu Dir.ppl similarity index 100% rename from tests/resources/powerpraisesongs/Naher, mein Gott zu Dir.ppl rename to tests/resources/songs/powerpraise/Naher, mein Gott zu Dir.ppl diff --git a/tests/resources/powerpraisesongs/You are so faithful.json b/tests/resources/songs/powerpraise/You are so faithful.json similarity index 100% rename from tests/resources/powerpraisesongs/You are so faithful.json rename to tests/resources/songs/powerpraise/You are so faithful.json diff --git a/tests/resources/powerpraisesongs/You are so faithful.ppl b/tests/resources/songs/powerpraise/You are so faithful.ppl similarity index 100% rename from tests/resources/powerpraisesongs/You are so faithful.ppl rename to tests/resources/songs/powerpraise/You are so faithful.ppl diff --git a/tests/resources/presentationmanagersongs/Amazing Grace.json b/tests/resources/songs/presentationmanager/Amazing Grace.json similarity index 100% rename from tests/resources/presentationmanagersongs/Amazing Grace.json rename to tests/resources/songs/presentationmanager/Amazing Grace.json diff --git a/tests/resources/presentationmanagersongs/Amazing Grace.sng b/tests/resources/songs/presentationmanager/Amazing Grace.sng similarity index 100% rename from tests/resources/presentationmanagersongs/Amazing Grace.sng rename to tests/resources/songs/presentationmanager/Amazing Grace.sng diff --git a/tests/resources/presentationmanagersongs/Great Is Thy Faithfulness.json b/tests/resources/songs/presentationmanager/Great Is Thy Faithfulness.json similarity index 100% rename from tests/resources/presentationmanagersongs/Great Is Thy Faithfulness.json rename to tests/resources/songs/presentationmanager/Great Is Thy Faithfulness.json diff --git a/tests/resources/presentationmanagersongs/Great Is Thy Faithfulness.sng b/tests/resources/songs/presentationmanager/Great Is Thy Faithfulness.sng similarity index 100% rename from tests/resources/presentationmanagersongs/Great Is Thy Faithfulness.sng rename to tests/resources/songs/presentationmanager/Great Is Thy Faithfulness.sng diff --git a/tests/resources/propresentersongs/Amazing Grace.json b/tests/resources/songs/propresenter/Amazing Grace.json similarity index 100% rename from tests/resources/propresentersongs/Amazing Grace.json rename to tests/resources/songs/propresenter/Amazing Grace.json diff --git a/tests/resources/propresentersongs/Amazing Grace.pro4 b/tests/resources/songs/propresenter/Amazing Grace.pro4 similarity index 100% rename from tests/resources/propresentersongs/Amazing Grace.pro4 rename to tests/resources/songs/propresenter/Amazing Grace.pro4 diff --git a/tests/resources/propresentersongs/Amazing Grace.pro5 b/tests/resources/songs/propresenter/Amazing Grace.pro5 similarity index 100% rename from tests/resources/propresentersongs/Amazing Grace.pro5 rename to tests/resources/songs/propresenter/Amazing Grace.pro5 diff --git a/tests/resources/propresentersongs/Amazing Grace.pro6 b/tests/resources/songs/propresenter/Amazing Grace.pro6 similarity index 100% rename from tests/resources/propresentersongs/Amazing Grace.pro6 rename to tests/resources/songs/propresenter/Amazing Grace.pro6 diff --git a/tests/resources/songbeamersongs/Amazing Grace.json b/tests/resources/songs/songbeamer/Amazing Grace.json similarity index 100% rename from tests/resources/songbeamersongs/Amazing Grace.json rename to tests/resources/songs/songbeamer/Amazing Grace.json diff --git a/tests/resources/songbeamersongs/Amazing Grace.sng b/tests/resources/songs/songbeamer/Amazing Grace.sng similarity index 100% rename from tests/resources/songbeamersongs/Amazing Grace.sng rename to tests/resources/songs/songbeamer/Amazing Grace.sng diff --git a/tests/resources/songbeamersongs/Lobsinget dem Herrn.json b/tests/resources/songs/songbeamer/Lobsinget dem Herrn.json similarity index 100% rename from tests/resources/songbeamersongs/Lobsinget dem Herrn.json rename to tests/resources/songs/songbeamer/Lobsinget dem Herrn.json diff --git a/tests/resources/songbeamersongs/Lobsinget dem Herrn.sng b/tests/resources/songs/songbeamer/Lobsinget dem Herrn.sng similarity index 100% rename from tests/resources/songbeamersongs/Lobsinget dem Herrn.sng rename to tests/resources/songs/songbeamer/Lobsinget dem Herrn.sng diff --git a/tests/resources/songbeamersongs/When I Call On You.json b/tests/resources/songs/songbeamer/When I Call On You.json similarity index 100% rename from tests/resources/songbeamersongs/When I Call On You.json rename to tests/resources/songs/songbeamer/When I Call On You.json diff --git a/tests/resources/songbeamersongs/When I Call On You.sng b/tests/resources/songs/songbeamer/When I Call On You.sng similarity index 100% rename from tests/resources/songbeamersongs/When I Call On You.sng rename to tests/resources/songs/songbeamer/When I Call On You.sng diff --git a/tests/resources/songbeamersongs/cp1252song.json b/tests/resources/songs/songbeamer/cp1252song.json similarity index 100% rename from tests/resources/songbeamersongs/cp1252song.json rename to tests/resources/songs/songbeamer/cp1252song.json diff --git a/tests/resources/songbeamersongs/cp1252song.sng b/tests/resources/songs/songbeamer/cp1252song.sng similarity index 100% rename from tests/resources/songbeamersongs/cp1252song.sng rename to tests/resources/songs/songbeamer/cp1252song.sng diff --git a/tests/resources/songprosongs/Amazing Grace.json b/tests/resources/songs/songpro/Amazing Grace.json similarity index 100% rename from tests/resources/songprosongs/Amazing Grace.json rename to tests/resources/songs/songpro/Amazing Grace.json diff --git a/tests/resources/songprosongs/amazing-grace.txt b/tests/resources/songs/songpro/amazing-grace.txt similarity index 100% rename from tests/resources/songprosongs/amazing-grace.txt rename to tests/resources/songs/songpro/amazing-grace.txt diff --git a/tests/resources/songselect/TestSong-bin.json b/tests/resources/songs/songselect/TestSong-bin.json similarity index 100% rename from tests/resources/songselect/TestSong-bin.json rename to tests/resources/songs/songselect/TestSong-bin.json diff --git a/tests/resources/songselect/TestSong-txt.json b/tests/resources/songs/songselect/TestSong-txt.json similarity index 100% rename from tests/resources/songselect/TestSong-txt.json rename to tests/resources/songs/songselect/TestSong-txt.json diff --git a/tests/resources/songselect/TestSong.bin b/tests/resources/songs/songselect/TestSong.bin similarity index 100% rename from tests/resources/songselect/TestSong.bin rename to tests/resources/songs/songselect/TestSong.bin diff --git a/tests/resources/songselect/TestSong.txt b/tests/resources/songs/songselect/TestSong.txt similarity index 100% rename from tests/resources/songselect/TestSong.txt rename to tests/resources/songs/songselect/TestSong.txt diff --git a/tests/resources/songshowplussongs/Amazing Grace.json b/tests/resources/songs/songshowplus/Amazing Grace.json similarity index 100% rename from tests/resources/songshowplussongs/Amazing Grace.json rename to tests/resources/songs/songshowplus/Amazing Grace.json diff --git a/tests/resources/songshowplussongs/Amazing Grace.sbsong b/tests/resources/songs/songshowplus/Amazing Grace.sbsong similarity index 100% rename from tests/resources/songshowplussongs/Amazing Grace.sbsong rename to tests/resources/songs/songshowplus/Amazing Grace.sbsong diff --git a/tests/resources/songshowplussongs/Beautiful Garden Of Prayer.json b/tests/resources/songs/songshowplus/Beautiful Garden Of Prayer.json similarity index 100% rename from tests/resources/songshowplussongs/Beautiful Garden Of Prayer.json rename to tests/resources/songs/songshowplus/Beautiful Garden Of Prayer.json diff --git a/tests/resources/songshowplussongs/Beautiful Garden Of Prayer.sbsong b/tests/resources/songs/songshowplus/Beautiful Garden Of Prayer.sbsong similarity index 100% rename from tests/resources/songshowplussongs/Beautiful Garden Of Prayer.sbsong rename to tests/resources/songs/songshowplus/Beautiful Garden Of Prayer.sbsong diff --git a/tests/resources/songshowplussongs/a mighty fortress is our god.json b/tests/resources/songs/songshowplus/a mighty fortress is our god.json similarity index 100% rename from tests/resources/songshowplussongs/a mighty fortress is our god.json rename to tests/resources/songs/songshowplus/a mighty fortress is our god.json diff --git a/tests/resources/songshowplussongs/a mighty fortress is our god.sbsong b/tests/resources/songs/songshowplus/a mighty fortress is our god.sbsong similarity index 100% rename from tests/resources/songshowplussongs/a mighty fortress is our god.sbsong rename to tests/resources/songs/songshowplus/a mighty fortress is our god.sbsong diff --git a/tests/resources/songshowplussongs/cleanse-me.json b/tests/resources/songs/songshowplus/cleanse-me.json similarity index 100% rename from tests/resources/songshowplussongs/cleanse-me.json rename to tests/resources/songs/songshowplus/cleanse-me.json diff --git a/tests/resources/songshowplussongs/cleanse-me.sbsong b/tests/resources/songs/songshowplus/cleanse-me.sbsong similarity index 100% rename from tests/resources/songshowplussongs/cleanse-me.sbsong rename to tests/resources/songs/songshowplus/cleanse-me.sbsong diff --git a/tests/resources/sundayplussongs/Amazing Grace.json b/tests/resources/songs/sundayplus/Amazing Grace.json similarity index 100% rename from tests/resources/sundayplussongs/Amazing Grace.json rename to tests/resources/songs/sundayplus/Amazing Grace.json diff --git a/tests/resources/sundayplussongs/Amazing Grace.ptf b/tests/resources/songs/sundayplus/Amazing Grace.ptf similarity index 100% rename from tests/resources/sundayplussongs/Amazing Grace.ptf rename to tests/resources/songs/sundayplus/Amazing Grace.ptf diff --git a/tests/resources/videopsalmsongs/as-safe-a-stronghold.json b/tests/resources/songs/videopsalm/as-safe-a-stronghold.json similarity index 100% rename from tests/resources/videopsalmsongs/as-safe-a-stronghold.json rename to tests/resources/songs/videopsalm/as-safe-a-stronghold.json diff --git a/tests/resources/videopsalmsongs/as-safe-a-stronghold2.json b/tests/resources/songs/videopsalm/as-safe-a-stronghold2.json similarity index 100% rename from tests/resources/videopsalmsongs/as-safe-a-stronghold2.json rename to tests/resources/songs/videopsalm/as-safe-a-stronghold2.json diff --git a/tests/resources/videopsalmsongs/videopsalm-as-safe-a-stronghold.json b/tests/resources/songs/videopsalm/videopsalm-as-safe-a-stronghold.json similarity index 100% rename from tests/resources/videopsalmsongs/videopsalm-as-safe-a-stronghold.json rename to tests/resources/songs/videopsalm/videopsalm-as-safe-a-stronghold.json diff --git a/tests/resources/videopsalmsongs/videopsalm-as-safe-a-stronghold2.json b/tests/resources/songs/videopsalm/videopsalm-as-safe-a-stronghold2.json similarity index 100% rename from tests/resources/videopsalmsongs/videopsalm-as-safe-a-stronghold2.json rename to tests/resources/songs/videopsalm/videopsalm-as-safe-a-stronghold2.json diff --git a/tests/resources/wordsofworshipsongs/Amazing Grace (6 Verses).json b/tests/resources/songs/wordsofworship/Amazing Grace (6 Verses).json similarity index 100% rename from tests/resources/wordsofworshipsongs/Amazing Grace (6 Verses).json rename to tests/resources/songs/wordsofworship/Amazing Grace (6 Verses).json diff --git a/tests/resources/wordsofworshipsongs/Amazing Grace (6 Verses).wow-song b/tests/resources/songs/wordsofworship/Amazing Grace (6 Verses).wow-song similarity index 100% rename from tests/resources/wordsofworshipsongs/Amazing Grace (6 Verses).wow-song rename to tests/resources/songs/wordsofworship/Amazing Grace (6 Verses).wow-song diff --git a/tests/resources/wordsofworshipsongs/Holy Holy Holy Lord God Almighty.json b/tests/resources/songs/wordsofworship/Holy Holy Holy Lord God Almighty.json similarity index 100% rename from tests/resources/wordsofworshipsongs/Holy Holy Holy Lord God Almighty.json rename to tests/resources/songs/wordsofworship/Holy Holy Holy Lord God Almighty.json diff --git a/tests/resources/wordsofworshipsongs/Holy Holy Holy Lord God Almighty.wow-song b/tests/resources/songs/wordsofworship/Holy Holy Holy Lord God Almighty.wow-song similarity index 100% rename from tests/resources/wordsofworshipsongs/Holy Holy Holy Lord God Almighty.wow-song rename to tests/resources/songs/wordsofworship/Holy Holy Holy Lord God Almighty.wow-song diff --git a/tests/resources/wordsofworshipsongs/When morning gilds the skies.json b/tests/resources/songs/wordsofworship/When morning gilds the skies.json similarity index 100% rename from tests/resources/wordsofworshipsongs/When morning gilds the skies.json rename to tests/resources/songs/wordsofworship/When morning gilds the skies.json diff --git a/tests/resources/wordsofworshipsongs/When morning gilds the skies.wsg b/tests/resources/songs/wordsofworship/When morning gilds the skies.wsg similarity index 100% rename from tests/resources/wordsofworshipsongs/When morning gilds the skies.wsg rename to tests/resources/songs/wordsofworship/When morning gilds the skies.wsg diff --git a/tests/resources/worshipassistantsongs/du_herr.csv b/tests/resources/songs/worshipassistant/du_herr.csv similarity index 100% rename from tests/resources/worshipassistantsongs/du_herr.csv rename to tests/resources/songs/worshipassistant/du_herr.csv diff --git a/tests/resources/worshipassistantsongs/du_herr.json b/tests/resources/songs/worshipassistant/du_herr.json similarity index 100% rename from tests/resources/worshipassistantsongs/du_herr.json rename to tests/resources/songs/worshipassistant/du_herr.json diff --git a/tests/resources/worshipassistantsongs/would_you_be_free.csv b/tests/resources/songs/worshipassistant/would_you_be_free.csv similarity index 100% rename from tests/resources/worshipassistantsongs/would_you_be_free.csv rename to tests/resources/songs/worshipassistant/would_you_be_free.csv diff --git a/tests/resources/worshipassistantsongs/would_you_be_free.json b/tests/resources/songs/worshipassistant/would_you_be_free.json similarity index 100% rename from tests/resources/worshipassistantsongs/would_you_be_free.json rename to tests/resources/songs/worshipassistant/would_you_be_free.json diff --git a/tests/resources/worshipassistantsongs/would_you_be_free2.csv b/tests/resources/songs/worshipassistant/would_you_be_free2.csv similarity index 100% rename from tests/resources/worshipassistantsongs/would_you_be_free2.csv rename to tests/resources/songs/worshipassistant/would_you_be_free2.csv diff --git a/tests/resources/zionworxsongs/zionworx.csv b/tests/resources/songs/zionworx/zionworx.csv similarity index 100% rename from tests/resources/zionworxsongs/zionworx.csv rename to tests/resources/songs/zionworx/zionworx.csv diff --git a/tests/resources/zionworxsongs/zionworx.json b/tests/resources/songs/zionworx/zionworx.json similarity index 100% rename from tests/resources/zionworxsongs/zionworx.json rename to tests/resources/songs/zionworx/zionworx.json diff --git a/tests/utils/__init__.py b/tests/utils/__init__.py index dd4d78354..7614193ce 100644 --- a/tests/utils/__init__.py +++ b/tests/utils/__init__.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -19,8 +19,8 @@ # with this program; if not, write to the Free Software Foundation, Inc., 59 # # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### -import os import json +import os def assert_length(expected, iterable, msg=None): @@ -41,3 +41,12 @@ def convert_file_service_item(test_path, name, row=0): finally: open_file.close() return first_line + + +def load_external_result_data(file_path): + """ + A method to load and return an object containing the song data from an external file. + + :param openlp.core.common.path.Path file_path: The path of the file to load + """ + return json.loads(file_path.read_bytes().decode()) diff --git a/tests/utils/constants.py b/tests/utils/constants.py index 45b2ee8ba..e65797261 100644 --- a/tests/utils/constants.py +++ b/tests/utils/constants.py @@ -1,5 +1,28 @@ +# -*- coding: utf-8 -*- +# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4 +############################################################################### +# OpenLP - Open Source Lyrics Projection # +# --------------------------------------------------------------------------- # +# Copyright (c) 2008-2018 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 # +############################################################################### import os +from openlp.core.common.path import Path + OPENLP_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), '..', '..')) TEST_RESOURCES_PATH = os.path.join(OPENLP_PATH, 'tests', 'resources') +RESOURCE_PATH = Path(TEST_RESOURCES_PATH) diff --git a/tests/utils/osdinteraction.py b/tests/utils/osdinteraction.py index d6beb54bf..8dbf93901 100644 --- a/tests/utils/osdinteraction.py +++ b/tests/utils/osdinteraction.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,8 +23,8 @@ The :mod:`osdinteraction` provides miscellaneous functions for interacting with OSD files. """ -import os import json +import os from tests.utils.constants import TEST_RESOURCES_PATH diff --git a/tests/utils/test_bzr_tags.py b/tests/utils/test_bzr_tags.py index 52f49692c..b6dc8f4ee 100644 --- a/tests/utils/test_bzr_tags.py +++ b/tests/utils/test_bzr_tags.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -23,9 +23,8 @@ Package to test for proper bzr tags. """ import os -from unittest import TestCase - from subprocess import Popen, PIPE +from unittest import TestCase TAGS1 = {'1.9.0', '1.9.1', '1.9.2', '1.9.3', '1.9.4', '1.9.5', '1.9.6', '1.9.7', '1.9.8', '1.9.9', '1.9.10', '1.9.11', '1.9.12', '2.0', '2.1.0', '2.1.1', '2.1.2', '2.1.3', '2.1.4', '2.1.5', '2.1.6', '2.2', @@ -52,4 +51,4 @@ class TestBzrTags(TestCase): count1 += 1 # THEN the tags should match the accepted tags - self.assertEqual(count, count1, 'List of tags should match') + assert count == count1, 'List of tags should match' diff --git a/tests/utils/test_pylint.py b/tests/utils/test_pylint.py index 50ca64db6..8ef9425c9 100644 --- a/tests/utils/test_pylint.py +++ b/tests/utils/test_pylint.py @@ -4,7 +4,7 @@ ############################################################################### # OpenLP - Open Source Lyrics Projection # # --------------------------------------------------------------------------- # -# Copyright (c) 2008-2017 OpenLP Developers # +# Copyright (c) 2008-2018 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 # @@ -22,7 +22,6 @@ """ Package to test for proper bzr tags. """ -import os import platform import sys from unittest import TestCase, SkipTest @@ -80,7 +79,7 @@ class TestPylint(TestCase): print(stderr) # THEN: The output should be empty - self.assertTrue(filtered_stdout == '', 'PyLint should find no errors') + assert filtered_stdout == '', 'PyLint should find no errors' def _filter_tolerated_errors(self, pylint_output): """