test_borgmatic.py 3.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  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).should_receive('run_configuration')
  45. args = flexmock(extract=False)
  46. logs = tuple(module.collect_configuration_run_summary_logs(('test.yaml',), args=args))
  47. assert any(log for log in logs if log.levelno == module.logging.INFO)
  48. def test_collect_configuration_run_summary_still_succeeds_when_extract_true():
  49. flexmock(module.validate).should_receive('parse_configuration').and_return({'test.yaml': {}})
  50. flexmock(module.validate).should_receive('guard_configuration_contains_repository')
  51. flexmock(module).should_receive('run_configuration')
  52. args = flexmock(extract=True, repository='repo')
  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.INFO)
  55. def test_collect_configuration_run_summary_logs_critical_for_parse_error():
  56. flexmock(module.validate).should_receive('parse_configuration').and_raise(ValueError)
  57. args = flexmock(extract=False)
  58. logs = tuple(module.collect_configuration_run_summary_logs(('test.yaml',), args=args))
  59. assert any(log for log in logs if log.levelno == module.logging.CRITICAL)
  60. def test_collect_configuration_run_summary_logs_critical_for_run_error():
  61. flexmock(module.validate).should_receive('parse_configuration').and_return({'test.yaml': {}})
  62. flexmock(module.validate).should_receive('guard_configuration_contains_repository')
  63. flexmock(module).should_receive('run_configuration').and_raise(ValueError)
  64. args = flexmock(extract=False)
  65. logs = tuple(module.collect_configuration_run_summary_logs(('test.yaml',), args=args))
  66. assert any(log for log in logs if log.levelno == module.logging.CRITICAL)
  67. def test_collect_configuration_run_summary_logs_critical_for_missing_configs():
  68. flexmock(module.validate).should_receive('parse_configuration').and_return({'test.yaml': {}})
  69. flexmock(module).should_receive('run_configuration')
  70. args = flexmock(config_paths=(), extract=False)
  71. logs = tuple(module.collect_configuration_run_summary_logs(config_filenames=(), args=args))
  72. assert any(log for log in logs if log.levelno == module.logging.CRITICAL)