| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374 | 
							- import pytest
 
- from flexmock import flexmock
 
- import borgmatic.execute
 
- from borgmatic.hooks import zfs as module
 
- def test_get_datasets_to_backup_filters_datasets_by_source_directories():
 
-     flexmock(borgmatic.execute).should_receive('execute_command_and_capture_output').and_return(
 
-         'dataset\t/dataset\t-\nother\t/other\t-',
 
-     )
 
-     assert module.get_datasets_to_backup(
 
-         'zfs', source_directories=('/foo', '/dataset', '/bar')
 
-     ) == (('dataset', '/dataset'),)
 
- def test_get_datasets_to_backup_filters_datasets_by_user_property():
 
-     flexmock(borgmatic.execute).should_receive('execute_command_and_capture_output').and_return(
 
-         'dataset\t/dataset\tauto\nother\t/other\t-',
 
-     )
 
-     assert module.get_datasets_to_backup('zfs', source_directories=('/foo', '/bar')) == (
 
-         ('dataset', '/dataset'),
 
-     )
 
- def test_get_datasets_to_backup_with_invalid_list_output_raises():
 
-     flexmock(borgmatic.execute).should_receive('execute_command_and_capture_output').and_return(
 
-         'dataset',
 
-     )
 
-     with pytest.raises(ValueError, match='zfs'):
 
-         module.get_datasets_to_backup('zfs', source_directories=('/foo', '/bar'))
 
- def test_get_get_all_datasets_does_not_filter_datasets():
 
-     flexmock(borgmatic.execute).should_receive('execute_command_and_capture_output').and_return(
 
-         'dataset\t/dataset\nother\t/other',
 
-     )
 
-     assert module.get_all_datasets('zfs') == (
 
-         ('dataset', '/dataset'),
 
-         ('other', '/other'),
 
-     )
 
- def test_get_all_datasets_with_invalid_list_output_raises():
 
-     flexmock(borgmatic.execute).should_receive('execute_command_and_capture_output').and_return(
 
-         'dataset',
 
-     )
 
-     with pytest.raises(ValueError, match='zfs'):
 
-         module.get_all_datasets('zfs')
 
- def test_dump_data_sources_snapshots_and_mounts_and_updates_source_directories():
 
-     flexmock(module).should_receive('get_datasets_to_backup').and_return(
 
-         (('dataset', '/mnt/dataset'),)
 
-     )
 
-     flexmock(module.os).should_receive('getpid').and_return(1234)
 
-     full_snapshot_name = 'dataset@borgmatic-1234'
 
-     flexmock(module).should_receive('snapshot_dataset').with_args(
 
-         'zfs',
 
-         full_snapshot_name,
 
-     ).once()
 
-     snapshot_mount_path = '/run/borgmatic/zfs_snapshots/./mnt/dataset'
 
-     flexmock(module).should_receive('mount_snapshot').with_args(
 
-         'mount',
 
-         full_snapshot_name,
 
-         module.os.path.normpath(snapshot_mount_path),
 
-     ).once()
 
-     source_directories = ['/mnt/dataset']
 
-     assert (
 
-         module.dump_data_sources(
 
-             hook_config={},
 
-             config={'source_directories': '/mnt/dataset', 'zfs': {}},
 
-             log_prefix='test',
 
-             borgmatic_runtime_directory='/run/borgmatic',
 
-             source_directories=source_directories,
 
-             dry_run=False,
 
-         )
 
-         == []
 
-     )
 
-     assert source_directories == [snapshot_mount_path]
 
- def test_dump_data_sources_uses_custom_commands():
 
-     flexmock(module).should_receive('get_datasets_to_backup').and_return(
 
-         (('dataset', '/mnt/dataset'),)
 
-     )
 
-     flexmock(module.os).should_receive('getpid').and_return(1234)
 
-     full_snapshot_name = 'dataset@borgmatic-1234'
 
-     flexmock(module).should_receive('snapshot_dataset').with_args(
 
-         '/usr/local/bin/zfs',
 
-         full_snapshot_name,
 
-     ).once()
 
-     snapshot_mount_path = '/run/borgmatic/zfs_snapshots/./mnt/dataset'
 
-     flexmock(module).should_receive('mount_snapshot').with_args(
 
-         '/usr/local/bin/mount',
 
-         full_snapshot_name,
 
-         module.os.path.normpath(snapshot_mount_path),
 
-     ).once()
 
-     source_directories = ['/mnt/dataset']
 
-     hook_config = {
 
-         'zfs_command': '/usr/local/bin/zfs',
 
-         'mount_command': '/usr/local/bin/mount',
 
-     }
 
