test_borgmatic.py 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. import json
  2. import sys
  3. from flexmock import flexmock
  4. from borgmatic.commands import borgmatic as module
  5. def test_run_commands_handles_multiple_json_outputs_in_array():
  6. (
  7. flexmock(module)
  8. .should_receive('_run_commands_on_repository')
  9. .times(3)
  10. .replace_with(
  11. lambda args, consistency, json_results, local_path, location, remote_path, retention, storage, unexpanded_repository: json_results.append(
  12. {"whatever": unexpanded_repository}
  13. )
  14. )
  15. )
  16. (
  17. flexmock(sys.stdout)
  18. .should_call("write")
  19. .with_args(
  20. json.dumps(
  21. json.loads(
  22. '''
  23. [
  24. {"whatever": "fake_repo1"},
  25. {"whatever": "fake_repo2"},
  26. {"whatever": "fake_repo3"}
  27. ]
  28. '''
  29. )
  30. )
  31. )
  32. )
  33. module._run_commands(
  34. args=flexmock(json=True),
  35. consistency=None,
  36. local_path=None,
  37. location={'repositories': ['fake_repo1', 'fake_repo2', 'fake_repo3']},
  38. remote_path=None,
  39. retention=None,
  40. storage=None,
  41. )
  42. def test_collect_configuration_run_summary_logs_info_for_success():
  43. flexmock(module.validate).should_receive('parse_configuration').and_return({'test.yaml': {}})
  44. flexmock(module.validate).should_receive('guard_configuration_contains_repository')
  45. flexmock(module).should_receive('run_configuration')
  46. args = flexmock(repository=None)
  47. logs = tuple(module.collect_configuration_run_summary_logs(('test.yaml',), args=args))
  48. assert any(log for log in logs if log.levelno == module.logging.INFO)
  49. def test_collect_configuration_run_summary_logs_critical_for_parse_error():
  50. flexmock(module.validate).should_receive('parse_configuration').and_raise(ValueError)
  51. flexmock(module.validate).should_receive('guard_configuration_contains_repository')
  52. args = flexmock(repository=None)
  53. logs = tuple(module.collect_configuration_run_summary_logs(('test.yaml',), args=args))
  54. assert any(log for log in logs if log.levelno == module.logging.CRITICAL)
  55. def test_collect_configuration_run_summary_logs_critical_for_run_error():
  56. flexmock(module.validate).should_receive('parse_configuration').and_return({'test.yaml': {}})
  57. flexmock(module.validate).should_receive('guard_configuration_contains_repository')
  58. flexmock(module).should_receive('run_configuration').and_raise(ValueError)
  59. args = flexmock(repository=None)
  60. logs = tuple(module.collect_configuration_run_summary_logs(('test.yaml',), args=args))
  61. assert any(log for log in logs if log.levelno == module.logging.CRITICAL)
  62. def test_collect_configuration_run_summary_logs_critical_for_missing_configs():
  63. flexmock(module.validate).should_receive('parse_configuration').and_return({'test.yaml': {}})
  64. flexmock(module.validate).should_receive('guard_configuration_contains_repository')
  65. flexmock(module).should_receive('run_configuration')
  66. args = flexmock(config_paths=(), repository=None)
  67. logs = tuple(module.collect_configuration_run_summary_logs(config_filenames=(), args=args))
  68. assert any(log for log in logs if log.levelno == module.logging.CRITICAL)