forked from openlp/openlp
Merge remote-tracking branch 'upstream/master' into test_fixes
This commit is contained in:
commit
3271e15401
2
.gitignore
vendored
2
.gitignore
vendored
@ -34,6 +34,7 @@ list
|
|||||||
node_modules
|
node_modules
|
||||||
openlp.cfg
|
openlp.cfg
|
||||||
openlp.pro
|
openlp.pro
|
||||||
|
openlp/core/resources.py
|
||||||
openlp/core/resources.py.old
|
openlp/core/resources.py.old
|
||||||
openlp/plugins/presentations/lib/vendor/Pyro4
|
openlp/plugins/presentations/lib/vendor/Pyro4
|
||||||
openlp/plugins/presentations/lib/vendor/serpent.py
|
openlp/plugins/presentations/lib/vendor/serpent.py
|
||||||
@ -41,3 +42,4 @@ output
|
|||||||
package-lock.json
|
package-lock.json
|
||||||
tags
|
tags
|
||||||
test
|
test
|
||||||
|
openlp-test-projectordb.sqlite
|
||||||
|
@ -1,6 +1,20 @@
|
|||||||
stages:
|
stages:
|
||||||
|
- lint
|
||||||
- test
|
- test
|
||||||
|
|
||||||
|
lint:
|
||||||
|
stage: lint
|
||||||
|
image: python
|
||||||
|
before_script:
|
||||||
|
- apt-get update
|
||||||
|
# packages required for dbus-python
|
||||||
|
- apt-get -y install libdbus-1-dev libdbus-glib-1-dev
|
||||||
|
# packages required for pyodbc
|
||||||
|
- apt-get -y install unixodbc unixodbc-dev
|
||||||
|
- pip install -e .[test]
|
||||||
|
script:
|
||||||
|
- flake8
|
||||||
|
|
||||||
test-debian:
|
test-debian:
|
||||||
stage: test
|
stage: test
|
||||||
variables:
|
variables:
|
||||||
@ -8,16 +22,16 @@ test-debian:
|
|||||||
image: debian:unstable
|
image: debian:unstable
|
||||||
before_script:
|
before_script:
|
||||||
- apt-get update
|
- apt-get update
|
||||||
- apt-get install -y python3 qttools5-dev-tools pyqt5-dev-tools python3-pyqt5 python3-pyqt5.qtmultimedia \
|
- apt-get install -y python3 qttools5-dev-tools pyqt5-dev-tools python3-pyqt5 python3-pyqt5.qtmultimedia
|
||||||
python3-pyqt5.qtsvg python3-pyqt5.qtopengl python3-pyqt5.qtwebchannel python3-pyqt5.qtwebkit \
|
python3-pyqt5.qtsvg python3-pyqt5.qtopengl python3-pyqt5.qtwebchannel python3-pyqt5.qtwebkit
|
||||||
python3-pyqt5.qtwebengine python3-sqlalchemy python3-chardet python3-lxml python3-enchant \
|
python3-pyqt5.qtwebengine python3-dbus.mainloop.pyqt5 python3-sqlalchemy python3-alembic
|
||||||
python3-bs4 python3-mako python3-uno python3-pytest python3-pytest-cov python3-pip \
|
python3-chardet python3-lxml python3-enchant python3-bs4 python3-mako python3-uno
|
||||||
python3-alembic python3-xdg python3-dbus.mainloop.pyqt5 python3-pep8 python3-websockets \
|
python3-pytest python3-pytest-cov python3-websockets python3-webob python3-waitress
|
||||||
python3-waitress python3-webob python3-requests python3-pymediainfo python3-qtawesome \
|
python3-requests python3-pymediainfo python3-qtawesome python3-opengl python3-appdirs
|
||||||
python3-opengl python3-appdirs python3-vlc python3-zeroconf mediainfo pylint3 xvfb
|
python3-vlc python3-zeroconf python3-pip python3-pep8 mediainfo mupdf-tools xvfb
|
||||||
- sh scripts/generate_resources.sh
|
- sh scripts/generate_resources.sh
|
||||||
script:
|
script:
|
||||||
- xvfb-run -s '-screen 0 1024x768x24' pytest-3 -Wignore
|
- xvfb-run -s '-screen 0 1024x768x24' pytest-3 -Wignore --ignore tests/functional/openlp_plugins/presentations/test_pdfcontroller.py
|
||||||
|
|
||||||
test-ubuntu:
|
test-ubuntu:
|
||||||
stage: test
|
stage: test
|
||||||
@ -26,39 +40,40 @@ test-ubuntu:
|
|||||||
image: ubuntu:rolling
|
image: ubuntu:rolling
|
||||||
before_script:
|
before_script:
|
||||||
- apt-get update
|
- apt-get update
|
||||||
- apt-get install -y python3 qttools5-dev-tools pyqt5-dev-tools python3-pyqt5 python3-pyqt5.qtmultimedia \
|
- apt-get install -y python3 qttools5-dev-tools pyqt5-dev-tools python3-pyqt5 python3-pyqt5.qtmultimedia
|
||||||
python3-pyqt5.qtsvg python3-pyqt5.qtopengl python3-pyqt5.qtwebchannel python3-pyqt5.qtwebkit \
|
python3-pyqt5.qtsvg python3-pyqt5.qtopengl python3-pyqt5.qtwebchannel python3-pyqt5.qtwebkit
|
||||||
python3-pyqt5.qtwebengine python3-sqlalchemy python3-chardet python3-lxml python3-enchant \
|
python3-pyqt5.qtwebengine python3-dbus.mainloop.pyqt5 python3-sqlalchemy python3-alembic
|
||||||
python3-bs4 python3-mako python3-uno python3-pytest python3-pytest-cov python3-pip \
|
python3-chardet python3-lxml python3-enchant python3-bs4 python3-mako python3-uno
|
||||||
python3-alembic python3-xdg python3-dbus.mainloop.pyqt5 python3-pep8 python3-websockets \
|
python3-pytest python3-pytest-cov python3-websockets python3-webob python3-waitress
|
||||||
python3-waitress python3-webob python3-requests python3-pymediainfo python3-qtawesome \
|
python3-requests python3-pymediainfo python3-qtawesome python3-opengl python3-appdirs
|
||||||
python3-opengl python3-appdirs python3-vlc python3-zeroconf mediainfo pylint3 xvfb
|
python3-vlc python3-zeroconf python3-pip python3-pep8 mediainfo mupdf-tools xvfb
|
||||||
- sh scripts/generate_resources.sh
|
- sh scripts/generate_resources.sh
|
||||||
script:
|
script:
|
||||||
- xvfb-run -s '-screen 0 1024x768x24' pytest-3 -Wignore
|
- xvfb-run -s '-screen 0 1024x768x24' pytest-3 -Wignore --ignore tests/functional/openlp_plugins/presentations/test_pdfcontroller.py
|
||||||
|
|
||||||
test-fedora:
|
test-fedora:
|
||||||
stage: test
|
stage: test
|
||||||
image: fedora
|
image: fedora
|
||||||
before_script:
|
before_script:
|
||||||
- dnf install -y https://download1.rpmfusion.org/free/fedora/rpmfusion-free-release-$(rpm -E %fedora).noarch.rpm \
|
- dnf install -y https://download1.rpmfusion.org/free/fedora/rpmfusion-free-release-$(rpm -E %fedora).noarch.rpm
|
||||||
https://download1.rpmfusion.org/nonfree/fedora/rpmfusion-nonfree-release-$(rpm -E %fedora).noarch.rpm
|
https://download1.rpmfusion.org/nonfree/fedora/rpmfusion-nonfree-release-$(rpm -E %fedora).noarch.rpm
|
||||||
- dnf install -y python3-PyQt5 python3-qt5-webkit python3-qt5-webengine python3-sqlalchemy python3-alembic \
|
- dnf install -y python3-PyQt5 python3-qt5-webkit python3-qt5-webengine python3-sqlalchemy python3-alembic
|
||||||
python3-beautifulsoup4 python3-chardet python3-enchant python3-lxml python3-pyxdg python3-pytest \
|
python3-beautifulsoup4 python3-chardet python3-enchant python3-lxml python3-pyxdg python3-pytest
|
||||||
python3-websockets python3-appdirs python3-webob python3-QtAwesome python3-waitress \
|
python3-websockets python3-appdirs python3-webob python3-QtAwesome python3-waitress python3-vlc
|
||||||
python3-pymediainfo python3-pyopengl python3-pylint python-pysword python3-requests \
|
python3-pymediainfo python3-pyopengl python-pysword python3-requests python3-zeroconf mediainfo
|
||||||
mediainfo patch xorg-x11-server-Xvfb python3-vlc python3-zeroconf
|
patch xorg-x11-server-Xvfb ghostscript mupdf
|
||||||
- sh scripts/generate_resources.sh
|
- sh scripts/generate_resources.sh
|
||||||
script:
|
script:
|
||||||
- xvfb-run -s '-screen 0 1024x768x24' pytest-3 -Wignore
|
- xvfb-run -s '-screen 0 1024x768x24' pytest-3 -Wignore --ignore tests/functional/openlp_plugins/presentations/test_pdfcontroller.py
|
||||||
|
|
||||||
test-macos:
|
test-macos:
|
||||||
only:
|
|
||||||
- master@openlp/openlp
|
|
||||||
stage: test
|
stage: test
|
||||||
tags:
|
tags:
|
||||||
- macos
|
- macos
|
||||||
before_script:
|
before_script:
|
||||||
|
- export PATH=/opt/local/bin:$PATH
|
||||||
- sh scripts/generate_resources.sh
|
- sh scripts/generate_resources.sh
|
||||||
script:
|
script:
|
||||||
- python3 -m pytest -v --color=no --disable-warnings --ignore=tests/utils
|
- python3 -m pytest -v --color=no --disable-warnings --ignore=tests/utils
|
||||||
|
only:
|
||||||
|
- master@openlp/openlp
|
||||||
|
@ -9,14 +9,14 @@
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
|
|
||||||
class Ui_AuditDetailDialog(object):
|
class Ui_AuditDetailDialog(object):
|
||||||
def setupUi(self, AuditDetailDialog):
|
def setupUi(self, AuditDetailDialog):
|
||||||
AuditDetailDialog.setObjectName(u'AuditDetailDialog')
|
AuditDetailDialog.setObjectName(u'AuditDetailDialog')
|
||||||
AuditDetailDialog.resize(593, 501)
|
AuditDetailDialog.resize(593, 501)
|
||||||
self.buttonBox = QtGui.QDialogButtonBox(AuditDetailDialog)
|
self.buttonBox = QtGui.QDialogButtonBox(AuditDetailDialog)
|
||||||
self.buttonBox.setGeometry(QtCore.QRect(420, 470, 170, 25))
|
self.buttonBox.setGeometry(QtCore.QRect(420, 470, 170, 25))
|
||||||
self.buttonBox.setStandardButtons(
|
self.buttonBox.setStandardButtons(QtGui.QDialogButtonBox.Cancel | QtGui.QDialogButtonBox.Ok)
|
||||||
QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Ok)
|
|
||||||
self.buttonBox.setObjectName(u'buttonBox')
|
self.buttonBox.setObjectName(u'buttonBox')
|
||||||
self.FileGroupBox = QtGui.QGroupBox(AuditDetailDialog)
|
self.FileGroupBox = QtGui.QGroupBox(AuditDetailDialog)
|
||||||
self.FileGroupBox.setGeometry(QtCore.QRect(10, 370, 571, 70))
|
self.FileGroupBox.setGeometry(QtCore.QRect(10, 370, 571, 70))
|
||||||
|
@ -26,6 +26,7 @@ from PyQt4 import QtCore, QtGui
|
|||||||
|
|
||||||
from auditdetaildialog import Ui_AuditDetailDialog
|
from auditdetaildialog import Ui_AuditDetailDialog
|
||||||
|
|
||||||
|
|
||||||
class AuditDetailForm(QtGui.QDialog, Ui_AuditDetailDialog):
|
class AuditDetailForm(QtGui.QDialog, Ui_AuditDetailDialog):
|
||||||
"""
|
"""
|
||||||
Class documentation goes here.
|
Class documentation goes here.
|
||||||
@ -68,10 +69,8 @@ class AuditDetailForm(QtGui.QDialog, Ui_AuditDetailDialog):
|
|||||||
self.resetWindow()
|
self.resetWindow()
|
||||||
|
|
||||||
def defineOutputLocation(self):
|
def defineOutputLocation(self):
|
||||||
path = QtGui.QFileDialog.getExistingDirectory(self,
|
path = QtGui.QFileDialog.getExistingDirectory(self, self.trUtf8(u'Output File Location'),
|
||||||
self.trUtf8(u'Output File Location'),
|
|
||||||
self.parent.config.get_last_dir(1))
|
self.parent.config.get_last_dir(1))
|
||||||
path = unicode(path)
|
|
||||||
if path != u'':
|
if path != u'':
|
||||||
self.parent.config.set_last_dir(path, 1)
|
self.parent.config.set_last_dir(path, 1)
|
||||||
self.FileLineEdit.setText(path)
|
self.FileLineEdit.setText(path)
|
||||||
@ -97,10 +96,10 @@ class AuditDetailForm(QtGui.QDialog, Ui_AuditDetailDialog):
|
|||||||
self.ThirdToTimeEdit.setEnabled(True)
|
self.ThirdToTimeEdit.setEnabled(True)
|
||||||
|
|
||||||
def accept(self):
|
def accept(self):
|
||||||
print self.DetailedReport.isChecked()
|
print(self.DetailedReport.isChecked())
|
||||||
print self.SummaryReport.isChecked()
|
print(self.SummaryReport.isChecked())
|
||||||
print self.FromDateEdit.date()
|
print(self.FromDateEdit.date())
|
||||||
print self.ToDateEdit.date()
|
print(self.ToDateEdit.date())
|
||||||
if self.DetailedReport.isChecked():
|
if self.DetailedReport.isChecked():
|
||||||
self.detailedReport()
|
self.detailedReport()
|
||||||
else:
|
else:
|
||||||
@ -108,15 +107,15 @@ class AuditDetailForm(QtGui.QDialog, Ui_AuditDetailDialog):
|
|||||||
self.close()
|
self.close()
|
||||||
|
|
||||||
def detailedReport(self):
|
def detailedReport(self):
|
||||||
print "detailed"
|
print("detailed")
|
||||||
filename = u'audit_det_%s_%s.txt' % \
|
filename = u'audit_det_%s_%s.txt' % \
|
||||||
(self.FromDateEdit.date().toString(u'ddMMyyyy'),
|
(self.FromDateEdit.date().toString(u'ddMMyyyy'),
|
||||||
self.ToDateEdit.date().toString(u'ddMMyyyy'))
|
self.ToDateEdit.date().toString(u'ddMMyyyy'))
|
||||||
print filename
|
print(filename)
|
||||||
|
|
||||||
def summaryReport(self):
|
def summaryReport(self):
|
||||||
print "summary"
|
print("summary")
|
||||||
filename = u'audit_sum_%s_%s.txt' % \
|
filename = u'audit_sum_%s_%s.txt' % \
|
||||||
(self.FromDateEdit.date().toString(u'ddMMyyyy'),
|
(self.FromDateEdit.date().toString(u'ddMMyyyy'),
|
||||||
self.ToDateEdit.date().toString(u'ddMMyyyy'))
|
self.ToDateEdit.date().toString(u'ddMMyyyy'))
|
||||||
print filename
|
print(filename)
|
||||||
|
@ -34,7 +34,9 @@
|
|||||||
#
|
#
|
||||||
###############################################################################
|
###############################################################################
|
||||||
# Backup the existing resources
|
# Backup the existing resources
|
||||||
|
if [ -f "openlp/core/resources.py" ]; then
|
||||||
mv openlp/core/resources.py openlp/core/resources.py.old
|
mv openlp/core/resources.py openlp/core/resources.py.old
|
||||||
|
fi
|
||||||
|
|
||||||
# Create the new data from the updated qrc
|
# Create the new data from the updated qrc
|
||||||
pyrcc5 -o openlp/core/resources.py.new resources/images/openlp-2.qrc
|
pyrcc5 -o openlp/core/resources.py.new resources/images/openlp-2.qrc
|
||||||
|
@ -1,63 +0,0 @@
|
|||||||
#!/usr/bin/env python2
|
|
||||||
import os
|
|
||||||
import sys
|
|
||||||
from argparse import ArgumentParser
|
|
||||||
|
|
||||||
from launchpadlib.credentials import UnencryptedFileCredentialStore
|
|
||||||
from launchpadlib.launchpad import Launchpad
|
|
||||||
|
|
||||||
|
|
||||||
HERE = os.path.dirname(os.path.abspath(__file__))
|
|
||||||
|
|
||||||
|
|
||||||
def parse_args():
|
|
||||||
"""
|
|
||||||
Parse the command line arguments
|
|
||||||
"""
|
|
||||||
parser = ArgumentParser()
|
|
||||||
parser.add_argument('-p', '--merge-proposal', required=True,
|
|
||||||
help='The main part of the URL to the merge proposal, without the hostname.')
|
|
||||||
parser.add_argument('-m', '--message', required=True,
|
|
||||||
help='The comment to add to the merge proposal')
|
|
||||||
parser.add_argument('-s', '--subject', default=None, help='The subject for the comment')
|
|
||||||
return parser.parse_args()
|
|
||||||
|
|
||||||
|
|
||||||
def get_merge_proposal(merge_proposal_url):
|
|
||||||
"""
|
|
||||||
Get the merge proposal for the ``merge_proposal_url``
|
|
||||||
"""
|
|
||||||
lp = Launchpad.login_with('OpenLP CI', 'production', version='devel',
|
|
||||||
credential_store=UnencryptedFileCredentialStore(os.path.join(HERE, 'launchpadcreds.txt')))
|
|
||||||
openlp_project = lp.projects['openlp']
|
|
||||||
merge_proposals = openlp_project.getMergeProposals()
|
|
||||||
for merge_proposal in merge_proposals:
|
|
||||||
if str(merge_proposal).endswith(merge_proposal_url):
|
|
||||||
return merge_proposal
|
|
||||||
return None
|
|
||||||
|
|
||||||
|
|
||||||
def create_comment(merge_proposal, comment, subject):
|
|
||||||
"""
|
|
||||||
Create a comment on the merge proposal
|
|
||||||
"""
|
|
||||||
if not subject:
|
|
||||||
subject = 'Jenkins test update'
|
|
||||||
merge_proposal.createComment(subject=subject, content=comment)
|
|
||||||
|
|
||||||
|
|
||||||
def main():
|
|
||||||
"""
|
|
||||||
Run the thing
|
|
||||||
"""
|
|
||||||
args = parse_args()
|
|
||||||
merge_proposal = get_merge_proposal(args.merge_proposal)
|
|
||||||
if not merge_proposal:
|
|
||||||
print('No merge proposal with that URL found')
|
|
||||||
sys.exit(1)
|
|
||||||
else:
|
|
||||||
create_comment(merge_proposal, args.message, args.subject)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
main()
|
|
12
setup.py
12
setup.py
@ -197,16 +197,16 @@ using a computer and a data projector.""",
|
|||||||
'sword-bibles': ['pysword'],
|
'sword-bibles': ['pysword'],
|
||||||
# Required for scripts/*.py:
|
# Required for scripts/*.py:
|
||||||
'jenkins': ['python-jenkins'],
|
'jenkins': ['python-jenkins'],
|
||||||
'launchpad': ['launchpadlib']
|
'launchpad': ['launchpadlib'],
|
||||||
},
|
'test': [
|
||||||
tests_require=[
|
|
||||||
'pylint',
|
|
||||||
'PyMuPDF',
|
'PyMuPDF',
|
||||||
'pyodbc',
|
'pyodbc',
|
||||||
'pysword',
|
'pysword',
|
||||||
'pytest',
|
'pytest',
|
||||||
'python-xlib; platform_system=="Linux"'
|
'python-xlib; platform_system=="Linux"',
|
||||||
],
|
'flake8',
|
||||||
|
]
|
||||||
|
},
|
||||||
setup_requires=['pytest-runner'],
|
setup_requires=['pytest-runner'],
|
||||||
entry_points={'gui_scripts': ['openlp = openlp.__main__:start']}
|
entry_points={'gui_scripts': ['openlp = openlp.__main__:start']}
|
||||||
)
|
)
|
||||||
|
@ -1,64 +0,0 @@
|
|||||||
# -*- coding: utf-8 -*-
|
|
||||||
# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4
|
|
||||||
|
|
||||||
###############################################################################
|
|
||||||
# OpenLP - Open Source Lyrics Projection #
|
|
||||||
# --------------------------------------------------------------------------- #
|
|
||||||
# Copyright (c) 2008-2017 OpenLP Developers #
|
|
||||||
# --------------------------------------------------------------------------- #
|
|
||||||
# This program is 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 #
|
|
||||||
###############################################################################
|
|
||||||
"""
|
|
||||||
Module to test the :mod:`~openlp.core.common.historycombobox` module.
|
|
||||||
"""
|
|
||||||
|
|
||||||
from unittest import TestCase
|
|
||||||
|
|
||||||
from PyQt5 import QtWidgets
|
|
||||||
|
|
||||||
from openlp.core.common.registry import Registry
|
|
||||||
from openlp.core.ui.lib.historycombobox import HistoryComboBox
|
|
||||||
from tests.helpers.testmixin import TestMixin
|
|
||||||
|
|
||||||
|
|
||||||
class TestHistoryComboBox(TestCase, TestMixin):
|
|
||||||
def setUp(self):
|
|
||||||
"""
|
|
||||||
Some pre-test setup required.
|
|
||||||
"""
|
|
||||||
Registry.create()
|
|
||||||
self.setup_application()
|
|
||||||
self.main_window = QtWidgets.QMainWindow()
|
|
||||||
Registry().register('main_window', self.main_window)
|
|
||||||
self.combo = HistoryComboBox(self.main_window)
|
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
"""
|
|
||||||
Delete all the C++ objects at the end so that we don't have a segfault
|
|
||||||
"""
|
|
||||||
del self.combo
|
|
||||||
del self.main_window
|
|
||||||
|
|
||||||
def test_get_items(self):
|
|
||||||
"""
|
|
||||||
Test the getItems() method
|
|
||||||
"""
|
|
||||||
# GIVEN: The combo.
|
|
||||||
|
|
||||||
# WHEN: Add two items.
|
|
||||||
self.combo.addItem('test1')
|
|
||||||
self.combo.addItem('test2')
|
|
||||||
|
|
||||||
# THEN: The list of items should contain both strings.
|
|
||||||
self.assertEqual(self.combo.getItems(), ['test1', 'test2'])
|
|
Loading…
Reference in New Issue
Block a user