123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- import io
- import sys
- import pytest
- from flexmock import flexmock
- from borgmatic.hooks.credential import file as module
- @pytest.mark.parametrize('credential_parameters', ((), ('foo', 'bar')))
- def test_load_credential_with_invalid_credential_parameters_raises(credential_parameters):
- with pytest.raises(ValueError):
- module.load_credential(
- hook_config={}, config={}, credential_parameters=credential_parameters
- )
- def test_load_credential_with_invalid_credential_name_raises():
- with pytest.raises(ValueError):
- module.load_credential(
- hook_config={}, config={}, credential_parameters=('this is invalid',)
- )
- def test_load_credential_reads_named_credential_from_file():
- credential_stream = io.StringIO('password')
- credential_stream.name = '/credentials/mycredential'
- builtins = flexmock(sys.modules['builtins'])
- flexmock(module.os.path).should_receive('expanduser').with_args(
- '/credentials/mycredential'
- ).and_return('/credentials/mycredential')
- builtins.should_receive('open').with_args('/credentials/mycredential').and_return(
- credential_stream
- )
- assert (
- module.load_credential(
- hook_config={}, config={}, credential_parameters=('/credentials/mycredential',)
- )
- == 'password'
- )
- def test_load_credential_reads_named_credential_from_file_using_working_directory():
- credential_stream = io.StringIO('password')
- credential_stream.name = '/working/credentials/mycredential'
- builtins = flexmock(sys.modules['builtins'])
- flexmock(module.os.path).should_receive('expanduser').with_args(
- 'credentials/mycredential'
- ).and_return('credentials/mycredential')
- builtins.should_receive('open').with_args('/working/credentials/mycredential').and_return(
- credential_stream
- )
- assert (
- module.load_credential(
- hook_config={},
- config={'working_directory': '/working'},
- credential_parameters=('credentials/mycredential',),
- )
- == 'password'
- )
- def test_load_credential_with_file_not_found_error_raises():
- builtins = flexmock(sys.modules['builtins'])
- flexmock(module.os.path).should_receive('expanduser').with_args(
- '/credentials/mycredential'
- ).and_return('/credentials/mycredential')
- builtins.should_receive('open').with_args('/credentials/mycredential').and_raise(
- FileNotFoundError
- )
- with pytest.raises(ValueError):
- module.load_credential(
- hook_config={}, config={}, credential_parameters=('/credentials/mycredential',)
- )
- def test_load_credential_reads_named_credential_from_expanded_directory():
- credential_stream = io.StringIO('password')
- credential_stream.name = '/root/credentials/mycredential'
- builtins = flexmock(sys.modules['builtins'])
- flexmock(module.os.path).should_receive('expanduser').with_args(
- '~/credentials/mycredential'
- ).and_return('/root/credentials/mycredential')
- builtins.should_receive('open').with_args('/root/credentials/mycredential').and_return(
- credential_stream
- )
- assert (
- module.load_credential(
- hook_config={}, config={}, credential_parameters=('~/credentials/mycredential',)
- )
- == 'password'
- )
|