forked from openlp/openlp
95 lines
4.9 KiB
Python
95 lines
4.9 KiB
Python
# -*- coding: utf-8 -*-
|
|
# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4
|
|
|
|
###############################################################################
|
|
# 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; 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 #
|
|
###############################################################################
|
|
"""
|
|
This module contains tests for the SongFormat class
|
|
"""
|
|
from unittest import TestCase
|
|
|
|
from openlp.plugins.songs.lib.importer import SongFormat
|
|
|
|
|
|
class TestSongFormat(TestCase):
|
|
"""
|
|
Test the functions in the :class:`SongFormat` class.
|
|
"""
|
|
|
|
def test_get_format_list(self):
|
|
"""
|
|
Test that get_format_list() returns all available formats
|
|
"""
|
|
# GIVEN: The SongFormat class
|
|
# WHEN: Retrieving the format list
|
|
# THEN: All SongFormats should be returned
|
|
assert len(SongFormat.get_format_list()) == len(SongFormat.__attributes__), \
|
|
"The returned SongFormats don't match the stored ones"
|
|
|
|
def test_get_attributed_no_attributes(self):
|
|
"""
|
|
Test that SongFormat.get(song_format) returns all attributes associated with the given song_format
|
|
"""
|
|
# GIVEN: A SongFormat
|
|
# WHEN: Retrieving all attributes of a SongFormat
|
|
for song_format in SongFormat.get_format_list():
|
|
# THEN: All attributes associated with the SongFormat should be returned
|
|
assert SongFormat.get(song_format) == SongFormat.__attributes__[song_format], \
|
|
"The returned attributes don't match the stored ones"
|
|
|
|
def test_get_attributed_single_attribute(self):
|
|
"""
|
|
Test that SongFormat.get(song_format, attribute) returns only one -and the correct- attribute
|
|
"""
|
|
# GIVEN: A SongFormat
|
|
for song_format in SongFormat.get_format_list():
|
|
# WHEN: Retrieving an attribute that overrides the default values
|
|
for attribute in SongFormat.get(song_format).keys():
|
|
# THEN: Return the attribute
|
|
assert SongFormat.get(song_format, attribute) == SongFormat.get(song_format)[attribute], \
|
|
"The returned attribute doesn't match the stored one"
|
|
# WHEN: Retrieving an attribute that was not overridden
|
|
for attribute in SongFormat.__defaults__.keys():
|
|
if attribute not in SongFormat.get(song_format).keys():
|
|
# THEN: Return the default value
|
|
assert SongFormat.get(song_format, attribute) == SongFormat.__defaults__[attribute], \
|
|
"The returned attribute does not match the default values stored"
|
|
|
|
def test_get_attributed_multiple_attributes(self):
|
|
"""
|
|
Test that multiple attributes can be retrieved for a song_format
|
|
"""
|
|
# GIVEN: A SongFormat
|
|
# WHEN: Retrieving multiple attributes at the same time
|
|
for song_format in SongFormat.get_format_list():
|
|
# THEN: Return all attributes that were specified
|
|
assert len(SongFormat.get(song_format, 'canDisable', 'availability')) == 2, \
|
|
"Did not return the correct number of attributes when retrieving multiple attributes at once"
|
|
|
|
def test_get_format_list_returns_ordered_list(self):
|
|
"""
|
|
Test that get_format_list() returns a list that is ordered
|
|
according to the order specified in SongFormat
|
|
"""
|
|
# GIVEN: The SongFormat class
|
|
# WHEN: Retrieving all formats
|
|
# THEN: The returned list should be sorted according to the ordering defined in SongFormat
|
|
assert sorted(SongFormat.get_format_list()) == SongFormat.get_format_list(), \
|
|
"The list returned should be sorted according to the ordering in SongFormat"
|