|
@@ -3,13 +3,70 @@ from flexmock import flexmock
|
|
from borgmatic.actions import compact as module
|
|
from borgmatic.actions import compact as module
|
|
|
|
|
|
|
|
|
|
-def test_compact_actions_calls_hooks():
|
|
|
|
|
|
+def test_compact_actions_calls_hooks_for_configured_repository():
|
|
flexmock(module.logger).answer = lambda message: None
|
|
flexmock(module.logger).answer = lambda message: None
|
|
flexmock(module.borgmatic.borg.feature).should_receive('available').and_return(True)
|
|
flexmock(module.borgmatic.borg.feature).should_receive('available').and_return(True)
|
|
- flexmock(module.borgmatic.borg.compact).should_receive('compact_segments')
|
|
|
|
|
|
+ flexmock(module.borgmatic.config.validate).should_receive('repositories_match').never()
|
|
|
|
+ flexmock(module.borgmatic.borg.compact).should_receive('compact_segments').once()
|
|
flexmock(module.borgmatic.hooks.command).should_receive('execute_hook').times(2)
|
|
flexmock(module.borgmatic.hooks.command).should_receive('execute_hook').times(2)
|
|
compact_arguments = flexmock(
|
|
compact_arguments = flexmock(
|
|
- progress=flexmock(), cleanup_commits=flexmock(), threshold=flexmock()
|
|
|
|
|
|
+ repository=None, progress=flexmock(), cleanup_commits=flexmock(), threshold=flexmock()
|
|
|
|
+ )
|
|
|
|
+ global_arguments = flexmock(monitoring_verbosity=1, dry_run=False)
|
|
|
|
+
|
|
|
|
+ module.run_compact(
|
|
|
|
+ config_filename='test.yaml',
|
|
|
|
+ repository='repo',
|
|
|
|
+ storage={},
|
|
|
|
+ retention={},
|
|
|
|
+ hooks={},
|
|
|
|
+ hook_context={},
|
|
|
|
+ local_borg_version=None,
|
|
|
|
+ compact_arguments=compact_arguments,
|
|
|
|
+ global_arguments=global_arguments,
|
|
|
|
+ dry_run_label='',
|
|
|
|
+ local_path=None,
|
|
|
|
+ remote_path=None,
|
|
|
|
+ )
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+def test_compact_runs_with_select_repository():
|
|
|
|
+ flexmock(module.logger).answer = lambda message: None
|
|
|
|
+ flexmock(module.borgmatic.config.validate).should_receive(
|
|
|
|
+ 'repositories_match'
|
|
|
|
+ ).once().and_return(True)
|
|
|
|
+ flexmock(module.borgmatic.borg.feature).should_receive('available').and_return(True)
|
|
|
|
+ flexmock(module.borgmatic.borg.compact).should_receive('compact_segments').once()
|
|
|
|
+ compact_arguments = flexmock(
|
|
|
|
+ repository=flexmock(), progress=flexmock(), cleanup_commits=flexmock(), threshold=flexmock()
|
|
|
|
+ )
|
|
|
|
+ global_arguments = flexmock(monitoring_verbosity=1, dry_run=False)
|
|
|
|
+
|
|
|
|
+ module.run_compact(
|
|
|
|
+ config_filename='test.yaml',
|
|
|
|
+ repository='repo',
|
|
|
|
+ storage={},
|
|
|
|
+ retention={},
|
|
|
|
+ hooks={},
|
|
|
|
+ hook_context={},
|
|
|
|
+ local_borg_version=None,
|
|
|
|
+ compact_arguments=compact_arguments,
|
|
|
|
+ global_arguments=global_arguments,
|
|
|
|
+ dry_run_label='',
|
|
|
|
+ local_path=None,
|
|
|
|
+ remote_path=None,
|
|
|
|
+ )
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+def test_compact_bails_if_repository_does_not_match():
|
|
|
|
+ flexmock(module.logger).answer = lambda message: None
|
|
|
|
+ flexmock(module.borgmatic.borg.feature).should_receive('available').and_return(True)
|
|
|
|
+ flexmock(module.borgmatic.config.validate).should_receive(
|
|
|
|
+ 'repositories_match'
|
|
|
|
+ ).once().and_return(False)
|
|
|
|
+ flexmock(module.borgmatic.borg.compact).should_receive('compact_segments').never()
|
|
|
|
+ compact_arguments = flexmock(
|
|
|
|
+ repository=flexmock(), progress=flexmock(), cleanup_commits=flexmock(), threshold=flexmock()
|
|
)
|
|
)
|
|
global_arguments = flexmock(monitoring_verbosity=1, dry_run=False)
|
|
global_arguments = flexmock(monitoring_verbosity=1, dry_run=False)
|
|
|
|
|