mirror of
https://projects.torsion.org/witten/borgmatic.git
synced 2025-04-04 21:05:30 +00:00
Fix end-to-end tests and don't stat() directories that don't exist (#1048).
This commit is contained in:
parent
ab01e97a5e
commit
6f07402407
2 changed files with 25 additions and 1 deletions
|
@ -32,7 +32,7 @@ def get_contained_patterns(parent_directory, candidate_patterns):
|
|||
if not candidate_patterns:
|
||||
return ()
|
||||
|
||||
parent_device = os.stat(parent_directory).st_dev
|
||||
parent_device = os.stat(parent_directory).st_dev if os.path.exists(parent_directory) else None
|
||||
|
||||
contained_patterns = tuple(
|
||||
candidate
|
||||
|
|
|
@ -6,6 +6,7 @@ from borgmatic.hooks.data_source import snapshot as module
|
|||
|
||||
def test_get_contained_patterns_without_candidates_returns_empty():
|
||||
flexmock(module.os).should_receive('stat').and_return(flexmock(st_dev=flexmock()))
|
||||
flexmock(module.os.path).should_receive('exists').and_return(True)
|
||||
|
||||
assert module.get_contained_patterns('/mnt', {}) == ()
|
||||
|
||||
|
@ -13,6 +14,7 @@ def test_get_contained_patterns_without_candidates_returns_empty():
|
|||
def test_get_contained_patterns_with_self_candidate_returns_self():
|
||||
device = flexmock()
|
||||
flexmock(module.os).should_receive('stat').and_return(flexmock(st_dev=device))
|
||||
flexmock(module.os.path).should_receive('exists').and_return(True)
|
||||
candidates = {
|
||||
Pattern('/foo', device=device),
|
||||
Pattern('/mnt', device=device),
|
||||
|
@ -26,6 +28,7 @@ def test_get_contained_patterns_with_self_candidate_returns_self():
|
|||
def test_get_contained_patterns_with_self_candidate_and_caret_prefix_returns_self():
|
||||
device = flexmock()
|
||||
flexmock(module.os).should_receive('stat').and_return(flexmock(st_dev=device))
|
||||
flexmock(module.os.path).should_receive('exists').and_return(True)
|
||||
candidates = {
|
||||
Pattern('^/foo', device=device),
|
||||
Pattern('^/mnt', device=device),
|
||||
|
@ -39,6 +42,7 @@ def test_get_contained_patterns_with_self_candidate_and_caret_prefix_returns_sel
|
|||
def test_get_contained_patterns_with_child_candidate_returns_child():
|
||||
device = flexmock()
|
||||
flexmock(module.os).should_receive('stat').and_return(flexmock(st_dev=device))
|
||||
flexmock(module.os.path).should_receive('exists').and_return(True)
|
||||
candidates = {
|
||||
Pattern('/foo', device=device),
|
||||
Pattern('/mnt/subdir', device=device),
|
||||
|
@ -54,6 +58,7 @@ def test_get_contained_patterns_with_child_candidate_returns_child():
|
|||
def test_get_contained_patterns_with_grandchild_candidate_returns_child():
|
||||
device = flexmock()
|
||||
flexmock(module.os).should_receive('stat').and_return(flexmock(st_dev=device))
|
||||
flexmock(module.os.path).should_receive('exists').and_return(True)
|
||||
candidates = {
|
||||
Pattern('/foo', device=device),
|
||||
Pattern('/mnt/sub/dir', device=device),
|
||||
|
@ -70,6 +75,7 @@ def test_get_contained_patterns_ignores_child_candidate_on_another_device():
|
|||
one_device = flexmock()
|
||||
another_device = flexmock()
|
||||
flexmock(module.os).should_receive('stat').and_return(flexmock(st_dev=one_device))
|
||||
flexmock(module.os.path).should_receive('exists').and_return(True)
|
||||
candidates = {
|
||||
Pattern('/foo', device=one_device),
|
||||
Pattern('/mnt/subdir', device=another_device),
|
||||
|
@ -82,3 +88,21 @@ def test_get_contained_patterns_ignores_child_candidate_on_another_device():
|
|||
Pattern('/mnt/subdir', device=another_device),
|
||||
Pattern('/bar', device=one_device),
|
||||
}
|
||||
|
||||
|
||||
def test_get_contained_patterns_with_non_existent_parent_directory_ignores_child_candidate():
|
||||
device = flexmock()
|
||||
flexmock(module.os).should_receive('stat').and_return(flexmock(st_dev=device))
|
||||
flexmock(module.os.path).should_receive('exists').and_return(False)
|
||||
candidates = {
|
||||
Pattern('/foo', device=device),
|
||||
Pattern('/mnt/subdir', device=device),
|
||||
Pattern('/bar', device=device),
|
||||
}
|
||||
|
||||
assert module.get_contained_patterns('/mnt', candidates) == ()
|
||||
assert candidates == {
|
||||
Pattern('/foo', device=device),
|
||||
Pattern('/mnt/subdir', device=device),
|
||||
Pattern('/bar', device=device),
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue