2016-11-30 22:12:14 +01:00
|
|
|
import os
|
|
|
|
|
|
|
|
from twisted.trial import unittest
|
|
|
|
from lbrynet import conf
|
|
|
|
|
|
|
|
|
|
|
|
class SettingsTest(unittest.TestCase):
|
|
|
|
def setUp(self):
|
|
|
|
os.environ['LBRY_TEST'] = 'test_string'
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
del os.environ['LBRY_TEST']
|
|
|
|
|
2017-01-17 04:23:20 +01:00
|
|
|
@staticmethod
|
|
|
|
def get_mock_config_instance():
|
2017-01-17 18:29:09 +01:00
|
|
|
settings = {'test': (str, '')}
|
|
|
|
env = conf.Env(**settings)
|
|
|
|
return conf.Config({}, settings, environment=env)
|
2016-11-30 22:12:14 +01:00
|
|
|
|
2017-01-17 04:23:20 +01:00
|
|
|
def test_envvar_is_read(self):
|
|
|
|
settings = self.get_mock_config_instance()
|
|
|
|
self.assertEqual('test_string', settings['test'])
|
|
|
|
|
|
|
|
def test_setting_can_be_overridden(self):
|
|
|
|
settings = self.get_mock_config_instance()
|
|
|
|
settings['test'] = 'my_override'
|
|
|
|
self.assertEqual('my_override', settings['test'])
|
2016-11-30 22:12:14 +01:00
|
|
|
|
|
|
|
def test_setting_can_be_updated(self):
|
2017-01-17 04:23:20 +01:00
|
|
|
settings = self.get_mock_config_instance()
|
2016-11-30 22:12:14 +01:00
|
|
|
settings.update({'test': 'my_update'})
|
2017-01-17 04:23:20 +01:00
|
|
|
self.assertEqual('my_update', settings['test'])
|
2016-11-30 22:12:14 +01:00
|
|
|
|
|
|
|
def test_setting_is_in_dict(self):
|
2017-01-17 04:23:20 +01:00
|
|
|
settings = self.get_mock_config_instance()
|
|
|
|
setting_dict = settings.get_current_settings_dict()
|
2016-11-30 22:12:14 +01:00
|
|
|
self.assertEqual({'test': 'test_string'}, setting_dict)
|
2017-01-17 18:29:09 +01:00
|
|
|
|
|
|
|
def test_invalid_setting_raises_exception(self):
|
|
|
|
settings = self.get_mock_config_instance()
|
|
|
|
self.assertRaises(AssertionError, settings.set, 'invalid_name', 123)
|
|
|
|
|
|
|
|
def test_invalid_data_type_raises_exception(self):
|
|
|
|
settings = self.get_mock_config_instance()
|
|
|
|
self.assertIsNone(settings.set('test', 123))
|
|
|
|
self.assertRaises(AssertionError, settings.set, 'test', 123, ('fake_data_type',))
|
|
|
|
|
|
|
|
def test_setting_precedence(self):
|
|
|
|
settings = self.get_mock_config_instance()
|
|
|
|
settings.set('test', 'cli_test_string', data_types=(conf.TYPE_CLI,))
|
|
|
|
self.assertEqual('cli_test_string', settings['test'])
|
|
|
|
settings.set('test', 'this_should_not_take_precedence', data_types=(conf.TYPE_ENV,))
|
|
|
|
self.assertEqual('cli_test_string', settings['test'])
|
|
|
|
settings.set('test', 'runtime_takes_precedence', data_types=(conf.TYPE_RUNTIME,))
|
|
|
|
self.assertEqual('runtime_takes_precedence', settings['test'])
|
2017-06-30 18:39:53 +02:00
|
|
|
|
|
|
|
def test_data_dir(self):
|
|
|
|
# check if these directories are returned as string and not unicode
|
|
|
|
# otherwise there will be problems when calling os.path.join on
|
|
|
|
# unicode directory names with string file names
|
2017-07-05 23:39:35 +02:00
|
|
|
self.assertEqual(str, type(conf.default_download_dir))
|
2017-06-30 18:39:53 +02:00
|
|
|
self.assertEqual(str, type(conf.default_data_dir))
|
|
|
|
self.assertEqual(str, type(conf.default_lbryum_dir))
|