refactor(backups): privatize assert_restorable and restore_snapshot_from_id

This commit is contained in:
Houkime 2023-06-26 18:42:26 +00:00 committed by Inex Code
parent cb2273323f
commit f2161f0532
2 changed files with 28 additions and 28 deletions

View file

@ -209,31 +209,6 @@ class Backups:
### Restoring ### Restoring
# to be deprecated/internalized in favor of restore_snapshot()
@staticmethod
def restore_service_from_snapshot(service: Service, snapshot_id: str):
folders = service.get_folders()
Backups.provider().backupper.restore_from_backup(
snapshot_id,
folders,
)
@staticmethod
def assert_restorable(snapshot: Snapshot):
service = get_service_by_id(snapshot.service_name)
if service is None:
raise ValueError(
f"snapshot has a nonexistent service: {snapshot.service_name}"
)
needed_space = Backups.service_snapshot_size(snapshot.id)
available_space = Backups.space_usable_for_service(service)
if needed_space > available_space:
raise ValueError(
f"we only have {available_space} bytes "
f"but snapshot needs {needed_space}"
)
@staticmethod @staticmethod
def restore_snapshot(snapshot: Snapshot): def restore_snapshot(snapshot: Snapshot):
@ -253,8 +228,8 @@ class Backups:
status=JobStatus.RUNNING, status=JobStatus.RUNNING,
) )
try: try:
Backups.assert_restorable(snapshot) Backups._assert_restorable(snapshot)
Backups.restore_service_from_snapshot( Backups._restore_service_from_snapshot(
service, service,
snapshot.id, snapshot.id,
) )
@ -271,6 +246,31 @@ class Backups:
status=JobStatus.FINISHED, status=JobStatus.FINISHED,
) )
@staticmethod
def _assert_restorable(snapshot: Snapshot):
service = get_service_by_id(snapshot.service_name)
if service is None:
raise ValueError(
f"snapshot has a nonexistent service: {snapshot.service_name}"
)
needed_space = Backups.service_snapshot_size(snapshot.id)
available_space = Backups.space_usable_for_service(service)
if needed_space > available_space:
raise ValueError(
f"we only have {available_space} bytes "
f"but snapshot needs {needed_space}"
)
@staticmethod
def _restore_service_from_snapshot(service: Service, snapshot_id: str):
folders = service.get_folders()
Backups.provider().backupper.restore_from_backup(
snapshot_id,
folders,
)
### Snapshots ### Snapshots
@staticmethod @staticmethod

View file

@ -222,7 +222,7 @@ def test_restore(backups, dummy_service):
remove(p) remove(p)
assert not path.exists(p) assert not path.exists(p)
Backups.restore_service_from_snapshot(dummy_service, snap.id) Backups._restore_service_from_snapshot(dummy_service, snap.id)
for p, content in zip(paths_to_nuke, contents): for p, content in zip(paths_to_nuke, contents):
assert path.exists(p) assert path.exists(p)
with open(p, "r") as file: with open(p, "r") as file: