fix #84
This commit is contained in:
@ -8,12 +8,51 @@ class TestZfsNode(unittest2.TestCase):
|
|||||||
prepare_zpools()
|
prepare_zpools()
|
||||||
self.longMessage=True
|
self.longMessage=True
|
||||||
|
|
||||||
# #resume initial backup
|
def test_keepsource0target10queuedsend(self):
|
||||||
# def test_keepsource0(self):
|
"""Test if thinner doesnt destroy too much early on if there are no common snapshots YET. Issue #84"""
|
||||||
|
|
||||||
# #somehow only specifying --allow-empty --keep-source 0 failed:
|
with patch('time.strftime', return_value="20101111000000"):
|
||||||
# with patch('time.strftime', return_value="20101111000000"):
|
self.assertFalse(ZfsAutobackup(
|
||||||
# self.assertFalse(ZfsAutobackup("test test_target1 --verbose --allow-empty --keep-source 0".split(" ")).run())
|
"test test_target1 --no-progress --verbose --keep-source=0 --keep-target=10 --allow-empty --no-send".split(
|
||||||
|
" ")).run())
|
||||||
|
|
||||||
# with patch('time.strftime', return_value="20101111000001"):
|
with patch('time.strftime', return_value="20101111000001"):
|
||||||
# self.assertFalse(ZfsAutobackup("test test_target1 --verbose --allow-empty --keep-source 0".split(" ")).run())
|
self.assertFalse(ZfsAutobackup(
|
||||||
|
"test test_target1 --no-progress --verbose --keep-source=0 --keep-target=10 --allow-empty --no-send".split(
|
||||||
|
" ")).run())
|
||||||
|
|
||||||
|
with patch('time.strftime', return_value="20101111000002"):
|
||||||
|
self.assertFalse(ZfsAutobackup(
|
||||||
|
"test test_target1 --no-progress --verbose --keep-source=0 --keep-target=10 --allow-empty".split(
|
||||||
|
" ")).run())
|
||||||
|
|
||||||
|
r = shelltest("zfs list -H -o name -r -t all " + TEST_POOLS)
|
||||||
|
self.assertMultiLineEqual(r, """
|
||||||
|
test_source1
|
||||||
|
test_source1/fs1
|
||||||
|
test_source1/fs1@test-20101111000002
|
||||||
|
test_source1/fs1/sub
|
||||||
|
test_source1/fs1/sub@test-20101111000002
|
||||||
|
test_source2
|
||||||
|
test_source2/fs2
|
||||||
|
test_source2/fs2/sub
|
||||||
|
test_source2/fs2/sub@test-20101111000002
|
||||||
|
test_source2/fs3
|
||||||
|
test_source2/fs3/sub
|
||||||
|
test_target1
|
||||||
|
test_target1/test_source1
|
||||||
|
test_target1/test_source1/fs1
|
||||||
|
test_target1/test_source1/fs1@test-20101111000000
|
||||||
|
test_target1/test_source1/fs1@test-20101111000001
|
||||||
|
test_target1/test_source1/fs1@test-20101111000002
|
||||||
|
test_target1/test_source1/fs1/sub
|
||||||
|
test_target1/test_source1/fs1/sub@test-20101111000000
|
||||||
|
test_target1/test_source1/fs1/sub@test-20101111000001
|
||||||
|
test_target1/test_source1/fs1/sub@test-20101111000002
|
||||||
|
test_target1/test_source2
|
||||||
|
test_target1/test_source2/fs2
|
||||||
|
test_target1/test_source2/fs2/sub
|
||||||
|
test_target1/test_source2/fs2/sub@test-20101111000000
|
||||||
|
test_target1/test_source2/fs2/sub@test-20101111000001
|
||||||
|
test_target1/test_source2/fs2/sub@test-20101111000002
|
||||||
|
""")
|
||||||
|
|||||||
@ -312,8 +312,6 @@ test_target1/test_source2/fs2
|
|||||||
self.assertFalse(ZfsAutobackup("test test_target1 --verbose --no-send --no-progress".split(" ")).run())
|
self.assertFalse(ZfsAutobackup("test test_target1 --verbose --no-send --no-progress".split(" ")).run())
|
||||||
|
|
||||||
r=shelltest("zfs list -H -o name -r -t all "+TEST_POOLS)
|
r=shelltest("zfs list -H -o name -r -t all "+TEST_POOLS)
|
||||||
#(only parents are created )
|
|
||||||
#TODO: it probably shouldn't create these
|
|
||||||
self.assertMultiLineEqual(r,"""
|
self.assertMultiLineEqual(r,"""
|
||||||
test_source1
|
test_source1
|
||||||
test_source1/fs1
|
test_source1/fs1
|
||||||
@ -337,8 +335,6 @@ test_target1
|
|||||||
self.assertFalse(ZfsAutobackup("test test_target1 --no-progress --verbose --ignore-replicated".split(" ")).run())
|
self.assertFalse(ZfsAutobackup("test test_target1 --no-progress --verbose --ignore-replicated".split(" ")).run())
|
||||||
|
|
||||||
r=shelltest("zfs list -H -o name -r -t all "+TEST_POOLS)
|
r=shelltest("zfs list -H -o name -r -t all "+TEST_POOLS)
|
||||||
#(only parents are created )
|
|
||||||
#TODO: it probably shouldn't create these
|
|
||||||
self.assertMultiLineEqual(r,"""
|
self.assertMultiLineEqual(r,"""
|
||||||
test_source1
|
test_source1
|
||||||
test_source1/fs1
|
test_source1/fs1
|
||||||
@ -851,7 +847,7 @@ test_target1/test_source2/fs2/sub@test-20101111000003
|
|||||||
""")
|
""")
|
||||||
|
|
||||||
|
|
||||||
# make snapshot 4, since we used no-holds, it will delete 3 on the source, breaking the backup
|
# run with snapshot-only for 4, since we used no-holds, it will delete 3 on the source, breaking the backup
|
||||||
with patch('time.strftime', return_value="20101111000004"):
|
with patch('time.strftime', return_value="20101111000004"):
|
||||||
self.assertFalse(ZfsAutobackup("test --no-progress --verbose --keep-source=0 --keep-target=0 --allow-empty".split(" ")).run())
|
self.assertFalse(ZfsAutobackup("test --no-progress --verbose --keep-source=0 --keep-target=0 --allow-empty".split(" ")).run())
|
||||||
|
|
||||||
|
|||||||
@ -16,7 +16,7 @@ from zfs_autobackup.ThinnerRule import ThinnerRule
|
|||||||
class ZfsAutobackup:
|
class ZfsAutobackup:
|
||||||
"""main class"""
|
"""main class"""
|
||||||
|
|
||||||
VERSION = "3.1-rc4"
|
VERSION = "3.1-rc5"
|
||||||
HEADER = "zfs-autobackup v{} - (c)2021 E.H.Eefting (edwin@datux.nl)".format(VERSION)
|
HEADER = "zfs-autobackup v{} - (c)2021 E.H.Eefting (edwin@datux.nl)".format(VERSION)
|
||||||
|
|
||||||
def __init__(self, argv, print_arguments=True):
|
def __init__(self, argv, print_arguments=True):
|
||||||
|
|||||||
@ -874,9 +874,13 @@ class ZfsDataset:
|
|||||||
:type target_keeps: list of ZfsDataset
|
:type target_keeps: list of ZfsDataset
|
||||||
"""
|
"""
|
||||||
|
|
||||||
# on source: destroy all obsoletes before common.
|
# on source: destroy all obsoletes before common. (since we cant send them anyways)
|
||||||
# But after common, only delete snapshots that target also doesn't want
|
# But after common, only delete snapshots that target also doesn't want
|
||||||
|
if common_snapshot:
|
||||||
before_common = True
|
before_common = True
|
||||||
|
else:
|
||||||
|
before_common = False
|
||||||
|
|
||||||
for source_snapshot in self.snapshots:
|
for source_snapshot in self.snapshots:
|
||||||
if common_snapshot and source_snapshot.snapshot_name == common_snapshot.snapshot_name:
|
if common_snapshot and source_snapshot.snapshot_name == common_snapshot.snapshot_name:
|
||||||
before_common = False
|
before_common = False
|
||||||
@ -888,8 +892,8 @@ class ZfsDataset:
|
|||||||
|
|
||||||
# on target: destroy everything thats obsolete, except common_snapshot
|
# on target: destroy everything thats obsolete, except common_snapshot
|
||||||
for target_snapshot in target_dataset.snapshots:
|
for target_snapshot in target_dataset.snapshots:
|
||||||
if (target_snapshot in target_obsoletes) and (
|
if (target_snapshot in target_obsoletes) \
|
||||||
not common_snapshot or target_snapshot.snapshot_name != common_snapshot.snapshot_name):
|
and ( not common_snapshot or (target_snapshot.snapshot_name != common_snapshot.snapshot_name)):
|
||||||
if target_snapshot.exists:
|
if target_snapshot.exists:
|
||||||
target_snapshot.destroy()
|
target_snapshot.destroy()
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user