123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118 |
- import io
- import sys
- import pytest
- from flexmock import flexmock
- from borgmatic.hooks.credential import systemd as module
- @pytest.mark.parametrize('credential_parameters', ((), ('foo', 'bar')))
- def test_load_credential_with_invalid_credential_parameters_raises(credential_parameters):
- flexmock(module.os.environ).should_receive('get').never()
- with pytest.raises(ValueError):
- module.load_credential(
- hook_config={},
- config={},
- credential_parameters=credential_parameters,
- )
- def test_load_credential_without_credentials_directory_falls_back_to_systemd_creds_command():
- flexmock(module.os.environ).should_receive('get').with_args('CREDENTIALS_DIRECTORY').and_return(
- None,
- )
- flexmock(module.borgmatic.execute).should_receive(
- 'execute_command_and_capture_output'
- ).with_args(('systemd-creds', 'decrypt', '/etc/credstore.encrypted/mycredential')).and_return(
- 'password'
- ).once()
- assert (
- module.load_credential(hook_config={}, config={}, credential_parameters=('mycredential',))
- == 'password'
- )
- def test_load_credential_without_credentials_directory_calls_custom_systemd_creds_command():
- flexmock(module.os.environ).should_receive('get').with_args('CREDENTIALS_DIRECTORY').and_return(
- None,
- )
- flexmock(module.borgmatic.execute).should_receive(
- 'execute_command_and_capture_output'
- ).with_args(
- ('/path/to/systemd-creds', '--flag', 'decrypt', '/etc/credstore.encrypted/mycredential')
- ).and_return('password').once()
- assert (
- module.load_credential(
- hook_config={'systemd_creds_command': '/path/to/systemd-creds --flag'},
- config={},
- credential_parameters=('mycredential',),
- )
- == 'password'
- )
- def test_load_credential_without_credentials_directory_uses_custom_encrypted_credentials_directory():
- flexmock(module.os.environ).should_receive('get').with_args('CREDENTIALS_DIRECTORY').and_return(
- None,
- )
- flexmock(module.borgmatic.execute).should_receive(
- 'execute_command_and_capture_output'
- ).with_args(('systemd-creds', 'decrypt', '/my/credstore.encrypted/mycredential')).and_return(
- 'password'
- ).once()
- assert (
- module.load_credential(
- hook_config={'encrypted_credentials_directory': '/my/credstore.encrypted'},
- config={},
- credential_parameters=('mycredential',),
- )
- == 'password'
- )
- def test_load_credential_with_invalid_credential_name_raises():
- flexmock(module.os.environ).should_receive('get').with_args('CREDENTIALS_DIRECTORY').and_return(
- '/var',
- )
- with pytest.raises(ValueError):
- module.load_credential(
- hook_config={},
- config={},
- credential_parameters=('../../my!@#$credential',),
- )
- def test_load_credential_reads_named_credential_from_file():
- flexmock(module.os.environ).should_receive('get').with_args('CREDENTIALS_DIRECTORY').and_return(
- '/var',
- )
- credential_stream = io.StringIO('password')
- credential_stream.name = '/var/borgmatic.pw'
- builtins = flexmock(sys.modules['builtins'])
- builtins.should_receive('open').with_args('/var/borgmatic.pw', encoding='utf-8').and_return(
- credential_stream
- )
- assert (
- module.load_credential(hook_config={}, config={}, credential_parameters=('borgmatic.pw',))
- == 'password'
- )
- def test_load_credential_with_file_not_found_error_raises():
- flexmock(module.os.environ).should_receive('get').with_args('CREDENTIALS_DIRECTORY').and_return(
- '/var',
- )
- builtins = flexmock(sys.modules['builtins'])
- builtins.should_receive('open').with_args('/var/mycredential', encoding='utf-8').and_raise(
- FileNotFoundError
- )
- with pytest.raises(ValueError):
- module.load_credential(hook_config={}, config={}, credential_parameters=('mycredential',))
|