openlp-core team mailing list archive
-
openlp-core team
-
Mailing list archive
-
Message #22930
[Merge] lp:~tomasgroth/openlp/pptview-fix into lp:openlp
Tomas Groth has proposed merging lp:~tomasgroth/openlp/pptview-fix into lp:openlp.
Requested reviews:
OpenLP Core (openlp-core)
For more details, see:
https://code.launchpad.net/~tomasgroth/openlp/pptview-fix/+merge/214111
Fixed wrong dll load path.
--
https://code.launchpad.net/~tomasgroth/openlp/pptview-fix/+merge/214111
Your team OpenLP Core is requested to review the proposed merge of lp:~tomasgroth/openlp/pptview-fix into lp:openlp.
=== modified file 'openlp/plugins/presentations/lib/pptviewcontroller.py'
--- openlp/plugins/presentations/lib/pptviewcontroller.py 2014-03-24 16:49:50 +0000
+++ openlp/plugins/presentations/lib/pptviewcontroller.py 2014-04-03 20:23:45 +0000
@@ -87,7 +87,7 @@
return
log.debug('start PPTView')
dll_path = os.path.join(AppLocation.get_directory(AppLocation.AppDir),
- 'presentations', 'lib', 'pptviewlib', 'pptviewlib.dll')
+ 'plugins', 'presentations', 'lib', 'pptviewlib', 'pptviewlib.dll')
self.process = cdll.LoadLibrary(dll_path)
if log.isEnabledFor(logging.DEBUG):
self.process.SetDebug(1)
=== modified file 'tests/functional/openlp_plugins/presentations/test_pdfcontroller.py'
--- tests/functional/openlp_plugins/presentations/test_pdfcontroller.py 2014-03-14 22:08:44 +0000
+++ tests/functional/openlp_plugins/presentations/test_pdfcontroller.py 2014-04-03 20:23:45 +0000
@@ -33,6 +33,7 @@
import shutil
from unittest import TestCase, SkipTest
from tempfile import mkdtemp
+from PyQt4 import QtCore, QtGui
from openlp.plugins.presentations.lib.pdfcontroller import PdfController, PdfDocument
from tests.functional import MagicMock
@@ -45,6 +46,11 @@
'presentations/enable_pdf_program': False
}
+SCREEN = {
+ 'primary': False,
+ 'number': 1,
+ 'size': QtCore.QRect(0, 0, 1024, 768)
+}
class TestPdfController(TestCase, TestMixin):
"""
@@ -56,7 +62,12 @@
"""
self.get_application()
self.build_settings()
- ScreenList.create(self.app.desktop())
+ # Mocked out desktop object
+ self.desktop = MagicMock()
+ self.desktop.primaryScreen.return_value = SCREEN['primary']
+ self.desktop.screenCount.return_value = SCREEN['number']
+ self.desktop.screenGeometry.return_value = SCREEN['size']
+ self.screens = ScreenList.create(self.desktop)
Settings().extend_default_settings(__default_settings__)
self.temp_folder = mkdtemp()
self.thumbnail_folder = mkdtemp()
@@ -67,12 +78,11 @@
"""
Delete all the C++ objects at the end so that we don't have a segfault
"""
- try:
- self.destroy_settings()
- shutil.rmtree(self.thumbnail_folder)
- shutil.rmtree(self.temp_folder)
- except OSError:
- pass
+ del self.screens
+ self.destroy_settings()
+ shutil.rmtree(self.thumbnail_folder)
+ shutil.rmtree(self.temp_folder)
+
def constructor_test(self):
"""
@@ -106,3 +116,30 @@
# 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.')
+
+ def load_pdf_pictures_test(self):
+ """
+ Test loading of a Pdf and check size of generate pictures
+ """
+ # GIVEN: A Pdf-file
+ test_file = os.path.join(TEST_RESOURCES_PATH, 'presentations', 'pdf_test1.pdf')
+
+ # WHEN: The Pdf is loaded
+ controller = PdfController(plugin=self.mock_plugin)
+ if not controller.check_available():
+ raise SkipTest('Could not detect mudraw or ghostscript, so skipping PDF test')
+ controller.temp_folder = self.temp_folder
+ controller.thumbnail_folder = self.thumbnail_folder
+ document = PdfDocument(controller, test_file)
+ 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.')
+ image = QtGui.QImage(os.path.join(self.temp_folder, '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')
+ else:
+ self.assertEqual(767, image.height(), 'The height should be 767')
+ self.assertEqual(543, image.width(), 'The width should be 543')
Follow ups