2017-10-30 02:36:26 +00:00
|
|
|
import pytest
|
2018-03-04 06:17:39 +00:00
|
|
|
from flexmock import flexmock
|
2017-10-30 02:36:26 +00:00
|
|
|
|
|
|
|
from borgmatic.config import validate as module
|
|
|
|
|
|
|
|
|
|
|
|
def test_validation_error_str_contains_error_messages_and_config_filename():
|
|
|
|
error = module.Validation_error('config.yaml', ('oops', 'uh oh'))
|
|
|
|
|
|
|
|
result = str(error)
|
|
|
|
|
|
|
|
assert 'config.yaml' in result
|
|
|
|
assert 'oops' in result
|
|
|
|
assert 'uh oh' in result
|
|
|
|
|
|
|
|
|
|
|
|
def test_apply_logical_validation_raises_if_archive_name_format_present_without_prefix():
|
|
|
|
with pytest.raises(module.Validation_error):
|
|
|
|
module.apply_logical_validation(
|
|
|
|
'config.yaml',
|
|
|
|
{
|
|
|
|
'storage': {'archive_name_format': '{hostname}-{now}'},
|
|
|
|
'retention': {'keep_daily': 7},
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
2018-09-30 06:45:00 +01:00
|
|
|
|
2018-03-04 06:17:39 +00:00
|
|
|
def test_apply_logical_validation_raises_if_archive_name_format_present_without_retention_prefix():
|
|
|
|
with pytest.raises(module.Validation_error):
|
|
|
|
module.apply_logical_validation(
|
|
|
|
'config.yaml',
|
|
|
|
{
|
|
|
|
'storage': {'archive_name_format': '{hostname}-{now}'},
|
|
|
|
'retention': {'keep_daily': 7},
|
2018-09-30 06:45:00 +01:00
|
|
|
'consistency': {'prefix': '{hostname}-'},
|
2018-03-04 06:17:39 +00:00
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def test_apply_logical_validation_warns_if_archive_name_format_present_without_consistency_prefix():
|
|
|
|
logger = flexmock(module.logger)
|
|
|
|
logger.should_receive('warning').once()
|
|
|
|
|
|
|
|
module.apply_logical_validation(
|
|
|
|
'config.yaml',
|
|
|
|
{
|
|
|
|
'storage': {'archive_name_format': '{hostname}-{now}'},
|
|
|
|
'retention': {'prefix': '{hostname}-'},
|
|
|
|
'consistency': {},
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2018-10-14 04:34:51 +01:00
|
|
|
def test_apply_locical_validation_raises_if_unknown_repository_in_check_repositories():
|
|
|
|
with pytest.raises(module.Validation_error):
|
|
|
|
module.apply_logical_validation(
|
|
|
|
'config.yaml',
|
|
|
|
{
|
|
|
|
'location': {'repositories': ['repo.borg', 'other.borg']},
|
|
|
|
'retention': {'keep_secondly': 1000},
|
|
|
|
'consistency': {'check_repositories': ['repo.borg', 'unknown.borg']},
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def test_apply_locical_validation_does_not_raise_if_known_repository_in_check_repositories():
|
|
|
|
module.apply_logical_validation(
|
|
|
|
'config.yaml',
|
|
|
|
{
|
|
|
|
'location': {'repositories': ['repo.borg', 'other.borg']},
|
|
|
|
'retention': {'keep_secondly': 1000},
|
|
|
|
'consistency': {'check_repositories': ['repo.borg']},
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2018-03-04 06:17:39 +00:00
|
|
|
def test_apply_logical_validation_does_not_raise_or_warn_if_archive_name_format_and_prefix_present():
|
|
|
|
logger = flexmock(module.logger)
|
|
|
|
logger.should_receive('warning').never()
|
2017-10-30 02:36:26 +00:00
|
|
|
|
|
|
|
module.apply_logical_validation(
|
|
|
|
'config.yaml',
|
|
|
|
{
|
|
|
|
'storage': {'archive_name_format': '{hostname}-{now}'},
|
|
|
|
'retention': {'prefix': '{hostname}-'},
|
2018-09-30 06:45:00 +01:00
|
|
|
'consistency': {'prefix': '{hostname}-'},
|
2017-10-30 02:36:26 +00:00
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def test_apply_logical_validation_does_not_raise_otherwise():
|
2018-09-30 06:45:00 +01:00
|
|
|
module.apply_logical_validation('config.yaml', {'retention': {'keep_secondly': 1000}})
|