Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Enhance tracing to hunt for restore bug #34

Merged
merged 1 commit into from
Aug 1, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions disktools.py
Original file line number Diff line number Diff line change
Expand Up @@ -1117,6 +1117,7 @@ def probePartitioningScheme(device):
if out == 'dos':
partitionType = constants.PARTITION_DOS

logger.debug("probePartitioningScheme(%r) => %r", device, partitionType)
return partitionType

def PartitionTool(device, partitionType=None):
Expand Down
6 changes: 6 additions & 0 deletions diskutil.py
Original file line number Diff line number Diff line change
Expand Up @@ -493,6 +493,8 @@ def __init__(self, device):
self.storage = (None, None)
self.logs = (False, None)
self.swap = (False, None)
def __str__(self):
return "Disk({})".format(self.__dict__)

INSTALL_RETAIL = 1
STORAGE_LVM = 1
Expand All @@ -512,10 +514,12 @@ def probeDisk(device):
swap is a tuple of True or False and the partition device
"""

logger.debug("probeDisk(%r)", device)
disk = Disk(device)
possible_srs = []

tool = PartitionTool(device)
tool.dump()
for num, part in tool.items():
label = None
part_device = tool._partitionDevice(num)
Expand Down Expand Up @@ -543,6 +547,8 @@ def probeDisk(device):
disk.swap = (True, part_device)
elif part['id'] == GPTPartitionTool.ID_EFI_BOOT or part['id'] == GPTPartitionTool.ID_BIOS_BOOT:
disk.boot = (True, part_device)
else:
logger.info("part %s has unknown id: %s", num, part)

lv_tool = len(possible_srs) and LVMTool()
for num in possible_srs:
Expand Down
3 changes: 3 additions & 0 deletions restore.py
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,8 @@ def restoreFromBackup(backup, progress=lambda x: ()):
assert disk_device.startswith('/dev/')

restore_partition = disk.root[1]
if not isinstance(restore_partition, str):
raise RuntimeError("failed to identify root partition to restore to, disk=%s" % disk)
logger.log("Restoring to partition %s." % restore_partition)

boot_part = tool.getPartition(boot_partnum)
Expand Down Expand Up @@ -138,6 +140,7 @@ def restore_partitions():
try:
util.mkfs(constants.rootfs_type, restore_partition)
except Exception as e:
logger.critical("Failed to create root filesystem", exc_info=1)
raise RuntimeError("Failed to create root filesystem: %s" % e)

if efi_boot:
Expand Down