- fixed presentation file mask

bzr-revno: 2279
This commit is contained in:
Andreas Preikschat 2013-07-18 08:09:00 +02:00
commit 53d5cda91a
5 changed files with 80 additions and 15 deletions

View File

@ -59,7 +59,7 @@ class PresentationMediaItem(MediaManagerItem):
self.controllers = controllers self.controllers = controllers
self.icon_path = u'presentations/presentation' self.icon_path = u'presentations/presentation'
self.Automatic = u'' self.Automatic = u''
MediaManagerItem.__init__(self, parent, plugin) super(PresentationMediaItem, self).__init__(parent, plugin)
self.message_listener = MessageListener(self) self.message_listener = MessageListener(self)
self.has_search = True self.has_search = True
self.single_service_item = False self.single_service_item = False
@ -80,15 +80,15 @@ class PresentationMediaItem(MediaManagerItem):
""" """
Build the list of file extensions to be used in the Open file dialog. Build the list of file extensions to be used in the Open file dialog.
""" """
file_type_list = u'' file_type_string = u''
for controller in self.controllers: for controller in self.controllers:
if self.controllers[controller].enabled(): if self.controllers[controller].enabled():
file_types = self.controllers[controller].supports + self.controllers[controller].also_supports file_types = self.controllers[controller].supports + self.controllers[controller].also_supports
for file_type in file_types: for file_type in file_types:
if file_type.find(file_type) == -1: if file_type not in file_type_string:
file_type_list += u'*.%s ' % file_type file_type_string += u'*.%s ' % file_type
self.service_manager.supported_suffixes(file_type) self.service_manager.supported_suffixes(file_type)
self.on_new_file_masks = translate('PresentationPlugin.MediaItem', 'Presentations (%s)') % file_type_list self.on_new_file_masks = translate('PresentationPlugin.MediaItem', 'Presentations (%s)') % file_type_string
def required_icons(self): def required_icons(self):
""" """

View File

@ -0,0 +1,71 @@
"""
This module contains tests for the lib submodule of the Presentations plugin.
"""
import os
from tempfile import mkstemp
from unittest import TestCase
from mock import patch, MagicMock
from PyQt4 import QtGui
from openlp.core.lib import Registry
from openlp.plugins.presentations.lib.mediaitem import PresentationMediaItem
class TestMediaItem(TestCase):
"""
Test the mediaitem methods.
"""
def setUp(self):
"""
Set up the components need for all tests.
"""
Registry.create()
Registry().register(u'service_manager', MagicMock())
Registry().register(u'main_window', MagicMock())
with patch('openlp.plugins.presentations.lib.mediaitem.PresentationMediaItem.__init__') as mocked_init:
mocked_init.return_value = None
self.media_item = PresentationMediaItem(MagicMock(), MagicMock, MagicMock(), MagicMock())
self.application = QtGui.QApplication.instance()
def tearDown(self):
"""
Delete all the C++ objects at the end so that we don't have a segfault
"""
del self.application
def build_file_mask_string_test(self):
"""
Test the build_file_mask_string() method
"""
# GIVEN: Different controllers.
impress_controller = MagicMock()
impress_controller.enabled.return_value = True
impress_controller.supports = [u'odp']
impress_controller.also_supports = [u'ppt']
presentation_controller = MagicMock()
presentation_controller.enabled.return_value = True
presentation_controller.supports = [u'ppt']
presentation_controller.also_supports = []
presentation_viewer_controller = MagicMock()
presentation_viewer_controller.enabled.return_value = False
# Mock the controllers.
self.media_item.controllers = {
u'Impress': impress_controller,
u'Powerpoint': presentation_controller,
u'Powerpoint Viewer': presentation_viewer_controller
}
# WHEN: Build the file mask.
with patch('openlp.plugins.presentations.lib.mediaitem.translate') as mocked_translate:
mocked_translate.side_effect = lambda module, string_to_translate: string_to_translate
self.media_item.build_file_mask_string()
# THEN: The file mask should be generated.
assert self.media_item.on_new_file_masks == u'Presentations (*.odp *.ppt )', \
u'The file mask should contain the odp and ppt extensions'

View File

@ -26,7 +26,7 @@ class TestMediaItem(TestCase):
Registry().register(u'service_list', MagicMock()) Registry().register(u'service_list', MagicMock())
Registry().register(u'main_window', MagicMock()) Registry().register(u'main_window', MagicMock())
with patch('openlp.core.lib.mediamanageritem.MediaManagerItem.__init__'), \ with patch('openlp.core.lib.mediamanageritem.MediaManagerItem.__init__'), \
patch('openlp.plugins.songs.forms.editsongform.EditSongForm.__init__'): patch('openlp.plugins.songs.forms.editsongform.EditSongForm.__init__'):
self.media_item = SongMediaItem(MagicMock(), MagicMock()) self.media_item = SongMediaItem(MagicMock(), MagicMock())
fd, self.ini_file = mkstemp(u'.ini') fd, self.ini_file = mkstemp(u'.ini')

View File

@ -80,9 +80,7 @@ class TestEditCustomForm(TestCase):
# GIVEN: Mocked methods. # GIVEN: Mocked methods.
with patch(u'openlp.plugins.custom.forms.editcustomform.critical_error_message_box') as \ with patch(u'openlp.plugins.custom.forms.editcustomform.critical_error_message_box') as \
mocked_critical_error_message_box: mocked_critical_error_message_box:
mocked_displayText = MagicMock() self.form.title_edit.displayText = MagicMock(return_value=u'')
mocked_displayText.return_value = u''
self.form.title_edit.displayText = mocked_displayText
mocked_setFocus = MagicMock() mocked_setFocus = MagicMock()
self.form.title_edit.setFocus = mocked_setFocus self.form.title_edit.setFocus = mocked_setFocus
@ -101,12 +99,8 @@ class TestEditCustomForm(TestCase):
# GIVEN: Mocked methods. # GIVEN: Mocked methods.
with patch(u'openlp.plugins.custom.forms.editcustomform.critical_error_message_box') as \ with patch(u'openlp.plugins.custom.forms.editcustomform.critical_error_message_box') as \
mocked_critical_error_message_box: mocked_critical_error_message_box:
mocked_displayText = MagicMock() self.form.title_edit.displayText = MagicMock(return_value=u'something')
mocked_displayText.return_value = u'something' self.form.slide_list_view.count = MagicMock(return_value=0)
self.form.title_edit.displayText = mocked_displayText
mocked_count = MagicMock()
mocked_count.return_value = 0
self.form.slide_list_view.count = mocked_count
# WHEN: Call the method. # WHEN: Call the method.
result = self.form._validate() result = self.form._validate()