-     assert (
 
-         module.dump_data_sources(
 
-             hook_config=hook_config,
 
-             config={
 
-                 'source_directories': source_directories,
 
-                 'zfs': hook_config,
 
-             },
 
-             log_prefix='test',
 
-             borgmatic_runtime_directory='/run/borgmatic',
 
-             source_directories=source_directories,
 
-             dry_run=False,
 
-         )
 
-         == []
 
-     )
 
-     assert source_directories == [snapshot_mount_path]
 
- def test_dump_data_sources_with_dry_run_skips_commands_and_does_not_touch_source_directories():
 
-     flexmock(module).should_receive('get_datasets_to_backup').and_return(
 
-         (('dataset', '/mnt/dataset'),)
 
-     )
 
-     flexmock(module.os).should_receive('getpid').and_return(1234)
 
-     flexmock(module).should_receive('snapshot_dataset').never()
 
-     flexmock(module).should_receive('mount_snapshot').never()
 
-     source_directories = ['/mnt/dataset']
 
-     assert (
 
-         module.dump_data_sources(
 
-             hook_config={},
 
-             config={'source_directories': '/mnt/dataset', 'zfs': {}},
 
-             log_prefix='test',
 
-             borgmatic_runtime_directory='/run/borgmatic',
 
-             source_directories=source_directories,
 
-             dry_run=True,
 
-         )
 
-         == []
 
-     )
 
-     assert source_directories == ['/mnt/dataset']
 
- def test_get_all_snapshots_parses_list_output():
 
-     flexmock(borgmatic.execute).should_receive('execute_command_and_capture_output').and_return(
 
-         'dataset1@borgmatic-1234\ndataset2@borgmatic-4567',
 
-     )
 
-     assert module.get_all_snapshots('zfs') == ('dataset1@borgmatic-1234', 'dataset2@borgmatic-4567')
 
- def test_remove_data_source_dumps_unmounts_and_destroys_snapshots():
 
-     flexmock(module).should_receive('get_all_datasets').and_return((('dataset', '/mnt/dataset'),))
 
-     flexmock(module.borgmatic.config.paths).should_receive(
 
-         'replace_temporary_subdirectory_with_glob'
 
-     ).and_return('/run/borgmatic')
 
-     flexmock(module.glob).should_receive('glob').replace_with(lambda path: [path])
 
-     flexmock(module.os.path).should_receive('isdir').and_return(True)
 
-     flexmock(module.shutil).should_receive('rmtree')
 
-     flexmock(module).should_receive('unmount_snapshot').with_args(
 
-         'umount', '/run/borgmatic/zfs_snapshots/mnt/dataset'
 
-     ).once()
 
-     flexmock(module).should_receive('get_all_snapshots').and_return(
 
-         ('dataset@borgmatic-1234', 'dataset@other', 'other@other', 'invalid')
 
-     )
 
-     flexmock(module).should_receive('destroy_snapshot').with_args(
 
-         'zfs', 'dataset@borgmatic-1234'
 
-     ).once()
 
-     module.remove_data_source_dumps(
 
-         hook_config={},
 
-         config={'source_directories': '/mnt/dataset', 'zfs': {}},
 
-         log_prefix='test',
 
-         borgmatic_runtime_directory='/run/borgmatic',
 
-         dry_run=False,
 
-     )
 
- def test_remove_data_source_dumps_use_custom_commands():
 
-     flexmock(module).should_receive('get_all_datasets').and_return((('dataset', '/mnt/dataset'),))
 
-     flexmock(module.borgmatic.config.paths).should_receive(
 
-         'replace_temporary_subdirectory_with_glob'
 
-     ).and_return('/run/borgmatic')
 
-     flexmock(module.glob).should_receive('glob').replace_with(lambda path: [path])
 
-     flexmock(module.os.path).should_receive('isdir').and_return(True)
 
-     flexmock(module.shutil).should_receive('rmtree')
 
-     flexmock(module).should_receive('unmount_snapshot').with_args(
 
-         '/usr/local/bin/umount', '/run/borgmatic/zfs_snapshots/mnt/dataset'
 
-     ).once()
 
-     flexmock(module).should_receive('get_all_snapshots').and_return(
 
-         ('dataset@borgmatic-1234', 'dataset@other', 'other@other', 'invalid')
 
-     )
 
-     flexmock(module).should_receive('destroy_snapshot').with_args(
 
-         '/usr/local/bin/zfs', 'dataset@borgmatic-1234'
 
-     ).once()
 
