123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- from flexmock import flexmock
- from borgmatic.borg import passcommand as module
- def test_run_passcommand_does_not_raise():
- module.run_passcommand.cache_clear()
- flexmock(module.borgmatic.execute).should_receive(
- 'execute_command_and_capture_output'
- ).and_return('passphrase')
- assert module.run_passcommand('passcommand', working_directory=None) == 'passphrase'
- def test_get_passphrase_from_passcommand_with_configured_passcommand_runs_it():
- module.run_passcommand.cache_clear()
- flexmock(module.borgmatic.config.paths).should_receive('get_working_directory').and_return(
- '/working'
- )
- flexmock(module).should_receive('run_passcommand').with_args('command', '/working').and_return(
- 'passphrase'
- ).once()
- assert (
- module.get_passphrase_from_passcommand(
- {'encryption_passcommand': 'command'},
- )
- == 'passphrase'
- )
- def test_get_passphrase_from_passcommand_without_configured_passcommand_bails():
- flexmock(module).should_receive('run_passcommand').never()
- assert module.get_passphrase_from_passcommand({}) is None
- def test_run_passcommand_caches_passcommand_after_first_call():
- module.run_passcommand.cache_clear()
- flexmock(module.borgmatic.execute).should_receive(
- 'execute_command_and_capture_output'
- ).and_return('passphrase').once()
- assert module.run_passcommand('passcommand', working_directory=None) == 'passphrase'
- assert module.run_passcommand('passcommand', working_directory=None) == 'passphrase'
|