123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426 |
- import json
- import os
- import pytest
- from flexmock import flexmock
- from borgmatic.actions import create as module
- def test_run_create_executes_and_calls_hooks_for_configured_repository():
- flexmock(module.logger).answer = lambda message: None
- flexmock(module.borgmatic.config.validate).should_receive('repositories_match').never()
- flexmock(module.borgmatic.config.paths).should_receive('Runtime_directory').and_return(
- flexmock()
- )
- flexmock(module.borgmatic.borg.create).should_receive('create_archive').once()
- flexmock(module.borgmatic.hooks.dispatch).should_receive('call_hooks').and_return({})
- flexmock(module.borgmatic.hooks.dispatch).should_receive(
- 'call_hooks_even_if_unconfigured'
- ).and_return({})
- flexmock(module.borgmatic.actions.pattern).should_receive('collect_patterns').and_return(())
- flexmock(module.borgmatic.actions.pattern).should_receive('process_patterns').and_return([])
- flexmock(os.path).should_receive('join').and_return('/run/borgmatic/bootstrap')
- create_arguments = flexmock(
- repository=None,
- progress=flexmock(),
- statistics=flexmock(),
- json=False,
- comment=None,
- list_details=flexmock(),
- )
- global_arguments = flexmock(monitoring_verbosity=1, dry_run=False)
- list(
- module.run_create(
- config_filename='test.yaml',
- repository={'path': 'repo'},
- config={},
- config_paths=['/tmp/test.yaml'],
- local_borg_version=None,
- create_arguments=create_arguments,
- global_arguments=global_arguments,
- dry_run_label='',
- local_path=None,
- remote_path=None,
- )
- )
- def test_run_create_runs_with_selected_repository():
- flexmock(module.logger).answer = lambda message: None
- flexmock(module.borgmatic.config.validate).should_receive(
- 'repositories_match'
- ).once().and_return(True)
- flexmock(module.borgmatic.config.paths).should_receive('Runtime_directory').and_return(
- flexmock()
- )
- flexmock(module.borgmatic.borg.create).should_receive('create_archive').once()
- flexmock(module.borgmatic.hooks.dispatch).should_receive('call_hooks').and_return({})
- flexmock(module.borgmatic.hooks.dispatch).should_receive(
- 'call_hooks_even_if_unconfigured'
- ).and_return({})
- flexmock(module.borgmatic.actions.pattern).should_receive('collect_patterns').and_return(())
- flexmock(module.borgmatic.actions.pattern).should_receive('process_patterns').and_return([])
- flexmock(os.path).should_receive('join').and_return('/run/borgmatic/bootstrap')
- create_arguments = flexmock(
- repository=flexmock(),
- progress=flexmock(),
- statistics=flexmock(),
- json=False,
- comment=None,
- list_details=flexmock(),
- )
- global_arguments = flexmock(monitoring_verbosity=1, dry_run=False)
- list(
- module.run_create(
- config_filename='test.yaml',
- repository={'path': 'repo'},
- config={},
- config_paths=['/tmp/test.yaml'],
- local_borg_version=None,
- create_arguments=create_arguments,
- global_arguments=global_arguments,
- dry_run_label='',
- local_path=None,
- remote_path=None,
- )
- )
- def test_run_create_bails_if_repository_does_not_match():
- flexmock(module.logger).answer = lambda message: None
- flexmock(module.borgmatic.config.validate).should_receive(
- 'repositories_match'
- ).once().and_return(False)
- flexmock(module.borgmatic.config.paths).should_receive('Runtime_directory').never()
- flexmock(module.borgmatic.borg.create).should_receive('create_archive').never()
- create_arguments = flexmock(
- repository=flexmock(),
- progress=flexmock(),
- statistics=flexmock(),
- json=False,
- comment=None,
- list_details=flexmock(),
- )
- global_arguments = flexmock(monitoring_verbosity=1, dry_run=False)
- list(
- module.run_create(
- config_filename='test.yaml',
- repository='repo',
- config={},
- config_paths=['/tmp/test.yaml'],
- local_borg_version=None,
- create_arguments=create_arguments,
- global_arguments=global_arguments,
- dry_run_label='',
- local_path=None,
- remote_path=None,
- )
- )
- def test_run_create_with_both_list_and_json_errors():
- flexmock(module.logger).answer = lambda message: None
- flexmock(module.borgmatic.config.validate).should_receive(
- 'repositories_match'
- ).once().and_return(True)
- flexmock(module.borgmatic.config.paths).should_receive('Runtime_directory').never()
- flexmock(module.borgmatic.borg.create).should_receive('create_archive').never()
- create_arguments = flexmock(
- repository=flexmock(),
- progress=flexmock(),
- statistics=flexmock(),
- json=True,
- comment=None,
- list_details=flexmock(),
- )
- global_arguments = flexmock(monitoring_verbosity=1, dry_run=False)
- with pytest.raises(ValueError):
- list(
- module.run_create(
- config_filename='test.yaml',
- repository={'path': 'repo'},
- config={'list_details': True},
- config_paths=['/tmp/test.yaml'],
- local_borg_version=None,
- create_arguments=create_arguments,
- global_arguments=global_arguments,
- dry_run_label='',
- local_path=None,
- remote_path=None,
- )
- )
- def test_run_create_with_both_list_and_progress_errors():
- flexmock(module.logger).answer = lambda message: None
- flexmock(module.borgmatic.config.validate).should_receive(
- 'repositories_match'
- ).once().and_return(True)
- flexmock(module.borgmatic.config.paths).should_receive('Runtime_directory').never()
- flexmock(module.borgmatic.borg.create).should_receive('create_archive').never()
- create_arguments = flexmock(
- repository=flexmock(),
- progress=flexmock(),
- statistics=flexmock(),
- json=False,
- comment=None,
- list_details=flexmock(),
- )
- global_arguments = flexmock(monitoring_verbosity=1, dry_run=False)
- with pytest.raises(ValueError):
- list(
- module.run_create(
- config_filename='test.yaml',
- repository={'path': 'repo'},
- config={'list_details': True, 'progress': True},
- config_paths=['/tmp/test.yaml'],
- local_borg_version=None,
- create_arguments=create_arguments,
- global_arguments=global_arguments,
- dry_run_label='',
- local_path=None,
- remote_path=None,
- )
- )
- def test_run_create_produces_json():
- flexmock(module.logger).answer = lambda message: None
- flexmock(module.borgmatic.config.validate).should_receive(
- 'repositories_match'
- ).once().and_return(True)
- flexmock(module.borgmatic.config.paths).should_receive('Runtime_directory').and_return(
- flexmock()
- )
- flexmock(module.borgmatic.borg.create).should_receive('create_archive').once().and_return(
- flexmock()
- )
- parsed_json = flexmock()
- flexmock(module.borgmatic.actions.json).should_receive('parse_json').and_return(parsed_json)
- flexmock(module.borgmatic.hooks.dispatch).should_receive('call_hooks').and_return({})
- flexmock(module.borgmatic.hooks.dispatch).should_receive(
- 'call_hooks_even_if_unconfigured'
- ).and_return({})
- flexmock(module.borgmatic.actions.pattern).should_receive('collect_patterns').and_return(())
- flexmock(module.borgmatic.actions.pattern).should_receive('process_patterns').and_return([])
- flexmock(os.path).should_receive('join').and_return('/run/borgmatic/bootstrap')
- create_arguments = flexmock(
- repository=flexmock(),
- progress=flexmock(),
- statistics=flexmock(),
- json=True,
- comment=None,
- list_details=flexmock(),
- )
- global_arguments = flexmock(monitoring_verbosity=1, dry_run=False)
- assert list(
- module.run_create(
- config_filename='test.yaml',
- repository={'path': 'repo'},
- config={},
- config_paths=['/tmp/test.yaml'],
- local_borg_version=None,
- create_arguments=create_arguments,
- global_arguments=global_arguments,
- dry_run_label='',
- local_path=None,
- remote_path=None,
- )
- ) == [parsed_json]
- def test_run_create_with_active_dumps_roundtrips_via_checkpoint_archive():
- mock_dump_process = flexmock()
- mock_dump_process.should_receive('poll').and_return(None).and_return(0)
- flexmock(module.logger).answer = lambda message: None
- flexmock(module.borgmatic.config.validate).should_receive('repositories_match').never()
- flexmock(module.borgmatic.config.paths).should_receive('Runtime_directory').and_return(
- flexmock()
- )
- flexmock(module.borgmatic.borg.create).should_receive('create_archive').once()
- flexmock(module.borgmatic.hooks.dispatch).should_receive('call_hooks').and_return(
- {'dump': mock_dump_process}
- )
- flexmock(module.borgmatic.hooks.dispatch).should_receive(
- 'call_hooks_even_if_unconfigured'
- ).and_return({})
- flexmock(module.borgmatic.actions.pattern).should_receive('collect_patterns').and_return(())
- flexmock(module.borgmatic.actions.pattern).should_receive('process_patterns').and_return([])
- flexmock(os.path).should_receive('join').and_return('/run/borgmatic/bootstrap')
- flexmock(module.borgmatic.borg.repo_list).should_receive('get_latest_archive').and_return(
- {'id': 'id1', 'name': 'archive.checkpoint'}
- )
- global_arguments = flexmock(monitoring_verbosity=1, dry_run=False)
- flexmock(module).should_receive('rename_checkpoint_archive').with_args(
- repository_path='repo',
- global_arguments=global_arguments,
- config={},
- local_borg_version=None,
- local_path=None,
- remote_path=None,
- ).once()
- create_arguments = flexmock(
- repository=None,
- progress=flexmock(),
- statistics=flexmock(),
- json=False,
- comment=None,
- list_details=flexmock(),
- )
- list(
- module.run_create(
- config_filename='test.yaml',
- repository={'path': 'repo'},
- config={},
- config_paths=['/tmp/test.yaml'],
- local_borg_version=None,
- create_arguments=create_arguments,
- global_arguments=global_arguments,
- dry_run_label='',
- local_path=None,
- remote_path=None,
- )
- )
- def test_run_create_with_active_dumps_json_updates_archive_info():
- mock_dump_process = flexmock()
- mock_dump_process.should_receive('poll').and_return(None).and_return(0)
- borg_create_result = {
- 'archive': {
- 'command_line': ['foo'],
- 'name': 'archive.checkpoint',
- 'id': 'id1',
- },
- 'cache': {},
- 'repository': {
- 'id': 'repo-id',
- },
- }
- expected_create_result = {
- 'archive': {
- 'command_line': ['foo'],
- 'name': 'archive',
- 'id': 'id2',
- },
- 'cache': {},
- 'repository': {'id': 'repo-id', 'label': ''},
- }
- flexmock(module.logger).answer = lambda message: None
- flexmock(module.borgmatic.config.validate).should_receive('repositories_match').never()
- flexmock(module.borgmatic.config.paths).should_receive('Runtime_directory').and_return(
- flexmock()
- )
- flexmock(module.borgmatic.borg.create).should_receive('create_archive').and_return(
- json.dumps(borg_create_result)
- ).once()
- flexmock(module.borgmatic.hooks.dispatch).should_receive('call_hooks').and_return(
- {'dump': mock_dump_process}
- )
- flexmock(module.borgmatic.hooks.dispatch).should_receive(
- 'call_hooks_even_if_unconfigured'
- ).and_return({})
- flexmock(module.borgmatic.actions.pattern).should_receive('collect_patterns').and_return(())
- flexmock(module.borgmatic.actions.pattern).should_receive('process_patterns').and_return([])
- flexmock(os.path).should_receive('join').and_return('/run/borgmatic/bootstrap')
- global_arguments = flexmock(monitoring_verbosity=1, dry_run=False)
- flexmock(module).should_receive('rename_checkpoint_archive').with_args(
- repository_path='repo',
- global_arguments=global_arguments,
- config={},
- local_borg_version=None,
- local_path=None,
- remote_path=None,
- ).once()
- flexmock(module.borgmatic.borg.repo_list).should_receive('get_latest_archive').and_return(
- {'id': 'id2', 'name': 'archive'},
- )
- create_arguments = flexmock(
- repository=None,
- progress=flexmock(),
- statistics=flexmock(),
- json=True,
- comment=None,
- list_details=flexmock(),
- )
- assert list(
- module.run_create(
- config_filename='test.yaml',
- repository={'path': 'repo'},
- config={},
- config_paths=['/tmp/test.yaml'],
- local_borg_version=None,
- create_arguments=create_arguments,
- global_arguments=global_arguments,
- dry_run_label='',
- local_path=None,
- remote_path=None,
- )
- ) == [expected_create_result]
- def test_rename_checkpoint_archive_renames_archive():
- global_arguments = flexmock(monitoring_verbosity=1, dry_run=False)
- flexmock(module.borgmatic.borg.repo_list).should_receive('get_latest_archive').and_return(
- {'id': 'id1', 'name': 'archive.checkpoint'}
- )
- flexmock(module.borgmatic.borg.rename).should_receive('rename_archive').with_args(
- repository_name='path',
- old_archive_name='archive.checkpoint',
- new_archive_name='archive',
- dry_run=False,
- config={},
- local_borg_version=None,
- local_path=None,
- remote_path=None,
- )
- module.rename_checkpoint_archive(
- repository_path='path',
- global_arguments=global_arguments,
- config={},
- local_borg_version=None,
- local_path=None,
- remote_path=None,
- )
- def test_rename_checkpoint_archive_checks_suffix():
- global_arguments = flexmock(monitoring_verbosity=1, dry_run=False)
- flexmock(module.borgmatic.borg.repo_list).should_receive('get_latest_archive').and_return(
- {'id': 'id1', 'name': 'unexpected-archive'}
- )
- with pytest.raises(
- ValueError,
- match='Latest archive did not have a .checkpoint suffix. Got: unexpected-archive',
- ):
- module.rename_checkpoint_archive(
- repository_path='path',
- global_arguments=global_arguments,
- config={},
- local_borg_version=None,
- local_path=None,
- remote_path=None,
- )
|