Fix normalization of settings using a custom dest
This commit is contained in:
parent
4c385667e8
commit
fc2a175e5b
@ -448,13 +448,13 @@ def normalize_config(
|
|||||||
value, is_default = get_option(options, setting)
|
value, is_default = get_option(options, setting)
|
||||||
if not is_default or default:
|
if not is_default or default:
|
||||||
# User has set a custom value or has requested the default value
|
# User has set a custom value or has requested the default value
|
||||||
group_options[setting_name] = value
|
group_options[setting.dest] = value
|
||||||
elif setting_name in group_options:
|
elif setting.dest in group_options:
|
||||||
# default values have been requested to be removed
|
# default values have been requested to be removed
|
||||||
del group_options[setting_name]
|
del group_options[setting.dest]
|
||||||
elif setting_name in group_options:
|
elif setting.dest in group_options:
|
||||||
# Setting type (file or cmdline) has not been requested and should be removed for persistent groups
|
# Setting type (file or cmdline) has not been requested and should be removed for persistent groups
|
||||||
del group_options[setting_name]
|
del group_options[setting.dest]
|
||||||
normalized[group_name] = group_options
|
normalized[group_name] = group_options
|
||||||
|
|
||||||
return Config(normalized, config.definitions)
|
return Config(normalized, config.definitions)
|
||||||
|
@ -18,7 +18,18 @@ from testing.settngs import failure
|
|||||||
from testing.settngs import success
|
from testing.settngs import success
|
||||||
|
|
||||||
|
|
||||||
if sys.version_info < (3, 9): # pragma: no cover
|
if sys.version_info >= (3, 10): # pragma: no cover
|
||||||
|
List = list
|
||||||
|
help_output = '''\
|
||||||
|
usage: __main__.py [-h] [TEST ...]
|
||||||
|
|
||||||
|
positional arguments:
|
||||||
|
TEST
|
||||||
|
|
||||||
|
options:
|
||||||
|
-h, --help show this help message and exit
|
||||||
|
'''
|
||||||
|
elif sys.version_info < (3, 9): # pragma: no cover
|
||||||
from typing import List
|
from typing import List
|
||||||
help_output = '''\
|
help_output = '''\
|
||||||
usage: __main__.py [-h] [TEST [TEST ...]]
|
usage: __main__.py [-h] [TEST [TEST ...]]
|
||||||
@ -42,17 +53,6 @@ optional arguments:
|
|||||||
-h, --help show this help message and exit
|
-h, --help show this help message and exit
|
||||||
'''
|
'''
|
||||||
|
|
||||||
if sys.version_info >= (3, 10): # pragma: no cover
|
|
||||||
help_output = '''\
|
|
||||||
usage: __main__.py [-h] [TEST ...]
|
|
||||||
|
|
||||||
positional arguments:
|
|
||||||
TEST
|
|
||||||
|
|
||||||
options:
|
|
||||||
-h, --help show this help message and exit
|
|
||||||
'''
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def settngs_manager() -> Generator[settngs.Manager, None, None]:
|
def settngs_manager() -> Generator[settngs.Manager, None, None]:
|
||||||
@ -210,6 +210,24 @@ class TestValues:
|
|||||||
assert non_defaults_normalized.values['tst'] == {'test': 'world'}
|
assert non_defaults_normalized.values['tst'] == {'test': 'world'}
|
||||||
assert non_defaults_normalized.values['tst_persistent'] == {'test': 'world'}
|
assert non_defaults_normalized.values['tst_persistent'] == {'test': 'world'}
|
||||||
|
|
||||||
|
def test_normalize_dest(self, settngs_manager):
|
||||||
|
settngs_manager.add_group('tst', lambda parser: parser.add_setting('--test', default='hello'))
|
||||||
|
settngs_manager.add_group('tst', lambda parser: parser.add_setting('--test2', dest='test', default='hello'))
|
||||||
|
settngs_manager.add_persistent_group('tst_persistent', lambda parser: parser.add_setting('--test', default='hello'))
|
||||||
|
|
||||||
|
defaults = settngs_manager.defaults()
|
||||||
|
defaults_normalized = settngs_manager.normalize_config(defaults, file=True, default=False)
|
||||||
|
assert defaults_normalized.values['tst'] == {}
|
||||||
|
assert defaults_normalized.values['tst_persistent'] == {}
|
||||||
|
|
||||||
|
non_defaults = settngs_manager.defaults()
|
||||||
|
non_defaults.values['tst']['test'] = 'world'
|
||||||
|
non_defaults.values['tst_persistent']['test'] = 'world'
|
||||||
|
non_defaults_normalized = settngs_manager.normalize_config(non_defaults, file=True, default=False)
|
||||||
|
|
||||||
|
assert non_defaults_normalized.values['tst'] == {'test': 'world'}
|
||||||
|
assert non_defaults_normalized.values['tst_persistent'] == {'test': 'world'}
|
||||||
|
|
||||||
def test_normalize(self, settngs_manager):
|
def test_normalize(self, settngs_manager):
|
||||||
settngs_manager.add_group('tst', lambda parser: parser.add_setting('--test', default='hello'))
|
settngs_manager.add_group('tst', lambda parser: parser.add_setting('--test', default='hello'))
|
||||||
settngs_manager.add_persistent_group('persistent', lambda parser: parser.add_setting('--world', default='world'))
|
settngs_manager.add_persistent_group('persistent', lambda parser: parser.add_setting('--world', default='world'))
|
||||||
@ -317,6 +335,23 @@ class TestNamespace:
|
|||||||
assert non_defaults_normalized.values.tst__test == 'world'
|
assert non_defaults_normalized.values.tst__test == 'world'
|
||||||
assert non_defaults_normalized.values.tst_persistent__test == 'world'
|
assert non_defaults_normalized.values.tst_persistent__test == 'world'
|
||||||
|
|
||||||
|
def test_normalize_dest(self, settngs_manager):
|
||||||
|
settngs_manager.add_group('tst', lambda parser: parser.add_setting('--test', default='hello'))
|
||||||
|
settngs_manager.add_group('tst', lambda parser: parser.add_setting('--test2', dest='test', default='hello'))
|
||||||
|
settngs_manager.add_persistent_group('tst_persistent', lambda parser: parser.add_setting('--test', default='hello'))
|
||||||
|
|
||||||
|
defaults = settngs_manager.defaults()
|
||||||
|
defaults_normalized = settngs_manager.get_namespace(settngs_manager.normalize_config(defaults, file=True, default=False), file=True, default=False)
|
||||||
|
assert defaults_normalized.values.__dict__ == {}
|
||||||
|
|
||||||
|
non_defaults = settngs_manager.get_namespace(settngs_manager.defaults(), file=True, cmdline=True)
|
||||||
|
non_defaults.values.tst__test = 'world'
|
||||||
|
non_defaults.values.tst_persistent__test = 'world'
|
||||||
|
non_defaults_normalized = settngs_manager.get_namespace(settngs_manager.normalize_config(non_defaults, file=True, default=False), file=True, default=False)
|
||||||
|
|
||||||
|
assert non_defaults_normalized.values.tst__test == 'world'
|
||||||
|
assert non_defaults_normalized.values.tst_persistent__test == 'world'
|
||||||
|
|
||||||
def test_normalize(self, settngs_manager):
|
def test_normalize(self, settngs_manager):
|
||||||
settngs_manager.add_group('tst', lambda parser: parser.add_setting('--test', default='hello'))
|
settngs_manager.add_group('tst', lambda parser: parser.add_setting('--test', default='hello'))
|
||||||
settngs_manager.add_persistent_group('persistent', lambda parser: parser.add_setting('--world', default='world'))
|
settngs_manager.add_persistent_group('persistent', lambda parser: parser.add_setting('--world', default='world'))
|
||||||
@ -333,7 +368,7 @@ class TestNamespace:
|
|||||||
assert normalized.persistent__hello == 'success'
|
assert normalized.persistent__hello == 'success'
|
||||||
assert normalized.persistent__world == 'world'
|
assert normalized.persistent__world == 'world'
|
||||||
|
|
||||||
def test_normalize_unknown(self, settngs_manager):
|
def test_normalize_unknown_group(self, settngs_manager):
|
||||||
manager = settngs.Manager()
|
manager = settngs.Manager()
|
||||||
manager.add_group('tst', lambda parser: parser.add_setting('--test', default='hello'))
|
manager.add_group('tst', lambda parser: parser.add_setting('--test', default='hello'))
|
||||||
manager.add_persistent_group('persistent', lambda parser: parser.add_setting('--world', default='world'))
|
manager.add_persistent_group('persistent', lambda parser: parser.add_setting('--world', default='world'))
|
||||||
|
Loading…
Reference in New Issue
Block a user