| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- import logging
- import platform
- from flexmock import flexmock
- from borgmatic.hooks.monitoring import loki as module
- def test_initialize_monitor_replaces_labels():
- '''
- Assert that label placeholders get replaced.
- '''
- hook_config = {
- 'url': 'http://localhost:3100/loki/api/v1/push',
- 'labels': {'hostname': '__hostname', 'config': '__config', 'config_full': '__config_path'},
- }
- config_filename = '/mock/path/test.yaml'
- module.initialize_monitor(hook_config, flexmock(), config_filename, flexmock(), dry_run=False)
- for handler in tuple(logging.getLogger().handlers):
- if isinstance(handler, module.Loki_log_handler):
- assert handler.buffer.root['streams'][0]['stream']['hostname'] == platform.node()
- assert handler.buffer.root['streams'][0]['stream']['config'] == 'test.yaml'
- assert handler.buffer.root['streams'][0]['stream']['config_full'] == config_filename
- return
- raise AssertionError()
- def test_initialize_monitor_adds_log_handler():
- '''
- Assert that calling initialize_monitor adds our logger to the root logger.
- '''
- hook_config = {'url': 'http://localhost:3100/loki/api/v1/push', 'labels': {'app': 'borgmatic'}}
- module.initialize_monitor(
- hook_config,
- flexmock(),
- config_filename='test.yaml',
- monitoring_log_level=flexmock(),
- dry_run=True,
- )
- for handler in tuple(logging.getLogger().handlers):
- if isinstance(handler, module.Loki_log_handler):
- return
- raise AssertionError()
- def test_ping_monitor_sends_log_message():
- '''
- Assert that calling ping_monitor sends a message to Loki via our logger.
- '''
- hook_config = {'url': 'http://localhost:3100/loki/api/v1/push', 'labels': {'app': 'borgmatic'}}
- config_filename = 'test.yaml'
- post_called = False
- def post(url, data, timeout, headers):
- nonlocal post_called
- post_called = True
- assert any(
- value[1] == f'{module.MONITOR_STATE_TO_LOKI[module.monitor.State.FINISH]} backup'
- for value in module.json.loads(data)['streams'][0]['values']
- )
- return flexmock(raise_for_status=lambda: None)
- flexmock(module.requests).should_receive('post').replace_with(post)
- module.initialize_monitor(hook_config, flexmock(), config_filename, flexmock(), dry_run=False)
- module.ping_monitor(
- hook_config,
- flexmock(),
- config_filename,
- module.monitor.State.FINISH,
- flexmock(),
- dry_run=False,
- )
- module.destroy_monitor(hook_config, flexmock(), flexmock(), dry_run=False)
- assert post_called
- def test_destroy_monitor_removes_log_handler():
- '''
- Assert that destroy_monitor removes the logger from the root logger.
- '''
- hook_config = {'url': 'http://localhost:3100/loki/api/v1/push', 'labels': {'app': 'borgmatic'}}
- config_filename = 'test.yaml'
- flexmock(module.requests).should_receive('post').never()
- module.initialize_monitor(hook_config, flexmock(), config_filename, flexmock(), dry_run=False)
- module.destroy_monitor(hook_config, flexmock(), flexmock(), dry_run=False)
- for handler in tuple(logging.getLogger().handlers):
- if isinstance(handler, module.Loki_log_handler):
- raise AssertionError()
|