-     hook_config = {'zfs_command': '/usr/local/bin/zfs', 'umount_command': '/usr/local/bin/umount'}
 
-     module.remove_data_source_dumps(
 
-         hook_config=hook_config,
 
-         config={'source_directories': '/mnt/dataset', 'zfs': hook_config},
 
-         log_prefix='test',
 
-         borgmatic_runtime_directory='/run/borgmatic',
 
-         dry_run=False,
 
-     )
 
- def test_remove_data_source_dumps_bails_for_missing_zfs_command():
 
-     flexmock(module).should_receive('get_all_datasets').and_raise(FileNotFoundError)
 
-     flexmock(module.borgmatic.config.paths).should_receive(
 
-         'replace_temporary_subdirectory_with_glob'
 
-     ).never()
 
-     hook_config = {'zfs_command': 'wtf'}
 
-     module.remove_data_source_dumps(
 
-         hook_config=hook_config,
 
-         config={'source_directories': '/mnt/dataset', 'zfs': hook_config},
 
-         log_prefix='test',
 
-         borgmatic_runtime_directory='/run/borgmatic',
 
-         dry_run=False,
 
-     )
 
- def test_remove_data_source_dumps_bails_for_zfs_command_error():
 
-     flexmock(module).should_receive('get_all_datasets').and_raise(
 
-         module.subprocess.CalledProcessError(1, 'wtf')
 
-     )
 
-     flexmock(module.borgmatic.config.paths).should_receive(
 
-         'replace_temporary_subdirectory_with_glob'
 
-     ).never()
 
-     hook_config = {'zfs_command': 'wtf'}
 
-     module.remove_data_source_dumps(
 
-         hook_config=hook_config,
 
-         config={'source_directories': '/mnt/dataset', 'zfs': hook_config},
 
-         log_prefix='test',
 
-         borgmatic_runtime_directory='/run/borgmatic',
 
-         dry_run=False,
 
-     )
 
- def test_remove_data_source_dumps_bails_for_missing_umount_command():
 
-     flexmock(module).should_receive('get_all_datasets').and_return((('dataset', '/mnt/dataset'),))
 
-     flexmock(module.borgmatic.config.paths).should_receive(
 
-         'replace_temporary_subdirectory_with_glob'
 
-     ).and_return('/run/borgmatic')
 
-     flexmock(module.glob).should_receive('glob').replace_with(lambda path: [path])
 
-     flexmock(module.os.path).should_receive('isdir').and_return(True)
 
-     flexmock(module.shutil).should_receive('rmtree')
 
-     flexmock(module).should_receive('unmount_snapshot').with_args(
 
-         '/usr/local/bin/umount', '/run/borgmatic/zfs_snapshots/mnt/dataset'
 
-     ).and_raise(FileNotFoundError)
 
-     flexmock(module).should_receive('get_all_snapshots').never()
 
-     flexmock(module).should_receive('destroy_snapshot').never()
 
-     hook_config = {'zfs_command': '/usr/local/bin/zfs', 'umount_command': '/usr/local/bin/umount'}
 
-     module.remove_data_source_dumps(
 
-         hook_config=hook_config,
 
-         config={'source_directories': '/mnt/dataset', 'zfs': hook_config},
 
-         log_prefix='test',
 
-         borgmatic_runtime_directory='/run/borgmatic',
 
-         dry_run=False,
 
-     )
 
- def test_remove_data_source_dumps_bails_for_umount_command_error():
 
-     flexmock(module).should_receive('get_all_datasets').and_return((('dataset', '/mnt/dataset'),))
 
-     flexmock(module.borgmatic.config.paths).should_receive(
 
-         'replace_temporary_subdirectory_with_glob'
 
-     ).and_return('/run/borgmatic')
 
-     flexmock(module.glob).should_receive('glob').replace_with(lambda path: [path])
 
-     flexmock(module.os.path).should_receive('isdir').and_return(True)
 
-     flexmock(module.shutil).should_receive('rmtree')
 
-     flexmock(module).should_receive('unmount_snapshot').with_args(
 
-         '/usr/local/bin/umount', '/run/borgmatic/zfs_snapshots/mnt/dataset'
 
-     ).and_raise(module.subprocess.CalledProcessError(1, 'wtf'))
 
-     flexmock(module).should_receive('get_all_snapshots').never()
 
-     flexmock(module).should_receive('destroy_snapshot').never()
 
-     hook_config = {'zfs_command': '/usr/local/bin/zfs', 'umount_command': '/usr/local/bin/umount'}
 
