# -*- coding: utf-8 -*- ########################################################################## # OpenLP - Open Source Lyrics Projection # # ---------------------------------------------------------------------- # # Copyright (c) 2008-2019 OpenLP Developers # # ---------------------------------------------------------------------- # # This program is 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 . # ########################################################################## """ Package to test the openlp.core.lib.theme package. """ from pathlib import Path from unittest import TestCase from openlp.core.lib.theme import BackgroundType, Theme class TestBackgroundType(TestCase): """ Test the BackgroundType enum methods. """ def test_solid_to_string(self): """ Test the to_string method of :class:`BackgroundType` """ # GIVEN: A BackgroundType member background_type = BackgroundType.Solid # WHEN: Calling BackgroundType.to_string # THEN: The string equivalent should have been returned assert BackgroundType.to_string(background_type) == 'solid' def test_gradient_to_string(self): """ Test the to_string method of :class:`BackgroundType` """ # GIVEN: A BackgroundType member background_type = BackgroundType.Gradient # WHEN: Calling BackgroundType.to_string # THEN: The string equivalent should have been returned assert BackgroundType.to_string(background_type) == 'gradient' def test_image_to_string(self): """ Test the to_string method of :class:`BackgroundType` """ # GIVEN: A BackgroundType member background_type = BackgroundType.Image # WHEN: Calling BackgroundType.to_string # THEN: The string equivalent should have been returned assert BackgroundType.to_string(background_type) == 'image' def test_transparent_to_string(self): """ Test the to_string method of :class:`BackgroundType` """ # GIVEN: A BackgroundType member background_type = BackgroundType.Transparent # WHEN: Calling BackgroundType.to_string # THEN: The string equivalent should have been returned assert BackgroundType.to_string(background_type) == 'transparent' def test_video_to_string(self): """ Test the to_string method of :class:`BackgroundType` """ # GIVEN: A BackgroundType member background_type = BackgroundType.Video # WHEN: Calling BackgroundType.to_string # THEN: The string equivalent should have been returned assert BackgroundType.to_string(background_type) == 'video' def test_stream_to_string(self): """ Test the to_string method of :class:`BackgroundType` """ # GIVEN: A BackgroundType member background_type = BackgroundType.Stream # WHEN: Calling BackgroundType.to_string # THEN: The string equivalent should have been returned assert BackgroundType.to_string(background_type) == 'stream' class TestTheme(TestCase): """ Test the Theme class """ def test_new_theme(self): """ Test the Theme constructor """ # GIVEN: The Theme class # WHEN: A theme object is created default_theme = Theme() # THEN: The default values should be correct self.check_theme(default_theme) def test_expand_json(self): """ Test the expand_json method """ # GIVEN: A Theme object and some JSON to "expand" theme = Theme() theme_json = { 'background': { 'border_color': '#000000', 'type': 'solid' }, 'display': { 'vertical_align': 0 }, 'font': { 'footer': { 'bold': False }, 'main': { 'name': 'Arial' } } } # WHEN: Theme.expand_json() is run theme.expand_json(theme_json) # THEN: The attributes should be set on the object self.check_theme(theme) def test_extend_image_filename(self): """ Test the extend_image_filename method """ # GIVEN: A theme object theme = Theme() theme.theme_name = 'MyBeautifulTheme' theme.background_filename = Path('video.mp4') theme.background_type = 'video' path = Path.home() # WHEN: Theme.extend_image_filename is run theme.extend_image_filename(path) # THEN: The filename of the background should be correct expected_filename = path / 'MyBeautifulTheme' / 'video.mp4' assert expected_filename == theme.background_filename assert 'MyBeautifulTheme' == theme.theme_name def test_save_retrieve(self): """ Load a dummy theme, save it and reload it """ # GIVEN: The default Theme class # WHEN: A theme object is created default_theme = Theme() # THEN: The default values should be correct save_theme_json = default_theme.export_theme() lt = Theme() lt.load_theme(save_theme_json) self.check_theme(lt) def check_theme(self, theme): assert '#000000' == theme.background_border_color, 'background_border_color should be "#000000"' assert 'solid' == theme.background_type, 'background_type should be "solid"' assert 0 == theme.display_vertical_align, 'display_vertical_align should be 0' assert theme.font_footer_bold is False, 'font_footer_bold should be False' assert 'Arial' == theme.font_main_name, 'font_main_name should be "Arial"' assert 51 == len(theme.__dict__), 'The theme should have 51 attributes'