##// END OF EJS Templates
caches: use individual namespaces per user to prevent beaker caching problems....
caches: use individual namespaces per user to prevent beaker caching problems. - especially for mysql in case large number of data in caches there could be critical errors storing cache, and thus preventing users from authentication. This is caused by the fact that we used single namespace for ALL users. It means it grew as number of users grew reaching mysql single column limit. This changes the behaviour and now we use namespace per-user it means that each user-id will have it's own cache namespace fragmenting maximum column data to a single user cache. Which we should never reach.

File last commit:

r2487:fcee5614 default
r2591:36829a17 stable
Show More
test_settings.py
807 lines | 28.7 KiB | text/x-python | PythonLexer
project: added all source files and assets
r1 # -*- coding: utf-8 -*-
release: update copyright year to 2018
r2487 # Copyright (C) 2010-2018 RhodeCode GmbH
project: added all source files and assets
r1 #
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License, version 3
# (only), as published by the Free Software Foundation.
#
# 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 Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
# This program is dual-licensed. If you wish to learn more about the
# RhodeCode Enterprise Edition, including its added features, Support services,
# and proprietary license terms, please see https://rhodecode.com/licenses/
import mock
import pytest
from rhodecode.lib.utils2 import safe_str
from rhodecode.model.db import (
RhodeCodeUi, RepoRhodeCodeUi, RhodeCodeSetting, RepoRhodeCodeSetting)
from rhodecode.model.meta import Session
from rhodecode.model.settings import SettingsModel, SettingNotFound, UiSetting
class TestRepoGetUiByKey(object):
def test_ui_settings_are_returned_when_key_is_found(
self, repo_stub, settings_util):
section = 'test section'
value = 'test value'
settings_util.create_repo_rhodecode_ui(
repo_stub, 'wrong section', 'wrong value')
setting = settings_util.create_repo_rhodecode_ui(
repo_stub, section, value)
key = setting.ui_key
model = SettingsModel(repo=repo_stub.repo_name)
result = model.get_ui_by_key(key)
assert result.ui_value == value
assert result.ui_section == section
assert result.ui_active is True
def test_none_is_returned_when_key_is_not_found(
self, repo_stub, settings_util):
settings_util.create_repo_rhodecode_ui(
repo_stub, 'wrong section', 'wrong value')
model = SettingsModel(repo=repo_stub.repo_name)
result = model.get_ui_by_key('abcde')
assert result is None
class TestGlobalGetUiByKey(object):
def test_ui_settings_are_returned_when_key_is_found(self, settings_util):
section = 'test section'
value = 'test value'
settings_util.create_rhodecode_ui('wrong section', 'wrong value')
setting = settings_util.create_rhodecode_ui(section, value)
key = setting.ui_key
model = SettingsModel()
result = model.get_ui_by_key(key)
assert result.ui_value == value
assert result.ui_section == section
assert result.ui_active is True
def test_none_is_returned_when_key_is_not_found(self, settings_util):
settings_util.create_rhodecode_ui('wrong section', 'wrong value')
model = SettingsModel()
result = model.get_ui_by_key('abcde')
assert result is None
class TestRepoGetUiBySection(object):
def test_ui_settings_are_returned_when_section_is_found(
self, repo_stub, settings_util):
section = 'test section'
values = ['test value 1', 'test value 2']
expected_pairs = []
for value in values:
setting = settings_util.create_repo_rhodecode_ui(
repo_stub, section, value)
expected_pairs.append((setting.ui_key, value))
model = SettingsModel(repo=repo_stub.repo_name)
result = model.get_ui_by_section(section)
result_pairs = [(r.ui_key, r.ui_value) for r in result]
assert sorted(result_pairs) == sorted(expected_pairs)
def test_empty_list_is_returned_when_section_is_not_found(
self, repo_stub, settings_util):
settings_util.create_repo_rhodecode_ui(
repo_stub, 'wrong section', 'wrong value')
model = SettingsModel(repo=repo_stub.repo_name)
result = model.get_ui_by_section('correct section')
assert result == []
class TestGlobalGetUiBySection(object):
def test_ui_settings_are_returned_when_section_is_found(
self, settings_util):
section = 'test section'
values = ['test value 1', 'test value 2']
expected_pairs = []
for value in values:
setting = settings_util.create_rhodecode_ui(section, value)
expected_pairs.append((setting.ui_key, value))
model = SettingsModel()
result = model.get_ui_by_section(section)
result_pairs = [(r.ui_key, r.ui_value) for r in result]
assert sorted(result_pairs) == sorted(expected_pairs)
def test_empty_list_is_returned_when_section_is_not_found(
self, settings_util):
settings_util.create_rhodecode_ui('wrong section', 'wrong value')
model = SettingsModel()
result = model.get_ui_by_section('correct section')
assert result == []
class TestRepoGetUiBySectionAndKey(object):
def test_ui_settings_are_returned_when_section_and_key_are_found(
self, repo_stub, settings_util):
section = 'test section'
value = 'test value'
key = 'test key'
settings_util.create_rhodecode_ui(
'wrong section', 'wrong value', key='wrong key')
setting = settings_util.create_repo_rhodecode_ui(
repo_stub, section, value, key=key)
key = setting.ui_key
model = SettingsModel(repo=repo_stub.repo_name)
result = model.get_ui_by_section_and_key(section, key)
assert result.ui_value == value
assert result.ui_section == section
assert result.ui_active is True
def test_none_is_returned_when_key_section_pair_is_not_found(
self, repo_stub, settings_util):
settings_util.create_repo_rhodecode_ui(
repo_stub, 'section', 'wrong value', key='wrong key')
model = SettingsModel(repo=repo_stub.repo_name)
result = model.get_ui_by_section_and_key('section', 'test key')
assert result is None
class TestGlobalGetUiBySectionAndKey(object):
def test_ui_settings_are_returned_when_section_and_key_are_found(
self, settings_util):
section = 'test section'
value = 'test value'
key = 'test key'
settings_util.create_rhodecode_ui(
'wrong section', 'wrong value', key='wrong key')
setting = settings_util.create_rhodecode_ui(section, value, key=key)
key = setting.ui_key
model = SettingsModel()
result = model.get_ui_by_section_and_key(section, key)
assert result.ui_value == value
assert result.ui_section == section
assert result.ui_active is True
def test_none_is_returned_when_key_section_pair_is_not_found(
self, settings_util):
settings_util.create_rhodecode_ui(
'section', 'wrong value', key='wrong key')
model = SettingsModel()
result = model.get_ui_by_section_and_key('section', 'test key')
assert result is None
class TestRepoGetUi(object):
def test_non_empty_list_is_returned_when_ui_settings_found(
self, repo_stub, settings_util, fake_ui_values):
for ui in fake_ui_values:
settings_util.create_repo_rhodecode_ui(
repo_stub, ui.section, ui.value, key=ui.key)
# Create few global settings to check that only repo ones are
# displayed
settings_util.create_rhodecode_ui(ui.section, ui.value, key=ui.key)
model = SettingsModel(repo=repo_stub.repo_name)
result = model.get_ui()
assert sorted(result) == sorted(fake_ui_values)
def test_settings_filtered_by_section(
self, repo_stub, settings_util, fake_ui_values):
for ui in fake_ui_values:
settings_util.create_repo_rhodecode_ui(
repo_stub, ui.section, ui.value, key=ui.key)
model = SettingsModel(repo=repo_stub.repo_name)
result = model.get_ui(section=fake_ui_values[0].section)
expected_result = [
s for s in fake_ui_values
if s.section == fake_ui_values[0].section]
assert sorted(result) == sorted(expected_result)
def test_settings_filtered_by_key(
self, repo_stub, settings_util, fake_ui_values):
for ui in fake_ui_values:
settings_util.create_repo_rhodecode_ui(
repo_stub, ui.section, ui.value, key=ui.key)
model = SettingsModel(repo=repo_stub.repo_name)
result = model.get_ui(key=fake_ui_values[0].key)
expected_result = [
s for s in fake_ui_values if s.key == fake_ui_values[0].key]
assert sorted(result) == sorted(expected_result)
def test_empty_list_is_returned_when_ui_settings_are_not_found(
self, repo_stub, settings_util):
for i in range(10):
settings_util.create_rhodecode_ui(
'section{}'.format(i), 'value{}'.format(i),
key='key{}'.format(i), active=True)
model = SettingsModel(repo=repo_stub.repo_name)
result = model.get_ui()
assert result == []
class TestGlobalGetUi(object):
def test_non_empty_list_is_returned_when_ui_settings_found(
self, backend_stub, settings_util, fake_ui_values):
repo = backend_stub.create_repo()
for ui in fake_ui_values:
settings_util.create_rhodecode_ui(ui.section, ui.value, key=ui.key)
# Create few repo settings to check that only global ones are
# displayed
settings_util.create_repo_rhodecode_ui(
repo, ui.section, ui.value, key=ui.key)
model = SettingsModel()
result = model.get_ui()
for ui in fake_ui_values:
assert ui in result
def test_settings_filtered_by_key(self, settings_util, fake_ui_values):
for ui in fake_ui_values:
settings_util.create_rhodecode_ui(ui.section, ui.value, key=ui.key)
expected_result = [
s for s in fake_ui_values if s.key == fake_ui_values[0].key]
model = SettingsModel()
result = model.get_ui(key=fake_ui_values[0].key)
assert sorted(result) == sorted(expected_result)
def test_settings_filtered_by_section(self, settings_util, fake_ui_values):
for ui in fake_ui_values:
settings_util.create_rhodecode_ui(ui.section, ui.value, key=ui.key)
expected_result = [
s for s in fake_ui_values
if s.section == fake_ui_values[0].section]
model = SettingsModel()
result = model.get_ui(section=fake_ui_values[0].section)
assert sorted(result) == sorted(expected_result)
def test_repo_settings_are_not_displayed(
self, backend_stub, settings_util, fake_ui_values):
repo = backend_stub.create_repo()
for ui in fake_ui_values:
settings_util.create_repo_rhodecode_ui(
repo, ui.section, ui.value, key=ui.key, active=ui.active)
model = SettingsModel()
result = model.get_ui()
for ui in fake_ui_values:
assert ui not in result
class TestRepoGetBuiltInHooks(object):
def test_only_builtin_hooks_are_returned(self, repo_stub, settings_util):
section = 'hooks'
valid_keys = SettingsModel.BUILTIN_HOOKS
invalid_keys = ('fake_hook', )
keys = valid_keys + invalid_keys
for key in keys:
settings_util.create_repo_rhodecode_ui(
repo_stub, section, 'test value', key=key)
model = SettingsModel(repo=repo_stub.repo_name)
result = model.get_builtin_hooks()
assert len(result) == len(valid_keys)
for entry in result:
assert entry.ui_key in valid_keys
class TestGlobalGetBuiltInHooks(object):
def test_only_builtin_hooks_are_returned(self, settings_util):
section = 'hooks'
valid_keys = ('valid_key1', 'valid_key2')
invalid_keys = ('fake_hook', )
keys = valid_keys + invalid_keys
for key in keys:
settings_util.create_rhodecode_ui(section, 'test value', key=key)
model = SettingsModel()
with mock.patch.object(model, 'BUILTIN_HOOKS', valid_keys):
result = model.get_builtin_hooks()
assert len(result) == len(valid_keys)
for entry in result:
assert entry.ui_key in valid_keys
class TestRepoGetCustomHooks(object):
def test_only_custom_hooks_are_returned(self, repo_stub, settings_util):
section = 'hooks'
valid_keys = ('custom', )
invalid_keys = SettingsModel.BUILTIN_HOOKS
keys = valid_keys + invalid_keys
for key in keys:
settings_util.create_repo_rhodecode_ui(
repo_stub, section, 'test value', key=key)
model = SettingsModel(repo=repo_stub.repo_name)
result = model.get_custom_hooks()
assert len(result) == len(valid_keys)
for entry in result:
assert entry.ui_key in valid_keys
class TestGlobalGetCustomHooks(object):
def test_only_custom_hooks_are_returned(self, settings_util):
section = 'hooks'
valid_keys = ('valid_key1', 'valid_key2')
invalid_keys = ('fake_hook', )
keys = valid_keys + invalid_keys
for key in keys:
settings_util.create_rhodecode_ui(section, 'test value', key=key)
model = SettingsModel()
with mock.patch.object(model, 'BUILTIN_HOOKS', invalid_keys):
result = model.get_custom_hooks()
for entry in result:
assert entry.ui_key not in invalid_keys
class TestRepoCreateUiSectionValue(object):
@pytest.mark.parametrize("additional_kwargs", [
{'key': 'abcde'},
{'active': False},
{}
])
def test_ui_section_value_is_created(
self, repo_stub, additional_kwargs):
model = SettingsModel(repo=repo_stub.repo_name)
section = 'test section'
value = 'test value'
result = model.create_ui_section_value(section, value)
key = result.ui_key
Session().commit()
setting = model.get_ui_by_key(key)
try:
assert setting == result
assert isinstance(setting, RepoRhodeCodeUi)
finally:
Session().delete(result)
Session().commit()
class TestGlobalCreateUiSectionValue(object):
@pytest.mark.parametrize("additional_kwargs", [
{'key': 'abcde'},
{'active': False},
{}
])
def test_ui_section_value_is_created_with_autogenerated_key(
self, backend_stub, additional_kwargs):
model = SettingsModel()
section = 'test section'
value = 'test value'
result = model.create_ui_section_value(
section, value, **additional_kwargs)
key = result.ui_key
Session().commit()
setting = model.get_ui_by_key(key)
try:
assert setting == result
assert isinstance(setting, RhodeCodeUi)
finally:
Session().delete(result)
Session().commit()
class TestRepoCreateOrUpdateHook(object):
def test_hook_created(self, repo_stub):
model = SettingsModel(repo=repo_stub.repo_name)
key = 'test_key'
value = 'test value'
result = model.create_or_update_hook(key, value)
Session().commit()
setting = model.get_ui_by_section_and_key('hooks', key)
try:
assert setting == result
assert isinstance(setting, RepoRhodeCodeUi)
finally:
Session().delete(result)
Session().commit()
def test_hook_updated(self, repo_stub, settings_util):
section = 'hooks'
key = 'test_key'
settings_util.create_repo_rhodecode_ui(
repo_stub, section, 'old value', key=key)
model = SettingsModel(repo=repo_stub.repo_name)
value = 'test value'
model.create_or_update_hook(key, value)
Session().commit()
setting = model.get_ui_by_section_and_key('hooks', key)
assert setting.ui_value == value
class TestGlobalCreateOrUpdateHook(object):
def test_hook_created(self):
model = SettingsModel()
key = 'test_key'
value = 'test value'
result = model.create_or_update_hook(key, value)
Session().commit()
setting = model.get_ui_by_section_and_key('hooks', key)
try:
assert setting == result
assert isinstance(setting, RhodeCodeUi)
finally:
Session().delete(result)
Session().commit()
def test_hook_updated(self, settings_util):
section = 'hooks'
key = 'test_key'
settings_util.create_rhodecode_ui(section, 'old value', key=key)
model = SettingsModel()
value = 'test value'
model.create_or_update_hook(key, value)
Session().commit()
setting = model.get_ui_by_section_and_key('hooks', key)
assert setting.ui_value == value
class TestDeleteUiValue(object):
def test_delete_ui_when_repo_is_set(self, repo_stub, settings_util):
model = SettingsModel(repo=repo_stub.repo_name)
result = settings_util.create_repo_rhodecode_ui(
repo_stub, 'section', None, cleanup=False)
key = result.ui_key
model.delete_ui(result.ui_id)
Session().commit()
setting = model.get_ui_by_key(key)
assert setting is None
@pytest.mark.parametrize('id_', (None, 123))
def test_raises_exception_when_id_is_not_specified(self, id_):
model = SettingsModel()
with pytest.raises(SettingNotFound) as exc_info:
model.delete_ui(id_)
repo-settings: ensure deletion on repo settings model validate...
r2180 assert exc_info.value.message == 'Setting `{}` is not found'.format(id_)
project: added all source files and assets
r1
def test_delete_ui_when_repo_is_not_set(self, settings_util):
model = SettingsModel()
result = settings_util.create_rhodecode_ui(
'section', None, cleanup=False)
key = result.ui_key
model.delete_ui(result.ui_id)
Session().commit()
setting = model.get_ui_by_key(key)
assert setting is None
class TestRepoGetSettingByName(object):
@pytest.mark.parametrize("name, value, type_, expected_value", [
('test_unicode', 'Straße', 'unicode', 'Straße'),
('test_int', '1234', 'int', 1234),
('test_bool', 'True', 'bool', True),
('test_list', 'a,b,c', 'list', ['a', 'b', 'c'])
])
def test_setting_is_returned_when_name_is_found(
self, repo_stub, settings_util, name, value, type_,
expected_value):
settings_util.create_repo_rhodecode_setting(
repo_stub, name, value, type_)
model = SettingsModel(repo=repo_stub.repo_name)
setting = model.get_setting_by_name(name)
assert setting.app_settings_type == type_
actual_value = setting.app_settings_value
if type_ == 'unicode':
actual_value = safe_str(actual_value)
assert actual_value == expected_value
def test_returns_none_if_the_setting_does_not_exist(self, repo_stub):
model = SettingsModel(repo=repo_stub.repo_name)
setting = model.get_setting_by_name('abcde')
assert setting is None
class TestGlobalGetSettingByName(object):
@pytest.mark.parametrize("name, value, type_, expected_value", [
('test_unicode', 'Straße', 'unicode', 'Straße'),
('test_int', '1234', 'int', 1234),
('test_bool', 'True', 'bool', True),
('test_list', 'a,b,c', 'list', ['a', 'b', 'c'])
])
def test_setting_is_returned_when_name_is_found(
self, settings_util, name, value, type_, expected_value):
settings_util.create_rhodecode_setting(name, value, type_)
model = SettingsModel()
setting = model.get_setting_by_name(name)
assert setting.app_settings_type == type_
actual_value = setting.app_settings_value
if type_ == 'unicode':
actual_value = safe_str(actual_value)
assert actual_value == expected_value
def test_returns_none_if_the_setting_does_not_exist(self):
model = SettingsModel()
setting = model.get_setting_by_name('abcde')
assert setting is None
class TestRepoGetAllSettings(object):
def test_settings_are_found(self, repo_stub, settings_util):
initial_settings = {
'test_setting_{}'.format(i): 'value' for i in range(10)}
settings = [
settings_util.create_repo_rhodecode_setting(
repo_stub, name, initial_settings[name], 'unicode')
for name in initial_settings
]
model = SettingsModel(repo=repo_stub.repo_name)
settings = model.get_all_settings()
expected_settings = {
'rhodecode_' + name: initial_settings[name]
for name in initial_settings
}
assert len(settings) == 10
assert expected_settings == settings
def test_settings_are_not_found(self, repo_stub):
model = SettingsModel(repo=repo_stub.repo_name)
setting = model.get_all_settings()
assert setting == {}
class TestGlobalGetAllSettings(object):
def test_settings_are_found(self, settings_util):
initial_settings = {
'test_setting_{}'.format(i): 'value' for i in range(10)}
settings = [
settings_util.create_rhodecode_setting(
name, initial_settings[name], 'unicode')
for name in initial_settings
]
model = SettingsModel()
settings = model.get_all_settings()
expected_settings = {
'rhodecode_' + name: initial_settings[name]
for name in initial_settings
}
filtered_settings = {
name: settings[name]
for name in settings if name.startswith('rhodecode_test_setting')
}
assert len(filtered_settings) == 10
assert expected_settings == filtered_settings
def test_settings_are_not_found(self, repo_stub):
model = SettingsModel(repo=repo_stub.repo_name)
setting = model.get_all_settings()
assert setting == {}
class TestRepoCreateOrUpdateSetting(object):
def test_setting_is_created(self, repo_stub):
model = SettingsModel(repo=repo_stub.repo_name)
name = 'test_setting'
value = 'test_value'
model.create_or_update_setting(name, val=value)
setting = model.get_setting_by_name(name)
try:
assert setting.app_settings_name == name
assert setting.app_settings_value == value
assert setting.app_settings_type == 'unicode'
assert isinstance(setting, RepoRhodeCodeSetting)
finally:
Session().delete(setting)
Session().commit()
def test_setting_is_updated(self, repo_stub, settings_util):
model = SettingsModel(repo=repo_stub.repo_name)
name = 'test_setting'
value = 'test_value'
settings_util.create_repo_rhodecode_setting(
repo_stub, name, value, 'unicode', cleanup=False)
updated_value = 'test_value_2'
model.create_or_update_setting(name, val=updated_value)
setting = model.get_setting_by_name(name)
try:
assert setting.app_settings_name == name
assert setting.app_settings_value == updated_value
assert setting.app_settings_type == 'unicode'
assert isinstance(setting, RepoRhodeCodeSetting)
finally:
Session().delete(setting)
Session().commit()
class TestGlobalCreateOrUpdateSetting(object):
def test_setting_is_created(self):
model = SettingsModel()
name = 'test_setting'
value = 'test_value'
model.create_or_update_setting(name, val=value)
setting = model.get_setting_by_name(name)
try:
assert setting.app_settings_name == name
assert setting.app_settings_value == value
assert setting.app_settings_type == 'unicode'
assert isinstance(setting, RhodeCodeSetting)
finally:
Session().delete(setting)
Session().commit()
def test_setting_is_updated(self, settings_util):
model = SettingsModel()
name = 'test_setting'
value = 'test_value'
settings_util.create_rhodecode_setting(
name, value, 'unicode', cleanup=False)
updated_value = 'test_value_2'
model.create_or_update_setting(name, val=updated_value)
setting = model.get_setting_by_name(name)
try:
assert setting.app_settings_name == name
assert setting.app_settings_value == updated_value
assert setting.app_settings_type == 'unicode'
assert isinstance(setting, RhodeCodeSetting)
finally:
Session().delete(setting)
Session().commit()
class TestRepoGetAuthSettings(object):
def test_settings_prefixed_with_auth_are_retured(
self, repo_stub, settings_util):
model = SettingsModel(repo=repo_stub.repo_name)
valid_settings = ('auth_test1', 'auth_test2')
invalid_settings = ('test1', 'test2')
fake_value = 'test_value'
for name in valid_settings + invalid_settings:
settings_util.create_repo_rhodecode_setting(
repo_stub, name, fake_value, 'unicode')
auth_settings = model.get_auth_settings()
assert auth_settings == {name: fake_value for name in valid_settings}
class TestGlobalGetAuthSettings(object):
def test_settings_prefixed_with_auth_are_retured(self, settings_util):
model = SettingsModel()
valid_settings = ('auth_test1', 'auth_test2')
invalid_settings = ('test1', 'test2')
fake_value = 'test_value'
for name in valid_settings + invalid_settings:
settings_util.create_rhodecode_setting(name, fake_value, 'unicode')
auth_settings = model.get_auth_settings()
for name in auth_settings:
assert name not in invalid_settings
if name in valid_settings:
assert auth_settings[name] == fake_value
class TestGetAuthPlugins(object):
def test_get_setting_by_name_is_called(self):
model = SettingsModel()
fake_value = 'some value'
result_mock = mock.Mock()
result_mock.app_settings_value = fake_value
get_setting_patch = mock.patch.object(
model, 'get_setting_by_name', return_value=result_mock)
with get_setting_patch as get_setting_mock:
result = model.get_auth_plugins()
get_setting_mock.assert_called_once_with('auth_plugins')
assert result == fake_value
class TestDefaultRepoSettings(object):
DEFAULT_SETTINGS_NAMES = ['default_a{}'.format(i) for i in range(10)]
CUSTOM_SETTINGS_NAMES = ['setting_b_{}'.format(i) for i in range(10)]
def test_returns_global_settings_prefixed_with_default(
self, settings_util):
self._create_values(settings_util)
model = SettingsModel()
result = model.get_default_repo_settings()
self._assert_prefixed_settings(result)
def test_returns_global_settings_without_default_prefix(
self, settings_util):
self._create_values(settings_util)
model = SettingsModel()
result = model.get_default_repo_settings(strip_prefix=True)
self._assert_non_prefixed_settings(result)
def test_returns_per_repo_settings_prefixed_with_default(
self, repo_stub, settings_util):
model = SettingsModel(repo=repo_stub)
self._create_values(settings_util, repo=repo_stub)
result = model.get_default_repo_settings()
self._assert_prefixed_settings(result)
def test_returns_per_repo_settings_without_default_prefix(
self, repo_stub, settings_util):
model = SettingsModel(repo=repo_stub)
self._create_values(settings_util, repo=repo_stub)
result = model.get_default_repo_settings(strip_prefix=True)
self._assert_non_prefixed_settings(result)
def _create_values(self, settings_util, repo=None):
for name in self.DEFAULT_SETTINGS_NAMES + self.CUSTOM_SETTINGS_NAMES:
if not repo:
settings_util.create_rhodecode_setting(
name, 'value', 'unicode')
else:
settings_util.create_repo_rhodecode_setting(
repo, name, 'value', 'unicode')
def _assert_prefixed_settings(self, result):
for setting in self.DEFAULT_SETTINGS_NAMES:
assert setting in result
assert result[setting] == 'value'
for setting in self.CUSTOM_SETTINGS_NAMES:
assert setting not in result
def _assert_non_prefixed_settings(self, result):
for setting in self.DEFAULT_SETTINGS_NAMES:
setting = setting.replace('default_', '')
assert setting in result
assert result[setting] == 'value'
@pytest.fixture
def fake_ui_values():
return [
UiSetting(
'section{}'.format(i % 2), 'key{}'.format(i),
'value{}'.format(i), True)
for i in range(10)
]