-     module.remove_data_source_dumps(
 
-         hook_config=hook_config,
 
-         config={'source_directories': '/mnt/dataset', 'zfs': hook_config},
 
-         log_prefix='test',
 
-         borgmatic_runtime_directory='/run/borgmatic',
 
-         dry_run=False,
 
-     )
 
- def test_remove_data_source_dumps_skips_unmount_snapshot_directories_that_are_not_actually_directories():
 
-     flexmock(module).should_receive('get_all_datasets').and_return((('dataset', '/mnt/dataset'),))
 
-     flexmock(module.borgmatic.config.paths).should_receive(
 
-         'replace_temporary_subdirectory_with_glob'
 
-     ).and_return('/run/borgmatic')
 
-     flexmock(module.glob).should_receive('glob').replace_with(lambda path: [path])
 
-     flexmock(module.os.path).should_receive('isdir').and_return(False)
 
-     flexmock(module.shutil).should_receive('rmtree').never()
 
-     flexmock(module).should_receive('unmount_snapshot').never()
 
-     flexmock(module).should_receive('get_all_snapshots').and_return(
 
-         ('dataset@borgmatic-1234', 'dataset@other', 'other@other', 'invalid')
 
-     )
 
-     flexmock(module).should_receive('destroy_snapshot').with_args(
 
-         'zfs', 'dataset@borgmatic-1234'
 
-     ).once()
 
-     module.remove_data_source_dumps(
 
-         hook_config={},
 
-         config={'source_directories': '/mnt/dataset', 'zfs': {}},
 
-         log_prefix='test',
 
-         borgmatic_runtime_directory='/run/borgmatic',
 
-         dry_run=False,
 
-     )
 
- def test_remove_data_source_dumps_skips_unmount_snapshot_mount_paths_that_are_not_actually_directories():
 
-     flexmock(module).should_receive('get_all_datasets').and_return((('dataset', '/mnt/dataset'),))
 
-     flexmock(module.borgmatic.config.paths).should_receive(
 
-         'replace_temporary_subdirectory_with_glob'
 
-     ).and_return('/run/borgmatic')
 
-     flexmock(module.glob).should_receive('glob').replace_with(lambda path: [path])
 
-     flexmock(module.os.path).should_receive('isdir').with_args(
 
-         '/run/borgmatic/zfs_snapshots'
 
-     ).and_return(True)
 
-     flexmock(module.os.path).should_receive('isdir').with_args(
 
-         '/run/borgmatic/zfs_snapshots/mnt/dataset'
 
-     ).and_return(False)
 
-     flexmock(module.shutil).should_receive('rmtree')
 
-     flexmock(module).should_receive('unmount_snapshot').never()
 
-     flexmock(module).should_receive('get_all_snapshots').and_return(
 
-         ('dataset@borgmatic-1234', 'dataset@other', 'other@other', 'invalid')
 
-     )
 
-     flexmock(module).should_receive('destroy_snapshot').with_args(
 
-         'zfs', 'dataset@borgmatic-1234'
 
-     ).once()
 
-     module.remove_data_source_dumps(
 
-         hook_config={},
 
-         config={'source_directories': '/mnt/dataset', 'zfs': {}},
 
-         log_prefix='test',
 
-         borgmatic_runtime_directory='/run/borgmatic',
 
-         dry_run=False,
 
-     )
 
- def test_remove_data_source_dumps_with_dry_run_skips_unmount_and_destroy():
 
-     flexmock(module).should_receive('get_all_datasets').and_return((('dataset', '/mnt/dataset'),))
 
-     flexmock(module.borgmatic.config.paths).should_receive(
 
-         'replace_temporary_subdirectory_with_glob'
 
-     ).and_return('/run/borgmatic')
 
-     flexmock(module.glob).should_receive('glob').replace_with(lambda path: [path])
 
-     flexmock(module.os.path).should_receive('isdir').and_return(True)
 
-     flexmock(module.shutil).should_receive('rmtree').never()
 
-     flexmock(module).should_receive('unmount_snapshot').never()
 
-     flexmock(module).should_receive('get_all_snapshots').and_return(
 
-         ('dataset@borgmatic-1234', 'dataset@other', 'other@other', 'invalid')
 
-     )
 
-     flexmock(module).should_receive('destroy_snapshot').never()
 
-     module.remove_data_source_dumps(
 
-         hook_config={},
 
-         config={'source_directories': '/mnt/dataset', 'zfs': {}},
 
-         log_prefix='test',
 
-         borgmatic_runtime_directory='/run/borgmatic',
 
-         dry_run=True,
 
-     )
 
 
  |