2018-07-28 22:21:38 +01:00
|
|
|
import json
|
|
|
|
import sys
|
|
|
|
|
2018-07-28 23:02:17 +01:00
|
|
|
from flexmock import flexmock
|
|
|
|
|
2018-12-25 23:23:54 +00:00
|
|
|
from borgmatic.commands import borgmatic as module
|
2018-07-28 23:02:17 +01:00
|
|
|
|
2018-07-28 22:21:38 +01:00
|
|
|
|
2018-10-13 23:19:16 +01:00
|
|
|
def test_run_commands_handles_multiple_json_outputs_in_array():
|
2018-07-28 23:02:17 +01:00
|
|
|
(
|
2018-12-25 23:23:54 +00:00
|
|
|
flexmock(module)
|
2018-07-28 23:02:17 +01:00
|
|
|
.should_receive('_run_commands_on_repository')
|
|
|
|
.times(3)
|
|
|
|
.replace_with(
|
2018-09-30 06:45:00 +01:00
|
|
|
lambda args, consistency, json_results, local_path, location, remote_path, retention, storage, unexpanded_repository: json_results.append(
|
|
|
|
{"whatever": unexpanded_repository}
|
|
|
|
)
|
2018-07-28 23:02:17 +01:00
|
|
|
)
|
|
|
|
)
|
2018-07-28 22:21:38 +01:00
|
|
|
|
2018-07-28 23:02:17 +01:00
|
|
|
(
|
|
|
|
flexmock(sys.stdout)
|
|
|
|
.should_call("write")
|
|
|
|
.with_args(
|
|
|
|
json.dumps(
|
|
|
|
json.loads(
|
|
|
|
'''
|
|
|
|
[
|
|
|
|
{"whatever": "fake_repo1"},
|
|
|
|
{"whatever": "fake_repo2"},
|
|
|
|
{"whatever": "fake_repo3"}
|
|
|
|
]
|
2018-09-30 06:45:00 +01:00
|
|
|
'''
|
2018-07-28 23:02:17 +01:00
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
2018-07-28 22:21:38 +01:00
|
|
|
|
2018-12-25 23:23:54 +00:00
|
|
|
module._run_commands(
|
2018-07-28 23:02:17 +01:00
|
|
|
args=flexmock(json=True),
|
|
|
|
consistency=None,
|
|
|
|
local_path=None,
|
2018-09-30 06:45:00 +01:00
|
|
|
location={'repositories': ['fake_repo1', 'fake_repo2', 'fake_repo3']},
|
2018-07-28 23:02:17 +01:00
|
|
|
remote_path=None,
|
|
|
|
retention=None,
|
|
|
|
storage=None,
|
|
|
|
)
|
2018-12-25 23:23:54 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_collect_configuration_run_summary_logs_info_for_success():
|
|
|
|
flexmock(module).should_receive('run_configuration')
|
|
|
|
|
|
|
|
logs = tuple(module.collect_configuration_run_summary_logs(('test.yaml',), args=()))
|
|
|
|
|
|
|
|
assert any(log for log in logs if log.levelno == module.logging.INFO)
|
|
|
|
|
|
|
|
|
|
|
|
def test_collect_configuration_run_summary_logs_critical_for_error():
|
|
|
|
flexmock(module).should_receive('run_configuration').and_raise(ValueError)
|
|
|
|
|
|
|
|
logs = tuple(module.collect_configuration_run_summary_logs(('test.yaml',), args=()))
|
|
|
|
|
|
|
|
assert any(log for log in logs if log.levelno == module.logging.CRITICAL)
|
|
|
|
|
|
|
|
|
|
|
|
def test_collect_configuration_run_summary_logs_critical_for_missing_configs():
|
|
|
|
logs = tuple(
|
|
|
|
module.collect_configuration_run_summary_logs(
|
|
|
|
config_filenames=(), args=flexmock(config_paths=())
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
assert any(log for log in logs if log.levelno == module.logging.CRITICAL)
|