forked from openlp/openlp
Expanded the tests.
This commit is contained in:
parent
8a4f143878
commit
ee6495e08f
@ -4,7 +4,7 @@ Functional tests to test the AppLocation class and related methods.
|
|||||||
import sys
|
import sys
|
||||||
from unittest import TestCase
|
from unittest import TestCase
|
||||||
|
|
||||||
from mock import patch
|
from mock import patch, MagicMock
|
||||||
from PyQt4 import QtCore
|
from PyQt4 import QtCore
|
||||||
|
|
||||||
from openlp.core.utils import AppLocation, _get_frozen_path
|
from openlp.core.utils import AppLocation, _get_frozen_path
|
||||||
@ -17,21 +17,52 @@ class TestAppLocation(TestCase):
|
|||||||
"""
|
"""
|
||||||
Test the _get_frozen_path() function
|
Test the _get_frozen_path() function
|
||||||
"""
|
"""
|
||||||
|
# GIVEN: The sys module "without" a "frozen" attribute
|
||||||
sys.frozen = None
|
sys.frozen = None
|
||||||
|
# WHEN: We call _get_frozen_path() with two parameters
|
||||||
|
# THEN: The non-frozen parameter is returned
|
||||||
assert _get_frozen_path(u'frozen', u'not frozen') == u'not frozen', u'Should return "not frozen"'
|
assert _get_frozen_path(u'frozen', u'not frozen') == u'not frozen', u'Should return "not frozen"'
|
||||||
|
# GIVEN: The sys module *with* a "frozen" attribute
|
||||||
sys.frozen = 1
|
sys.frozen = 1
|
||||||
|
# WHEN: We call _get_frozen_path() with two parameters
|
||||||
|
# THEN: The frozen parameter is returned
|
||||||
assert _get_frozen_path(u'frozen', u'not frozen') == u'frozen', u'Should return "frozen"'
|
assert _get_frozen_path(u'frozen', u'not frozen') == u'frozen', u'Should return "frozen"'
|
||||||
|
|
||||||
|
def get_data_path_test(self):
|
||||||
|
"""
|
||||||
|
Test the AppLocation.get_data_path() method
|
||||||
|
"""
|
||||||
|
with patch(u'openlp.core.utils.Settings') as mocked_class, \
|
||||||
|
patch(u'openlp.core.utils.AppLocation.get_directory') as mocked_get_directory, \
|
||||||
|
patch(u'openlp.core.utils.check_directory_exists') as mocked_check_directory_exists,\
|
||||||
|
patch(u'openlp.core.utils.os') as mocked_os:
|
||||||
|
# GIVEN: A mocked out Settings class and a mocked out AppLocation.get_directory()
|
||||||
|
mocked_settings = mocked_class.return_value
|
||||||
|
mocked_settings.contains.return_value = False
|
||||||
|
mocked_get_directory.return_value = u'test/dir'
|
||||||
|
mocked_check_directory_exists.return_value = True
|
||||||
|
mocked_os.path.normpath.return_value = u'test/dir'
|
||||||
|
# WHEN: we call AppLocation.get_data_path()
|
||||||
|
data_path = AppLocation.get_data_path()
|
||||||
|
# THEN: check that all the correct methods were called, and the result is correct
|
||||||
|
mocked_settings.contains.assert_called_with(u'advanced/data path')
|
||||||
|
mocked_get_directory.assert_called_with(AppLocation.DataDir)
|
||||||
|
mocked_check_directory_exists.assert_called_with(u'test/dir')
|
||||||
|
assert data_path == u'test/dir', u'Result should be "test/dir"'
|
||||||
|
|
||||||
def get_data_path_with_custom_location_test(self):
|
def get_data_path_with_custom_location_test(self):
|
||||||
"""
|
"""
|
||||||
Test the AppLocation.get_data_path() method when a custom location is set in the settings
|
Test the AppLocation.get_data_path() method when a custom location is set in the settings
|
||||||
"""
|
"""
|
||||||
with patch(u'openlp.core.utils.Settings') as mocked_class:
|
with patch(u'openlp.core.utils.Settings') as mocked_class:
|
||||||
|
# GIVEN: A mocked out Settings class which returns a custom data location
|
||||||
mocked_settings = mocked_class.return_value
|
mocked_settings = mocked_class.return_value
|
||||||
mocked_settings.contains.return_value = True
|
mocked_settings.contains.return_value = True
|
||||||
mocked_settings.value.return_value.toString.return_value = u'test/dir'
|
mocked_settings.value.return_value.toString.return_value = u'custom/dir'
|
||||||
|
# WHEN: we call AppLocation.get_data_path()
|
||||||
data_path = AppLocation.get_data_path()
|
data_path = AppLocation.get_data_path()
|
||||||
|
# THEN: the mocked Settings methods were called and the value returned was our set up value
|
||||||
mocked_settings.contains.assert_called_with(u'advanced/data path')
|
mocked_settings.contains.assert_called_with(u'advanced/data path')
|
||||||
mocked_settings.value.assert_called_with(u'advanced/data path')
|
mocked_settings.value.assert_called_with(u'advanced/data path')
|
||||||
mocked_settings.value.return_value.toString.assert_called_with()
|
mocked_settings.value.return_value.toString.assert_called_with()
|
||||||
assert data_path == u'test/dir', u'Result should be "test/dir"'
|
assert data_path == u'custom/dir', u'Result should be "custom/dir"'
|
||||||
|
Loading…
Reference in New Issue
Block a user