forked from openlp/openlp
b33d27f77c
The theme combo box did not show when the currently rendered item doesn't support the service/song theme levels. This changes the theme combo box to use the theme level from the settings rather than the currently rendered item.
759 lines
40 KiB
Python
759 lines
40 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
##########################################################################
|
|
# OpenLP - Open Source Lyrics Projection #
|
|
# ---------------------------------------------------------------------- #
|
|
# Copyright (c) 2008-2020 OpenLP Developers #
|
|
# ---------------------------------------------------------------------- #
|
|
# This program is 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, either version 3 of the License, or #
|
|
# (at your option) any later version. #
|
|
# #
|
|
# 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, see <https://www.gnu.org/licenses/>. #
|
|
##########################################################################
|
|
"""
|
|
Package to test the openlp.core.ui.slidecontroller package.
|
|
"""
|
|
from unittest.mock import MagicMock, patch
|
|
|
|
import PyQt5
|
|
|
|
from openlp.core.common import ThemeLevel
|
|
from openlp.core.common.registry import Registry
|
|
from openlp.core.common.enum import ServiceItemType
|
|
from openlp.core.lib.serviceitem import ItemCapabilities, ServiceItem
|
|
from openlp.core.ui.servicemanager import ServiceManager
|
|
from openlp.core.widgets.toolbar import OpenLPToolbar
|
|
|
|
|
|
def test_initial_service_manager(registry):
|
|
"""
|
|
Test the initial of service manager.
|
|
"""
|
|
# GIVEN: A new service manager instance.
|
|
ServiceManager(None)
|
|
# WHEN: the default service manager is built.
|
|
# THEN: The the controller should be registered in the registry.
|
|
assert Registry().get('service_manager') is not None, 'The base service manager should be registered'
|
|
|
|
|
|
def test_create_basic_service(registry):
|
|
"""
|
|
Test the create basic service array
|
|
"""
|
|
# GIVEN: A new service manager instance.
|
|
service_manager = ServiceManager(None)
|
|
# WHEN: when the basic service array is created.
|
|
service_manager._save_lite = False
|
|
service_manager.service_theme = 'test_theme'
|
|
service = service_manager.create_basic_service()[0]
|
|
# THEN: The controller should be registered in the registry.
|
|
assert service is not None, 'The base service should be created'
|
|
assert service['openlp_core']['service-theme'] == 'test_theme', 'The test theme should be saved'
|
|
assert service['openlp_core']['lite-service'] is False, 'The lite service should be saved'
|
|
|
|
|
|
def test_supported_suffixes(registry):
|
|
"""
|
|
Test the create basic service array
|
|
"""
|
|
# GIVEN: A new service manager instance.
|
|
service_manager = ServiceManager(None)
|
|
# WHEN: a suffix is added as an individual or a list.
|
|
service_manager.supported_suffixes('txt')
|
|
service_manager.supported_suffixes(['pptx', 'ppt'])
|
|
# THEN: The suffixes should be available to test.
|
|
assert 'txt' in service_manager.suffixes, 'The suffix txt should be in the list'
|
|
assert 'ppt' in service_manager.suffixes, 'The suffix ppt should be in the list'
|
|
assert 'pptx' in service_manager.suffixes, 'The suffix pptx should be in the list'
|
|
|
|
|
|
def test_build_context_menu(registry):
|
|
"""
|
|
Test the creation of a context menu from a null service item.
|
|
"""
|
|
# GIVEN: A new service manager instance and a default service item.
|
|
service_manager = ServiceManager(None)
|
|
item = MagicMock()
|
|
item.parent.return_value = False
|
|
item.data.return_value = 0
|
|
service_manager.service_manager_list = MagicMock()
|
|
service_manager.service_manager_list.itemAt.return_value = item
|
|
service_item = ServiceItem(None)
|
|
service_manager.service_items.insert(1, {'service_item': service_item})
|
|
service_manager.edit_action = MagicMock()
|
|
service_manager.rename_action = MagicMock()
|
|
service_manager.create_custom_action = MagicMock()
|
|
service_manager.maintain_action = MagicMock()
|
|
service_manager.notes_action = MagicMock()
|
|
service_manager.time_action = MagicMock()
|
|
service_manager.auto_start_action = MagicMock()
|
|
service_manager.auto_play_slides_menu = MagicMock()
|
|
service_manager.auto_play_slides_once = MagicMock()
|
|
service_manager.auto_play_slides_loop = MagicMock()
|
|
service_manager.timed_slide_interval = MagicMock()
|
|
service_manager.theme_menu = MagicMock()
|
|
service_manager.menu = MagicMock()
|
|
# WHEN I define a context menu
|
|
service_manager.context_menu(1)
|
|
# THEN the following calls should have occurred.
|
|
assert service_manager.edit_action.setVisible.call_count == 1, 'Should have been called once'
|
|
assert service_manager.rename_action.setVisible.call_count == 1, 'Should have been called once'
|
|
assert service_manager.create_custom_action.setVisible.call_count == 1, 'Should have been called once'
|
|
assert service_manager.maintain_action.setVisible.call_count == 1, 'Should have been called once'
|
|
assert service_manager.notes_action.setVisible.call_count == 1, 'Should have been called once'
|
|
assert service_manager.time_action.setVisible.call_count == 1, 'Should have been called once'
|
|
assert service_manager.auto_start_action.setVisible.call_count == 1, 'Should have been called once'
|
|
assert service_manager.auto_play_slides_menu.menuAction().setVisible.call_count == 1, \
|
|
'Should have been called once'
|
|
assert service_manager.auto_play_slides_once.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.auto_play_slides_loop.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.timed_slide_interval.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.theme_menu.menuAction().setVisible.call_count == 1, \
|
|
'Should have been called once'
|
|
|
|
|
|
def test_build_song_context_menu(registry, state):
|
|
"""
|
|
Test the creation of a context menu from service item of type text from Songs.
|
|
"""
|
|
# GIVEN: A new service manager instance and a default service item.
|
|
mocked_renderer = MagicMock()
|
|
mocked_renderer.theme_level = ThemeLevel.Song
|
|
Registry().register('plugin_manager', MagicMock())
|
|
Registry().register('renderer', mocked_renderer)
|
|
service_manager = ServiceManager(None)
|
|
item = MagicMock()
|
|
item.parent.return_value = False
|
|
item.data.return_value = 0
|
|
service_manager.service_manager_list = MagicMock()
|
|
service_manager.service_manager_list.itemAt.return_value = item
|
|
service_item = ServiceItem(None)
|
|
for capability in [ItemCapabilities.CanEdit, ItemCapabilities.CanPreview, ItemCapabilities.CanLoop,
|
|
ItemCapabilities.OnLoadUpdate, ItemCapabilities.AddIfNewItem,
|
|
ItemCapabilities.CanSoftBreak]:
|
|
service_item.add_capability(capability)
|
|
service_item.service_item_type = ServiceItemType.Text
|
|
service_item.edit_id = 1
|
|
service_item._display_slides = []
|
|
service_item._display_slides.append(MagicMock())
|
|
service_manager.service_items.insert(1, {'service_item': service_item})
|
|
service_manager.edit_action = MagicMock()
|
|
service_manager.rename_action = MagicMock()
|
|
service_manager.create_custom_action = MagicMock()
|
|
service_manager.maintain_action = MagicMock()
|
|
service_manager.notes_action = MagicMock()
|
|
service_manager.time_action = MagicMock()
|
|
service_manager.auto_start_action = MagicMock()
|
|
service_manager.auto_play_slides_menu = MagicMock()
|
|
service_manager.auto_play_slides_once = MagicMock()
|
|
service_manager.auto_play_slides_loop = MagicMock()
|
|
service_manager.timed_slide_interval = MagicMock()
|
|
service_manager.theme_menu = MagicMock()
|
|
service_manager.menu = MagicMock()
|
|
# WHEN I define a context menu
|
|
service_manager.context_menu(1)
|
|
# THEN the following calls should have occurred.
|
|
assert service_manager.edit_action.setVisible.call_count == 2, 'Should have be called twice'
|
|
assert service_manager.rename_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.create_custom_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.maintain_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.notes_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.time_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_start_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_play_slides_menu.menuAction().setVisible.call_count == 1, \
|
|
'Should have be called once'
|
|
assert service_manager.auto_play_slides_once.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.auto_play_slides_loop.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.timed_slide_interval.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.theme_menu.menuAction().setVisible.call_count == 2, \
|
|
'Should have be called twice'
|
|
# THEN we add a 2nd display frame
|
|
service_item._display_slides.append(MagicMock())
|
|
service_manager.context_menu(1)
|
|
# THEN the following additional calls should have occurred.
|
|
assert service_manager.auto_play_slides_menu.menuAction().setVisible.call_count == 2, \
|
|
'Should have be called twice'
|
|
assert service_manager.auto_play_slides_once.setChecked.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_play_slides_loop.setChecked.call_count == 1, 'Should have be called once'
|
|
assert service_manager.timed_slide_interval.setChecked.call_count == 1, 'Should have be called once'
|
|
|
|
|
|
def test_build_bible_context_menu(registry, state):
|
|
"""
|
|
Test the creation of a context menu from service item of type text from Bibles.
|
|
"""
|
|
# GIVEN: A new service manager instance and a default service item.
|
|
mocked_renderer = MagicMock()
|
|
mocked_renderer.theme_level = ThemeLevel.Song
|
|
Registry().register('plugin_manager', MagicMock())
|
|
Registry().register('renderer', mocked_renderer)
|
|
service_manager = ServiceManager(None)
|
|
item = MagicMock()
|
|
item.parent.return_value = False
|
|
item.data.return_value = 0
|
|
service_manager.service_manager_list = MagicMock()
|
|
service_manager.service_manager_list.itemAt.return_value = item
|
|
service_item = ServiceItem(None)
|
|
for capability in [ItemCapabilities.NoLineBreaks, ItemCapabilities.CanPreview,
|
|
ItemCapabilities.CanLoop, ItemCapabilities.CanWordSplit,
|
|
ItemCapabilities.CanEditTitle]:
|
|
service_item.add_capability(capability)
|
|
service_item.service_item_type = ServiceItemType.Text
|
|
service_item.edit_id = 1
|
|
service_item._display_slides = []
|
|
service_item._display_slides.append(MagicMock())
|
|
service_manager.service_items.insert(1, {'service_item': service_item})
|
|
service_manager.edit_action = MagicMock()
|
|
service_manager.rename_action = MagicMock()
|
|
service_manager.create_custom_action = MagicMock()
|
|
service_manager.maintain_action = MagicMock()
|
|
service_manager.notes_action = MagicMock()
|
|
service_manager.time_action = MagicMock()
|
|
service_manager.auto_start_action = MagicMock()
|
|
service_manager.auto_play_slides_menu = MagicMock()
|
|
service_manager.auto_play_slides_once = MagicMock()
|
|
service_manager.auto_play_slides_loop = MagicMock()
|
|
service_manager.timed_slide_interval = MagicMock()
|
|
service_manager.theme_menu = MagicMock()
|
|
service_manager.menu = MagicMock()
|
|
# WHEN I define a context menu
|
|
service_manager.context_menu(1)
|
|
# THEN the following calls should have occurred.
|
|
assert service_manager.edit_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.rename_action.setVisible.call_count == 2, 'Should have be called twice'
|
|
assert service_manager.create_custom_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.maintain_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.notes_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.time_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_start_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_play_slides_menu.menuAction().setVisible.call_count == 1, \
|
|
'Should have be called once'
|
|
assert service_manager.auto_play_slides_once.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.auto_play_slides_loop.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.timed_slide_interval.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.theme_menu.menuAction().setVisible.call_count == 2, \
|
|
'Should have be called twice'
|
|
# THEN we add a 2nd display frame
|
|
service_item._display_slides.append(MagicMock())
|
|
service_manager.context_menu(1)
|
|
# THEN the following additional calls should have occurred.
|
|
assert service_manager.auto_play_slides_menu.menuAction().setVisible.call_count == 2, \
|
|
'Should have be called twice'
|
|
assert service_manager.auto_play_slides_once.setChecked.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_play_slides_loop.setChecked.call_count == 1, 'Should have be called once'
|
|
assert service_manager.timed_slide_interval.setChecked.call_count == 1, 'Should have be called once'
|
|
|
|
|
|
def test_build_custom_context_menu(registry, state):
|
|
"""
|
|
Test the creation of a context menu from service item of type text from Custom.
|
|
"""
|
|
# GIVEN: A new service manager instance and a default service item.
|
|
mocked_renderer = MagicMock()
|
|
mocked_renderer.theme_level = ThemeLevel.Song
|
|
Registry().register('plugin_manager', MagicMock())
|
|
Registry().register('renderer', mocked_renderer)
|
|
service_manager = ServiceManager(None)
|
|
item = MagicMock()
|
|
item.parent.return_value = False
|
|
item.data.return_value = 0
|
|
service_manager.service_manager_list = MagicMock()
|
|
service_manager.service_manager_list.itemAt.return_value = item
|
|
service_item = ServiceItem(None)
|
|
service_item.add_capability(ItemCapabilities.CanEdit)
|
|
service_item.add_capability(ItemCapabilities.CanPreview)
|
|
service_item.add_capability(ItemCapabilities.CanLoop)
|
|
service_item.add_capability(ItemCapabilities.CanSoftBreak)
|
|
service_item.add_capability(ItemCapabilities.OnLoadUpdate)
|
|
service_item.service_item_type = ServiceItemType.Text
|
|
service_item.edit_id = 1
|
|
service_item._display_slides = []
|
|
service_item._display_slides.append(MagicMock())
|
|
service_manager.service_items.insert(1, {'service_item': service_item})
|
|
service_manager.edit_action = MagicMock()
|
|
service_manager.rename_action = MagicMock()
|
|
service_manager.create_custom_action = MagicMock()
|
|
service_manager.maintain_action = MagicMock()
|
|
service_manager.notes_action = MagicMock()
|
|
service_manager.time_action = MagicMock()
|
|
service_manager.auto_start_action = MagicMock()
|
|
service_manager.auto_play_slides_menu = MagicMock()
|
|
service_manager.auto_play_slides_once = MagicMock()
|
|
service_manager.auto_play_slides_loop = MagicMock()
|
|
service_manager.timed_slide_interval = MagicMock()
|
|
service_manager.theme_menu = MagicMock()
|
|
service_manager.menu = MagicMock()
|
|
# WHEN I define a context menu
|
|
service_manager.context_menu(1)
|
|
# THEN the following calls should have occurred.
|
|
assert service_manager.edit_action.setVisible.call_count == 2, 'Should have be called twice'
|
|
assert service_manager.rename_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.create_custom_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.maintain_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.notes_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.time_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_start_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_play_slides_menu.menuAction().setVisible.call_count == 1, \
|
|
'Should have be called once'
|
|
assert service_manager.auto_play_slides_once.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.auto_play_slides_loop.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.timed_slide_interval.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.theme_menu.menuAction().setVisible.call_count == 2, \
|
|
'Should have be called twice'
|
|
# THEN we add a 2nd display frame
|
|
service_item._display_slides.append(MagicMock())
|
|
service_manager.context_menu(1)
|
|
# THEN the following additional calls should have occurred.
|
|
assert service_manager.auto_play_slides_menu.menuAction().setVisible.call_count == 2, \
|
|
'Should have be called twice'
|
|
assert service_manager.auto_play_slides_once.setChecked.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_play_slides_loop.setChecked.call_count == 1, 'Should have be called once'
|
|
assert service_manager.timed_slide_interval.setChecked.call_count == 1, 'Should have be called once'
|
|
|
|
|
|
def test_build_image_context_menu(registry):
|
|
"""
|
|
Test the creation of a context menu from service item of type Image from Image.
|
|
"""
|
|
# GIVEN: A new service manager instance and a default service item.
|
|
Registry().register('plugin_manager', MagicMock())
|
|
Registry().register('renderer', MagicMock())
|
|
service_manager = ServiceManager(None)
|
|
item = MagicMock()
|
|
item.parent.return_value = False
|
|
item.data.return_value = 0
|
|
service_manager.service_manager_list = MagicMock()
|
|
service_manager.service_manager_list.itemAt.return_value = item
|
|
service_item = ServiceItem(None)
|
|
service_item.add_capability(ItemCapabilities.CanMaintain)
|
|
service_item.add_capability(ItemCapabilities.CanPreview)
|
|
service_item.add_capability(ItemCapabilities.CanLoop)
|
|
service_item.add_capability(ItemCapabilities.CanAppend)
|
|
service_item.add_capability(ItemCapabilities.CanEditTitle)
|
|
service_item.service_item_type = ServiceItemType.Image
|
|
service_item.edit_id = 1
|
|
service_item.slides.append(MagicMock())
|
|
service_manager.service_items.insert(1, {'service_item': service_item})
|
|
service_manager.edit_action = MagicMock()
|
|
service_manager.rename_action = MagicMock()
|
|
service_manager.create_custom_action = MagicMock()
|
|
service_manager.maintain_action = MagicMock()
|
|
service_manager.notes_action = MagicMock()
|
|
service_manager.time_action = MagicMock()
|
|
service_manager.auto_start_action = MagicMock()
|
|
service_manager.auto_play_slides_menu = MagicMock()
|
|
service_manager.auto_play_slides_once = MagicMock()
|
|
service_manager.auto_play_slides_loop = MagicMock()
|
|
service_manager.timed_slide_interval = MagicMock()
|
|
service_manager.theme_menu = MagicMock()
|
|
service_manager.menu = MagicMock()
|
|
# WHEN I define a context menu
|
|
service_manager.context_menu(1)
|
|
# THEN the following calls should have occurred.
|
|
assert service_manager.edit_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.rename_action.setVisible.call_count == 2, 'Should have be called twice'
|
|
assert service_manager.create_custom_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.maintain_action.setVisible.call_count == 2, 'Should have be called twice'
|
|
assert service_manager.notes_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.time_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_start_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_play_slides_menu.menuAction().setVisible.call_count == 1, \
|
|
'Should have be called once'
|
|
assert service_manager.auto_play_slides_once.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.auto_play_slides_loop.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.timed_slide_interval.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.theme_menu.menuAction().setVisible.call_count == 1, \
|
|
'Should have be called once'
|
|
# THEN we add a 2nd display frame and regenerate the menu.
|
|
service_item.slides.append(MagicMock())
|
|
service_manager.context_menu(1)
|
|
# THEN the following additional calls should have occurred.
|
|
assert service_manager.auto_play_slides_menu.menuAction().setVisible.call_count == 2, \
|
|
'Should have be called twice'
|
|
assert service_manager.auto_play_slides_once.setChecked.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_play_slides_loop.setChecked.call_count == 1, 'Should have be called once'
|
|
assert service_manager.timed_slide_interval.setChecked.call_count == 1, 'Should have be called once'
|
|
|
|
|
|
def test_build_media_context_menu(registry):
|
|
"""
|
|
Test the creation of a context menu from service item of type Command from Media.
|
|
"""
|
|
# GIVEN: A new service manager instance and a default service item.
|
|
Registry().register('plugin_manager', MagicMock())
|
|
Registry().register('renderer', MagicMock())
|
|
service_manager = ServiceManager(None)
|
|
item = MagicMock()
|
|
item.parent.return_value = False
|
|
item.data.return_value = 0
|
|
service_manager.service_manager_list = MagicMock()
|
|
service_manager.service_manager_list.itemAt.return_value = item
|
|
service_item = ServiceItem(None)
|
|
service_item.add_capability(ItemCapabilities.CanAutoStartForLive)
|
|
service_item.add_capability(ItemCapabilities.CanEditTitle)
|
|
service_item.add_capability(ItemCapabilities.RequiresMedia)
|
|
service_item.service_item_type = ServiceItemType.Command
|
|
service_item.edit_id = 1
|
|
service_item.slides.append(MagicMock())
|
|
service_manager.service_items.insert(1, {'service_item': service_item})
|
|
service_manager.edit_action = MagicMock()
|
|
service_manager.rename_action = MagicMock()
|
|
service_manager.create_custom_action = MagicMock()
|
|
service_manager.maintain_action = MagicMock()
|
|
service_manager.notes_action = MagicMock()
|
|
service_manager.time_action = MagicMock()
|
|
service_manager.auto_start_action = MagicMock()
|
|
service_manager.auto_play_slides_menu = MagicMock()
|
|
service_manager.auto_play_slides_once = MagicMock()
|
|
service_manager.auto_play_slides_loop = MagicMock()
|
|
service_manager.timed_slide_interval = MagicMock()
|
|
service_manager.theme_menu = MagicMock()
|
|
service_manager.menu = MagicMock()
|
|
# WHEN I define a context menu
|
|
service_manager.context_menu(1)
|
|
# THEN the following calls should have occurred.
|
|
assert service_manager.edit_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.rename_action.setVisible.call_count == 2, 'Should have be called twice'
|
|
assert service_manager.create_custom_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.maintain_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.notes_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.time_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_start_action.setVisible.call_count == 2, 'Should have be called twice'
|
|
assert service_manager.auto_play_slides_menu.menuAction().setVisible.call_count == 1, \
|
|
'Should have be called once'
|
|
assert service_manager.auto_play_slides_once.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.auto_play_slides_loop.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.timed_slide_interval.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.theme_menu.menuAction().setVisible.call_count == 1, \
|
|
'Should have be called once'
|
|
# THEN I change the length of the media and regenerate the menu.
|
|
service_item.set_media_length(5)
|
|
service_manager.context_menu(1)
|
|
# THEN the following additional calls should have occurred.
|
|
assert service_manager.time_action.setVisible.call_count == 3, 'Should have be called three times'
|
|
|
|
|
|
def test_build_presentation_pdf_context_menu(registry):
|
|
"""
|
|
Test the creation of a context menu from service item of type Command with PDF from Presentation.
|
|
"""
|
|
# GIVEN: A new service manager instance and a default service item.
|
|
Registry().register('plugin_manager', MagicMock())
|
|
Registry().register('renderer', MagicMock())
|
|
service_manager = ServiceManager(None)
|
|
item = MagicMock()
|
|
item.parent.return_value = False
|
|
item.data.return_value = 0
|
|
service_manager.service_manager_list = MagicMock()
|
|
service_manager.service_manager_list.itemAt.return_value = item
|
|
service_item = ServiceItem(None)
|
|
service_item.add_capability(ItemCapabilities.CanMaintain)
|
|
service_item.add_capability(ItemCapabilities.CanPreview)
|
|
service_item.add_capability(ItemCapabilities.CanLoop)
|
|
service_item.add_capability(ItemCapabilities.CanAppend)
|
|
service_item.service_item_type = ServiceItemType.Command
|
|
service_item.edit_id = 1
|
|
service_item.slides.append(MagicMock())
|
|
service_manager.service_items.insert(1, {'service_item': service_item})
|
|
service_manager.edit_action = MagicMock()
|
|
service_manager.rename_action = MagicMock()
|
|
service_manager.create_custom_action = MagicMock()
|
|
service_manager.maintain_action = MagicMock()
|
|
service_manager.notes_action = MagicMock()
|
|
service_manager.time_action = MagicMock()
|
|
service_manager.auto_start_action = MagicMock()
|
|
service_manager.auto_play_slides_menu = MagicMock()
|
|
service_manager.auto_play_slides_once = MagicMock()
|
|
service_manager.auto_play_slides_loop = MagicMock()
|
|
service_manager.timed_slide_interval = MagicMock()
|
|
service_manager.theme_menu = MagicMock()
|
|
service_manager.menu = MagicMock()
|
|
# WHEN I define a context menu
|
|
service_manager.context_menu(1)
|
|
# THEN the following calls should have occurred.
|
|
assert service_manager.edit_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.rename_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.create_custom_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.maintain_action.setVisible.call_count == 2, 'Should have be called twice'
|
|
assert service_manager.notes_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.time_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_start_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_play_slides_menu.menuAction().setVisible.call_count == 1, \
|
|
'Should have be called once'
|
|
assert service_manager.auto_play_slides_once.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.auto_play_slides_loop.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.timed_slide_interval.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.theme_menu.menuAction().setVisible.call_count == 1, \
|
|
'Should have be called once'
|
|
|
|
|
|
def test_build_presentation_non_pdf_context_menu(registry):
|
|
"""
|
|
Test the creation of a context menu from service item of type Command with Impress from Presentation.
|
|
"""
|
|
# GIVEN: A new service manager instance and a default service item.
|
|
Registry().register('plugin_manager', MagicMock())
|
|
Registry().register('renderer', MagicMock())
|
|
service_manager = ServiceManager(None)
|
|
item = MagicMock()
|
|
item.parent.return_value = False
|
|
item.data.return_value = 0
|
|
service_manager.service_manager_list = MagicMock()
|
|
service_manager.service_manager_list.itemAt.return_value = item
|
|
service_item = ServiceItem(None)
|
|
service_item.add_capability(ItemCapabilities.ProvidesOwnDisplay)
|
|
service_item.service_item_type = ServiceItemType.Command
|
|
service_item.edit_id = 1
|
|
service_item.slides.append(MagicMock())
|
|
service_manager.service_items.insert(1, {'service_item': service_item})
|
|
service_manager.edit_action = MagicMock()
|
|
service_manager.rename_action = MagicMock()
|
|
service_manager.create_custom_action = MagicMock()
|
|
service_manager.maintain_action = MagicMock()
|
|
service_manager.notes_action = MagicMock()
|
|
service_manager.time_action = MagicMock()
|
|
service_manager.auto_start_action = MagicMock()
|
|
service_manager.auto_play_slides_menu = MagicMock()
|
|
service_manager.auto_play_slides_once = MagicMock()
|
|
service_manager.auto_play_slides_loop = MagicMock()
|
|
service_manager.timed_slide_interval = MagicMock()
|
|
service_manager.theme_menu = MagicMock()
|
|
service_manager.menu = MagicMock()
|
|
# WHEN I define a context menu
|
|
service_manager.context_menu(1)
|
|
# THEN the following calls should have occurred.
|
|
assert service_manager.edit_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.rename_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.create_custom_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.maintain_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.notes_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.time_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_start_action.setVisible.call_count == 1, 'Should have be called once'
|
|
assert service_manager.auto_play_slides_menu.menuAction().setVisible.call_count == 1, \
|
|
'Should have be called once'
|
|
assert service_manager.auto_play_slides_once.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.auto_play_slides_loop.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.timed_slide_interval.setChecked.call_count == 0, 'Should not be called'
|
|
assert service_manager.theme_menu.menuAction().setVisible.call_count == 1, \
|
|
'Should have be called once'
|
|
|
|
|
|
@patch('PyQt5.QtCore.QTimer.singleShot')
|
|
def test_single_click_preview_true(mocked_singleShot, registry):
|
|
"""
|
|
Test that when "Preview items when clicked in Service Manager" enabled the preview timer starts
|
|
"""
|
|
# GIVEN: A setting to enable "Preview items when clicked in Service Manager" and a service manager.
|
|
mocked_settings = MagicMock()
|
|
mocked_settings.value.return_value = True
|
|
Registry().register('settings', mocked_settings)
|
|
service_manager = ServiceManager(None)
|
|
# WHEN: on_single_click_preview() is called
|
|
service_manager.on_single_click_preview()
|
|
# THEN: timer should have been started
|
|
mocked_singleShot.assert_called_with(PyQt5.QtWidgets.QApplication.instance().doubleClickInterval(),
|
|
service_manager.on_single_click_preview_timeout)
|
|
|
|
|
|
@patch('PyQt5.QtCore.QTimer.singleShot')
|
|
def test_single_click_preview_false(mocked_singleShot, registry):
|
|
"""
|
|
Test that when "Preview items when clicked in Service Manager" disabled the preview timer doesn't start
|
|
"""
|
|
# GIVEN: A setting to enable "Preview items when clicked in Service Manager" and a service manager.
|
|
mocked_settings = MagicMock()
|
|
mocked_settings.value.return_value = False
|
|
Registry().register('settings', mocked_settings)
|
|
service_manager = ServiceManager(None)
|
|
# WHEN: on_single_click_preview() is called
|
|
service_manager.on_single_click_preview()
|
|
# THEN: timer should not be started
|
|
assert mocked_singleShot.call_count == 0, 'Should not be called'
|
|
|
|
|
|
@patch('PyQt5.QtCore.QTimer.singleShot')
|
|
@patch('openlp.core.ui.servicemanager.ServiceManager.make_live')
|
|
def test_single_click_preview_double(mocked_make_live, mocked_singleShot, registry):
|
|
"""
|
|
Test that when a double click has registered the preview timer doesn't start
|
|
"""
|
|
# GIVEN: A setting to enable "Preview items when clicked in Service Manager" and a service manager.
|
|
mocked_settings = MagicMock()
|
|
mocked_settings.value.return_value = True
|
|
Registry().register('settings', mocked_settings)
|
|
service_manager = ServiceManager(None)
|
|
# WHEN: on_single_click_preview() is called following a double click
|
|
service_manager.on_double_click_live()
|
|
service_manager.on_single_click_preview()
|
|
# THEN: timer should not be started
|
|
mocked_make_live.assert_called_with()
|
|
assert mocked_singleShot.call_count == 0, 'Should not be called'
|
|
|
|
|
|
@patch('openlp.core.ui.servicemanager.ServiceManager.make_preview')
|
|
def test_single_click_timeout_single(mocked_make_preview, registry):
|
|
"""
|
|
Test that when a single click has been registered, the item is sent to preview
|
|
"""
|
|
# GIVEN: A service manager.
|
|
service_manager = ServiceManager(None)
|
|
# WHEN: on_single_click_preview() is called
|
|
service_manager.on_single_click_preview_timeout()
|
|
# THEN: make_preview() should have been called
|
|
assert mocked_make_preview.call_count == 1, 'ServiceManager.make_preview() should have been called once'
|
|
|
|
|
|
@patch('openlp.core.ui.servicemanager.ServiceManager.make_preview')
|
|
@patch('openlp.core.ui.servicemanager.ServiceManager.make_live')
|
|
def test_single_click_timeout_double(mocked_make_live, mocked_make_preview, registry):
|
|
"""
|
|
Test that when a double click has been registered, the item does not goes to preview
|
|
"""
|
|
# GIVEN: A service manager.
|
|
service_manager = ServiceManager(None)
|
|
# WHEN: on_single_click_preview() is called after a double click
|
|
service_manager.on_double_click_live()
|
|
service_manager.on_single_click_preview_timeout()
|
|
# THEN: make_preview() should not have been called
|
|
assert mocked_make_preview.call_count == 0, 'ServiceManager.make_preview() should not be called'
|
|
|
|
|
|
@patch('openlp.core.ui.servicemanager.zipfile')
|
|
@patch('openlp.core.ui.servicemanager.ServiceManager.save_file_as')
|
|
@patch('openlp.core.ui.servicemanager.os')
|
|
def test_save_file_raises_permission_error(mocked_os, mocked_save_file_as, mocked_zipfile, registry):
|
|
"""
|
|
Test that when a PermissionError is raised when trying to save a file, it is handled correctly
|
|
"""
|
|
# GIVEN: A service manager, a service to save
|
|
mocked_main_window = MagicMock()
|
|
Registry().register('main_window', mocked_main_window)
|
|
Registry().register('application', MagicMock())
|
|
service_manager = ServiceManager(None)
|
|
service_manager._service_path = MagicMock()
|
|
service_manager._save_lite = False
|
|
service_manager.service_items = []
|
|
service_manager.service_theme = 'Default'
|
|
service_manager.service_manager_list = MagicMock()
|
|
mocked_save_file_as.return_value = True
|
|
mocked_zipfile.ZipFile.return_value = MagicMock()
|
|
mocked_os.link.side_effect = PermissionError
|
|
|
|
# WHEN: The service is saved and a PermissionError is raised
|
|
result = service_manager.save_file()
|
|
|
|
# THEN: The "save_as" method is called to save the service
|
|
assert result is True
|
|
mocked_save_file_as.assert_called_with()
|
|
|
|
|
|
@patch('openlp.core.ui.servicemanager.zipfile')
|
|
@patch('openlp.core.ui.servicemanager.ServiceManager.save_file_as')
|
|
@patch('openlp.core.ui.servicemanager.os')
|
|
@patch('openlp.core.ui.servicemanager.len')
|
|
def test_save_file_large_file(mocked_len, mocked_os, mocked_save_file_as, mocked_zipfile, registry):
|
|
"""
|
|
Test that when a file size size larger than a 32bit signed int is attempted to save, the progress bar
|
|
should be provided a value that fits in a 32bit int (because it's passed to C++ as a 32bit unsigned int)
|
|
"""
|
|
# GIVEN: A service manager, a service to save, and len() returns a huge value (file size)
|
|
def check_for_i32_overflow(val):
|
|
if val > 2147483647:
|
|
raise OverflowError
|
|
mocked_main_window = MagicMock()
|
|
mocked_main_window.display_progress_bar.side_effect = check_for_i32_overflow
|
|
Registry().register('main_window', mocked_main_window)
|
|
Registry().register('application', MagicMock())
|
|
mocked_settings = MagicMock()
|
|
Registry().register('settings', mocked_settings)
|
|
service_manager = ServiceManager(None)
|
|
service_manager._service_path = MagicMock()
|
|
service_manager._save_lite = False
|
|
service_manager.service_items = []
|
|
service_manager.service_theme = 'Default'
|
|
service_manager.service_manager_list = MagicMock()
|
|
mocked_save_file_as.return_value = True
|
|
mocked_zipfile.ZipFile.return_value = MagicMock()
|
|
mocked_len.return_value = 10000000000000
|
|
|
|
# WHEN: The service is saved and no error is raised
|
|
result = service_manager.save_file()
|
|
|
|
# THEN: The "save_as" method is called to save the service
|
|
assert result is True
|
|
mocked_save_file_as.assert_called_with()
|
|
|
|
|
|
@patch('openlp.core.ui.servicemanager.ServiceManager.regenerate_service_items')
|
|
def test_theme_change_global(mocked_regenerate_service_items, registry):
|
|
"""
|
|
Test that when a Toolbar theme combobox displays correctly when the theme is set to Global
|
|
"""
|
|
# GIVEN: A service manager, settings set to Global theme
|
|
service_manager = ServiceManager(None)
|
|
service_manager.toolbar = OpenLPToolbar(None)
|
|
service_manager.toolbar.add_toolbar_action('theme_combo_box', triggers=MagicMock())
|
|
service_manager.toolbar.add_toolbar_action('theme_label', triggers=MagicMock())
|
|
mocked_settings = MagicMock()
|
|
mocked_settings.value.return_value = ThemeLevel.Global
|
|
Registry().register('settings', mocked_settings)
|
|
|
|
# WHEN: theme_change is called
|
|
service_manager.theme_change()
|
|
|
|
# THEN: The the theme toolbar should not be visible
|
|
assert service_manager.toolbar.actions['theme_combo_box'].isVisible() is False, \
|
|
'The visibility should be False'
|
|
|
|
|
|
@patch('openlp.core.ui.servicemanager.ServiceManager.regenerate_service_items')
|
|
def test_theme_change_service(mocked_regenerate_service_items, registry):
|
|
"""
|
|
Test that when a Toolbar theme combobox displays correctly when the theme is set to Theme
|
|
"""
|
|
# GIVEN: A service manager, settings set to Service theme
|
|
service_manager = ServiceManager(None)
|
|
service_manager.toolbar = OpenLPToolbar(None)
|
|
service_manager.toolbar.add_toolbar_action('theme_combo_box', triggers=MagicMock())
|
|
service_manager.toolbar.add_toolbar_action('theme_label', triggers=MagicMock())
|
|
mocked_settings = MagicMock()
|
|
mocked_settings.value.return_value = ThemeLevel.Service
|
|
Registry().register('settings', mocked_settings)
|
|
|
|
# WHEN: theme_change is called
|
|
service_manager.theme_change()
|
|
|
|
# THEN: The the theme toolbar should be visible
|
|
assert service_manager.toolbar.actions['theme_combo_box'].isVisible() is True, \
|
|
'The visibility should be True'
|
|
|
|
|
|
@patch('openlp.core.ui.servicemanager.ServiceManager.regenerate_service_items')
|
|
def test_theme_change_song(mocked_regenerate_service_items, registry):
|
|
"""
|
|
Test that when a Toolbar theme combobox displays correctly when the theme is set to Song
|
|
"""
|
|
# GIVEN: A service manager, settings set to Song theme
|
|
service_manager = ServiceManager(None)
|
|
service_manager.toolbar = OpenLPToolbar(None)
|
|
service_manager.toolbar.add_toolbar_action('theme_combo_box', triggers=MagicMock())
|
|
service_manager.toolbar.add_toolbar_action('theme_label', triggers=MagicMock())
|
|
mocked_settings = MagicMock()
|
|
mocked_settings.value.return_value = ThemeLevel.Song
|
|
Registry().register('settings', mocked_settings)
|
|
|
|
# WHEN: theme_change is called
|
|
service_manager.theme_change()
|
|
|
|
# THEN: The the theme toolbar should be visible
|
|
assert service_manager.toolbar.actions['theme_combo_box'].isVisible() is True, \
|
|
'The visibility should be True'
|