forked from openlp/openlp
fix tests
This commit is contained in:
parent
7fbeb10207
commit
cad03b9abd
@ -26,7 +26,6 @@ import os
|
|||||||
import logging
|
import logging
|
||||||
import json
|
import json
|
||||||
|
|
||||||
from xml.dom.minidom import Document
|
|
||||||
from lxml import etree, objectify
|
from lxml import etree, objectify
|
||||||
from openlp.core.common import AppLocation, de_hump
|
from openlp.core.common import AppLocation, de_hump
|
||||||
|
|
||||||
@ -195,184 +194,6 @@ class Theme(object):
|
|||||||
self.background_filename = self.background_filename.strip()
|
self.background_filename = self.background_filename.strip()
|
||||||
self.background_filename = os.path.join(path, self.theme_name, self.background_filename)
|
self.background_filename = os.path.join(path, self.theme_name, self.background_filename)
|
||||||
|
|
||||||
# def _new_document(self, name):
|
|
||||||
# """
|
|
||||||
# Create a new theme XML document.
|
|
||||||
# """
|
|
||||||
# self.theme_xml = Document()
|
|
||||||
# self.theme = self.theme_xml.createElement('theme')
|
|
||||||
# self.theme_xml.appendChild(self.theme)
|
|
||||||
# self.theme.setAttribute('version', '2.0')
|
|
||||||
# self.name = self.theme_xml.createElement('name')
|
|
||||||
# text_node = self.theme_xml.createTextNode(name)
|
|
||||||
# self.name.appendChild(text_node)
|
|
||||||
# self.theme.appendChild(self.name)
|
|
||||||
|
|
||||||
# def add_background_transparent(self):
|
|
||||||
# """
|
|
||||||
# Add a transparent background.
|
|
||||||
# """
|
|
||||||
# background = self.theme_xml.createElement('background')
|
|
||||||
# background.setAttribute('type', 'transparent')
|
|
||||||
# self.theme.appendChild(background)
|
|
||||||
|
|
||||||
# def add_background_solid(self, bkcolor):
|
|
||||||
# """
|
|
||||||
# Add a Solid background.
|
|
||||||
#
|
|
||||||
# :param bkcolor: The color of the background.
|
|
||||||
# """
|
|
||||||
# background = self.theme_xml.createElement('background')
|
|
||||||
# background.setAttribute('type', 'solid')
|
|
||||||
# self.theme.appendChild(background)
|
|
||||||
# self.child_element(background, 'color', str(bkcolor))
|
|
||||||
|
|
||||||
# def add_background_gradient(self, startcolor, endcolor, direction):
|
|
||||||
# """
|
|
||||||
# Add a gradient background.
|
|
||||||
#
|
|
||||||
# :param startcolor: The gradient's starting colour.
|
|
||||||
# :param endcolor: The gradient's ending colour.
|
|
||||||
# :param direction: The direction of the gradient.
|
|
||||||
# """
|
|
||||||
# background = self.theme_xml.createElement('background')
|
|
||||||
# background.setAttribute('type', 'gradient')
|
|
||||||
# self.theme.appendChild(background)
|
|
||||||
# # Create startColor element
|
|
||||||
# self.child_element(background, 'startColor', str(startcolor))
|
|
||||||
# # Create endColor element
|
|
||||||
# self.child_element(background, 'endColor', str(endcolor))
|
|
||||||
# # Create direction element
|
|
||||||
# self.child_element(background, 'direction', str(direction))
|
|
||||||
|
|
||||||
# def add_background_image(self, filename, border_color):
|
|
||||||
# """
|
|
||||||
# Add a image background.
|
|
||||||
#
|
|
||||||
# :param filename: The file name of the image.
|
|
||||||
# :param border_color:
|
|
||||||
# """
|
|
||||||
# background = self.theme_xml.createElement('background')
|
|
||||||
# background.setAttribute('type', 'image')
|
|
||||||
# self.theme.appendChild(background)
|
|
||||||
# # Create Filename element
|
|
||||||
# self.child_element(background, 'filename', filename)
|
|
||||||
# # Create endColor element
|
|
||||||
# self.child_element(background, 'borderColor', str(border_color))
|
|
||||||
#
|
|
||||||
# def add_background_video(self, filename, border_color):
|
|
||||||
# """
|
|
||||||
# Add a video background.
|
|
||||||
#
|
|
||||||
# :param filename: The file name of the video.
|
|
||||||
# :param border_color:
|
|
||||||
# """
|
|
||||||
# background = self.theme_xml.createElement('background')
|
|
||||||
# background.setAttribute('type', 'video')
|
|
||||||
# self.theme.appendChild(background)
|
|
||||||
# # Create Filename element
|
|
||||||
# self.child_element(background, 'filename', filename)
|
|
||||||
# # Create endColor element
|
|
||||||
# self.child_element(background, 'borderColor', str(border_color))
|
|
||||||
|
|
||||||
# def add_font(self, name, color, size, override, fonttype='main', bold='False', italics='False',
|
|
||||||
# line_adjustment=0, xpos=0, ypos=0, width=0, height=0, outline='False', outline_color='#ffffff',
|
|
||||||
# outline_pixel=2, shadow='False', shadow_color='#ffffff', shadow_pixel=5):
|
|
||||||
# """
|
|
||||||
# Add a Font.
|
|
||||||
#
|
|
||||||
# :param name: The name of the font.
|
|
||||||
# :param color: The colour of the font.
|
|
||||||
# :param size: The size of the font.
|
|
||||||
# :param override: Whether or not to override the default positioning of the theme.
|
|
||||||
# :param fonttype: The type of font, ``main`` or ``footer``. Defaults to ``main``.
|
|
||||||
# :param bold:
|
|
||||||
# :param italics: The weight of then font Defaults to 50 Normal
|
|
||||||
# :param line_adjustment: Does the font render to italics Defaults to 0 Normal
|
|
||||||
# :param xpos: The X position of the text block.
|
|
||||||
# :param ypos: The Y position of the text block.
|
|
||||||
# :param width: The width of the text block.
|
|
||||||
# :param height: The height of the text block.
|
|
||||||
# :param outline: Whether or not to show an outline.
|
|
||||||
# :param outline_color: The colour of the outline.
|
|
||||||
# :param outline_pixel: How big the Shadow is
|
|
||||||
# :param shadow: Whether or not to show a shadow.
|
|
||||||
# :param shadow_color: The colour of the shadow.
|
|
||||||
# :param shadow_pixel: How big the Shadow is
|
|
||||||
# """
|
|
||||||
# background = self.theme_xml.createElement('font')
|
|
||||||
# background.setAttribute('type', fonttype)
|
|
||||||
# self.theme.appendChild(background)
|
|
||||||
# # Create Font name element
|
|
||||||
# self.child_element(background, 'name', name)
|
|
||||||
# # Create Font color element
|
|
||||||
# self.child_element(background, 'color', str(color))
|
|
||||||
# # Create Proportion name element
|
|
||||||
# self.child_element(background, 'size', str(size))
|
|
||||||
# # Create weight name element
|
|
||||||
# self.child_element(background, 'bold', str(bold))
|
|
||||||
# # Create italics name element
|
|
||||||
# self.child_element(background, 'italics', str(italics))
|
|
||||||
# # Create indentation name element
|
|
||||||
# self.child_element(background, 'line_adjustment', str(line_adjustment))
|
|
||||||
# # Create Location element
|
|
||||||
# element = self.theme_xml.createElement('location')
|
|
||||||
# element.setAttribute('override', str(override))
|
|
||||||
# element.setAttribute('x', str(xpos))
|
|
||||||
# element.setAttribute('y', str(ypos))
|
|
||||||
# element.setAttribute('width', str(width))
|
|
||||||
# element.setAttribute('height', str(height))
|
|
||||||
# background.appendChild(element)
|
|
||||||
# # Shadow
|
|
||||||
# element = self.theme_xml.createElement('shadow')
|
|
||||||
# element.setAttribute('shadowColor', str(shadow_color))
|
|
||||||
# element.setAttribute('shadowSize', str(shadow_pixel))
|
|
||||||
# value = self.theme_xml.createTextNode(str(shadow))
|
|
||||||
# element.appendChild(value)
|
|
||||||
# background.appendChild(element)
|
|
||||||
# # Outline
|
|
||||||
# element = self.theme_xml.createElement('outline')
|
|
||||||
# element.setAttribute('outlineColor', str(outline_color))
|
|
||||||
# element.setAttribute('outlineSize', str(outline_pixel))
|
|
||||||
# value = self.theme_xml.createTextNode(str(outline))
|
|
||||||
# element.appendChild(value)
|
|
||||||
# background.appendChild(element)
|
|
||||||
#
|
|
||||||
# def add_display(self, horizontal, vertical, transition):
|
|
||||||
# """
|
|
||||||
# Add a Display options.
|
|
||||||
#
|
|
||||||
# :param horizontal: The horizontal alignment of the text.
|
|
||||||
# :param vertical: The vertical alignment of the text.
|
|
||||||
# :param transition: Whether the slide transition is active.
|
|
||||||
# """
|
|
||||||
# background = self.theme_xml.createElement('display')
|
|
||||||
# self.theme.appendChild(background)
|
|
||||||
# # Horizontal alignment
|
|
||||||
# element = self.theme_xml.createElement('horizontalAlign')
|
|
||||||
# value = self.theme_xml.createTextNode(str(horizontal))
|
|
||||||
# element.appendChild(value)
|
|
||||||
# background.appendChild(element)
|
|
||||||
# # Vertical alignment
|
|
||||||
# element = self.theme_xml.createElement('verticalAlign')
|
|
||||||
# value = self.theme_xml.createTextNode(str(vertical))
|
|
||||||
# element.appendChild(value)
|
|
||||||
# background.appendChild(element)
|
|
||||||
# # Slide Transition
|
|
||||||
# element = self.theme_xml.createElement('slideTransition')
|
|
||||||
# value = self.theme_xml.createTextNode(str(transition))
|
|
||||||
# element.appendChild(value)
|
|
||||||
# background.appendChild(element)
|
|
||||||
#
|
|
||||||
# def child_element(self, element, tag, value):
|
|
||||||
# """
|
|
||||||
# Generic child element creator.
|
|
||||||
# """
|
|
||||||
# child = self.theme_xml.createElement(tag)
|
|
||||||
# child.appendChild(self.theme_xml.createTextNode(value))
|
|
||||||
# element.appendChild(child)
|
|
||||||
# return child
|
|
||||||
|
|
||||||
def set_default_header_footer(self):
|
def set_default_header_footer(self):
|
||||||
"""
|
"""
|
||||||
Set the header and footer size into the current primary screen.
|
Set the header and footer size into the current primary screen.
|
||||||
@ -386,26 +207,6 @@ class Theme(object):
|
|||||||
self.font_footer_y = current_screen['size'].height() * 9 / 10
|
self.font_footer_y = current_screen['size'].height() * 9 / 10
|
||||||
self.font_footer_height = current_screen['size'].height() / 10
|
self.font_footer_height = current_screen['size'].height() / 10
|
||||||
|
|
||||||
# def dump_xml(self):
|
|
||||||
# """
|
|
||||||
# Dump the XML to file used for debugging
|
|
||||||
# """
|
|
||||||
# return self.theme_xml.toprettyxml(indent=' ')
|
|
||||||
|
|
||||||
# def extract_xml(self):
|
|
||||||
# """
|
|
||||||
# Print out the XML string.
|
|
||||||
# """
|
|
||||||
# self._build_xml_from_attrs()
|
|
||||||
# return self.theme_xml.toxml('utf-8').decode('utf-8')
|
|
||||||
#
|
|
||||||
# def extract_formatted_xml(self):
|
|
||||||
# """
|
|
||||||
# Pull out the XML string formatted for human consumption
|
|
||||||
# """
|
|
||||||
# self._build_xml_from_attrs()
|
|
||||||
# return self.theme_xml.toprettyxml(indent=' ', newl='\n', encoding='utf-8')
|
|
||||||
|
|
||||||
def load_theme(self, theme):
|
def load_theme(self, theme):
|
||||||
"""
|
"""
|
||||||
Pull out the XML string formatted for human consumption
|
Pull out the XML string formatted for human consumption
|
||||||
@ -526,68 +327,3 @@ class Theme(object):
|
|||||||
if key[0:1] != '_':
|
if key[0:1] != '_':
|
||||||
theme_strings.append('{key:>30}: {value}'.format(key=key, value=getattr(self, key)))
|
theme_strings.append('{key:>30}: {value}'.format(key=key, value=getattr(self, key)))
|
||||||
return '\n'.join(theme_strings)
|
return '\n'.join(theme_strings)
|
||||||
|
|
||||||
# def _build_xml_from_attrs(self):
|
|
||||||
# """
|
|
||||||
# Build the XML from the varables in the object
|
|
||||||
# """
|
|
||||||
# self._new_document(self.theme_name)
|
|
||||||
# if self.background_type == BackgroundType.to_string(BackgroundType.Solid):
|
|
||||||
# self.add_background_solid(self.background_color)
|
|
||||||
# elif self.background_type == BackgroundType.to_string(BackgroundType.Gradient):
|
|
||||||
# self.add_background_gradient(
|
|
||||||
# self.background_start_color,
|
|
||||||
# self.background_end_color,
|
|
||||||
# self.background_direction
|
|
||||||
# )
|
|
||||||
# elif self.background_type == BackgroundType.to_string(BackgroundType.Image):
|
|
||||||
# filename = os.path.split(self.background_filename)[1]
|
|
||||||
# self.add_background_image(filename, self.background_border_color)
|
|
||||||
# elif self.background_type == BackgroundType.to_string(BackgroundType.Video):
|
|
||||||
# filename = os.path.split(self.background_filename)[1]
|
|
||||||
# self.add_background_video(filename, self.background_border_color)
|
|
||||||
# elif self.background_type == BackgroundType.to_string(BackgroundType.Transparent):
|
|
||||||
# self.add_background_transparent()
|
|
||||||
# self.add_font(
|
|
||||||
# self.font_main_name,
|
|
||||||
# self.font_main_color,
|
|
||||||
# self.font_main_size,
|
|
||||||
# self.font_main_override, 'main',
|
|
||||||
# self.font_main_bold,
|
|
||||||
# self.font_main_italics,
|
|
||||||
# self.font_main_line_adjustment,
|
|
||||||
# self.font_main_x,
|
|
||||||
# self.font_main_y,
|
|
||||||
# self.font_main_width,
|
|
||||||
# self.font_main_height,
|
|
||||||
# self.font_main_outline,
|
|
||||||
# self.font_main_outline_color,
|
|
||||||
# self.font_main_outline_size,
|
|
||||||
# self.font_main_shadow,
|
|
||||||
# self.font_main_shadow_color,
|
|
||||||
# self.font_main_shadow_size
|
|
||||||
# )
|
|
||||||
# self.add_font(
|
|
||||||
# self.font_footer_name,
|
|
||||||
# self.font_footer_color,
|
|
||||||
# self.font_footer_size,
|
|
||||||
# self.font_footer_override, 'footer',
|
|
||||||
# self.font_footer_bold,
|
|
||||||
# self.font_footer_italics,
|
|
||||||
# 0, # line adjustment
|
|
||||||
# self.font_footer_x,
|
|
||||||
# self.font_footer_y,
|
|
||||||
# self.font_footer_width,
|
|
||||||
# self.font_footer_height,
|
|
||||||
# self.font_footer_outline,
|
|
||||||
# self.font_footer_outline_color,
|
|
||||||
# self.font_footer_outline_size,
|
|
||||||
# self.font_footer_shadow,
|
|
||||||
# self.font_footer_shadow_color,
|
|
||||||
# self.font_footer_shadow_size
|
|
||||||
# )
|
|
||||||
# self.add_display(
|
|
||||||
# self.display_horizontal_align,
|
|
||||||
# self.display_vertical_align,
|
|
||||||
# self.display_slide_transition
|
|
||||||
# )
|
|
||||||
|
@ -32,7 +32,7 @@ from openlp.core.lib.theme import Theme
|
|||||||
|
|
||||||
class TestTheme(TestCase):
|
class TestTheme(TestCase):
|
||||||
"""
|
"""
|
||||||
Test the ThemeL class
|
Test the Theme class
|
||||||
"""
|
"""
|
||||||
def test_new_theme(self):
|
def test_new_theme(self):
|
||||||
"""
|
"""
|
||||||
|
37
tests/functional/openlp_core_ui_lib/test_thememanager.py
Normal file
37
tests/functional/openlp_core_ui_lib/test_thememanager.py
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
# -*- 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 #
|
||||||
|
###############################################################################
|
||||||
|
"""
|
||||||
|
Package to test the openlp.core.ui.lib.theme package.
|
||||||
|
"""
|
||||||
|
import json
|
||||||
|
from unittest import TestCase
|
||||||
|
import os
|
||||||
|
|
||||||
|
from openlp.core.common import json_default
|
||||||
|
from openlp.core.lib.theme import Theme
|
||||||
|
|
||||||
|
|
||||||
|
class TestThemeManager(TestCase):
|
||||||
|
"""
|
||||||
|
Test the ThemeManager class
|
||||||
|
"""
|
||||||
|
|
Loading…
Reference in New Issue
Block a user