2019-06-25 18:18:30 +01:00
|
|
|
from flexmock import flexmock
|
|
|
|
|
|
|
|
from borgmatic.borg import flags as module
|
|
|
|
|
|
|
|
|
|
|
|
def test_make_flags_formats_string_value():
|
|
|
|
assert module.make_flags('foo', 'bar') == ('--foo', 'bar')
|
|
|
|
|
|
|
|
|
|
|
|
def test_make_flags_formats_integer_value():
|
|
|
|
assert module.make_flags('foo', 3) == ('--foo', '3')
|
|
|
|
|
|
|
|
|
|
|
|
def test_make_flags_formats_true_value():
|
|
|
|
assert module.make_flags('foo', True) == ('--foo',)
|
|
|
|
|
|
|
|
|
|
|
|
def test_make_flags_omits_false_value():
|
|
|
|
assert module.make_flags('foo', False) == ()
|
|
|
|
|
|
|
|
|
|
|
|
def test_make_flags_formats_name_with_underscore():
|
|
|
|
assert module.make_flags('posix_me_harder', 'okay') == ('--posix-me-harder', 'okay')
|
|
|
|
|
|
|
|
|
2019-06-25 19:04:10 +01:00
|
|
|
def test_make_flags_from_arguments_flattens_and_sorts_multiple_arguments():
|
2019-06-25 18:18:30 +01:00
|
|
|
flexmock(module).should_receive('make_flags').with_args('foo', 'bar').and_return(('foo', 'bar'))
|
|
|
|
flexmock(module).should_receive('make_flags').with_args('baz', 'quux').and_return(
|
|
|
|
('baz', 'quux')
|
|
|
|
)
|
|
|
|
arguments = flexmock(foo='bar', baz='quux')
|
|
|
|
|
2019-06-25 19:04:10 +01:00
|
|
|
assert module.make_flags_from_arguments(arguments) == ('baz', 'quux', 'foo', 'bar')
|
2019-06-25 18:18:30 +01:00
|
|
|
|
|
|
|
|
|
|
|
def test_make_flags_from_arguments_excludes_underscored_argument_names():
|
|
|
|
flexmock(module).should_receive('make_flags').with_args('foo', 'bar').and_return(('foo', 'bar'))
|
|
|
|
arguments = flexmock(foo='bar', _baz='quux')
|
|
|
|
|
|
|
|
assert module.make_flags_from_arguments(arguments) == ('foo', 'bar')
|
|
|
|
|
|
|
|
|
|
|
|
def test_make_flags_from_arguments_omits_excludes():
|
|
|
|
flexmock(module).should_receive('make_flags').with_args('foo', 'bar').and_return(('foo', 'bar'))
|
|
|
|
arguments = flexmock(foo='bar', baz='quux')
|
|
|
|
|
|
|
|
assert module.make_flags_from_arguments(arguments, excludes=('baz', 'other')) == ('foo', 'bar')
|
2022-08-14 06:07:15 +01:00
|
|
|
|
|
|
|
|
|
|
|
def test_make_repository_flags_with_borg_features_includes_repo_flag():
|
|
|
|
flexmock(module.feature).should_receive('available').and_return(True)
|
|
|
|
|
2023-03-26 19:22:25 +01:00
|
|
|
assert module.make_repository_flags(repository_path='repo', local_borg_version='1.2.3') == (
|
2022-08-14 06:07:15 +01:00
|
|
|
'--repo',
|
|
|
|
'repo',
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def test_make_repository_flags_without_borg_features_includes_omits_flag():
|
|
|
|
flexmock(module.feature).should_receive('available').and_return(False)
|
|
|
|
|
2023-03-26 19:22:25 +01:00
|
|
|
assert module.make_repository_flags(repository_path='repo', local_borg_version='1.2.3') == (
|
|
|
|
'repo',
|
|
|
|
)
|
2022-08-14 06:50:14 +01:00
|
|
|
|
|
|
|
|
|
|
|
def test_make_repository_archive_flags_with_borg_features_separates_repository_and_archive():
|
|
|
|
flexmock(module.feature).should_receive('available').and_return(True)
|
|
|
|
|
|
|
|
assert module.make_repository_archive_flags(
|
2023-03-26 19:22:25 +01:00
|
|
|
repository_path='repo', archive='archive', local_borg_version='1.2.3'
|
2022-08-14 06:50:14 +01:00
|
|
|
) == ('--repo', 'repo', 'archive',)
|
|
|
|
|
|
|
|
|
|
|
|
def test_make_repository_archive_flags_with_borg_features_joins_repository_and_archive():
|
|
|
|
flexmock(module.feature).should_receive('available').and_return(False)
|
|
|
|
|
|
|
|
assert module.make_repository_archive_flags(
|
2023-03-26 19:22:25 +01:00
|
|
|
repository_path='repo', archive='archive', local_borg_version='1.2.3'
|
2022-08-14 06:50:14 +01:00
|
|
|
) == ('repo::archive',)
|