| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 | 
							- import pytest
 
- import ruamel.yaml
 
- from flexmock import flexmock
 
- from borgmatic.config import override as module
 
- def test_set_values_with_empty_keys_bails():
 
-     config = {}
 
-     module.set_values(config, keys=(), value='value')
 
-     assert config == {}
 
- def test_set_values_with_one_key_sets_it_into_config():
 
-     config = {}
 
-     module.set_values(config, keys=('key',), value='value')
 
-     assert config == {'key': 'value'}
 
- def test_set_values_with_one_key_overwrites_existing_key():
 
-     config = {'key': 'old_value', 'other': 'other_value'}
 
-     module.set_values(config, keys=('key',), value='value')
 
-     assert config == {'key': 'value', 'other': 'other_value'}
 
- def test_set_values_with_multiple_keys_creates_hierarchy():
 
-     config = {}
 
-     module.set_values(config, ('option', 'suboption'), 'value')
 
-     assert config == {'option': {'suboption': 'value'}}
 
- def test_set_values_with_multiple_keys_updates_hierarchy():
 
-     config = {'option': {'other': 'other_value'}}
 
-     module.set_values(config, ('option', 'key'), 'value')
 
-     assert config == {'option': {'key': 'value', 'other': 'other_value'}}
 
- def test_set_values_with_key_when_list_index_expected_errors():
 
-     config = {'option': ['foo', 'bar', 'baz']}
 
-     with pytest.raises(ValueError):
 
-         module.set_values(config, keys=('option', 'key'), value='value')
 
- @pytest.mark.parametrize(
 
-     'schema,option_keys,expected_type',
 
-     (
 
-         ({'properties': {'foo': {'type': 'array'}}}, ('foo',), 'array'),
 
-         (
 
-             {'properties': {'foo': {'properties': {'bar': {'type': 'array'}}}}},
 
-             ('foo', 'bar'),
 
-             'array',
 
-         ),
 
-         ({'properties': {'foo': {'type': 'array'}}}, ('other',), None),
 
-         ({'properties': {'foo': {'description': 'stuff'}}}, ('foo',), None),
 
-         ({}, ('foo',), None),
 
-     ),
 
- )
 
- def test_type_for_option_grabs_type_if_found_in_schema(schema, option_keys, expected_type):
 
-     assert module.type_for_option(schema, option_keys) == expected_type
 
- @pytest.mark.parametrize(
 
-     'key,expected_key',
 
-     (
 
-         (('foo', 'bar'), ('foo', 'bar')),
 
-         (('location', 'foo'), ('foo',)),
 
-         (('storage', 'foo'), ('foo',)),
 
-         (('retention', 'foo'), ('foo',)),
 
-         (('consistency', 'foo'), ('foo',)),
 
-         (('output', 'foo'), ('foo',)),
 
-         (('hooks', 'foo', 'bar'), ('foo', 'bar')),
 
-         (('foo', 'hooks'), ('foo', 'hooks')),
 
-     ),
 
- )
 
- def test_strip_section_names_passes_through_key_without_section_name(key, expected_key):
 
-     assert module.strip_section_names(key) == expected_key
 
- def test_parse_overrides_splits_keys_and_values():
 
-     flexmock(module).should_receive('type_for_option').and_return('string')
 
-     flexmock(module).should_receive('convert_value_type').replace_with(
 
-         lambda value, option_type: value,
 
-     )
 
-     raw_overrides = ['option.my_option=value1', 'other_option=value2']
 
-     expected_result = (
 
-         (('option', 'my_option'), 'value1'),
 
-         (('other_option',), 'value2'),
 
-     )
 
-     assert module.parse_overrides(raw_overrides, schema={}) == expected_result
 
- def test_parse_overrides_allows_value_with_equal_sign():
 
-     flexmock(module).should_receive('type_for_option').and_return('string')
 
-     flexmock(module).should_receive('convert_value_type').replace_with(
 
-         lambda value, option_type: value,
 
-     )
 
-     raw_overrides = ['option=this===value']
 
-     expected_result = ((('option',), 'this===value'),)
 
-     assert module.parse_overrides(raw_overrides, schema={}) == expected_result
 
- def test_parse_overrides_raises_on_missing_equal_sign():
 
-     flexmock(module).should_receive('type_for_option').and_return('string')
 
-     flexmock(module).should_receive('convert_value_type').replace_with(
 
-         lambda value, option_type: value,
 
-     )
 
-     raw_overrides = ['option']
 
-     with pytest.raises(ValueError):
 
-         module.parse_overrides(raw_overrides, schema={})
 
- def test_parse_overrides_raises_on_invalid_override_value():
 
-     flexmock(module).should_receive('type_for_option').and_return('string')
 
-     flexmock(module).should_receive('convert_value_type').and_raise(ruamel.yaml.parser.ParserError)
 
-     raw_overrides = ['option=[in valid]']
 
-     with pytest.raises(ValueError):
 
-         module.parse_overrides(raw_overrides, schema={})
 
- def test_parse_overrides_allows_value_with_single_key():
 
-     flexmock(module).should_receive('type_for_option').and_return('string')
 
-     flexmock(module).should_receive('convert_value_type').replace_with(
 
-         lambda value, option_type: value,
 
-     )
 
-     raw_overrides = ['option=value']
 
-     expected_result = ((('option',), 'value'),)
 
-     assert module.parse_overrides(raw_overrides, schema={}) == expected_result
 
- def test_parse_overrides_handles_empty_overrides():
 
-     assert module.parse_overrides(raw_overrides=None, schema={}) == ()
 
 
  |