From 1488cebff1817b885f6292d8e3ce8329b799d233 Mon Sep 17 00:00:00 2001 From: Thomas Castleman Date: Mon, 26 Dec 2022 00:10:42 -0500 Subject: [PATCH] add tests for get_drive_path(), implement fix affecting NVMe and eMMC RAID setup --- DEBIAN/control | 2 +- usr/bin/system-installer.cxx | 2 +- .../system-installer/auto_partitioner.py | 6 +- .../tests/test_auto_partitioner.py | 113 ++++++++++++++++++ 4 files changed, 120 insertions(+), 3 deletions(-) diff --git a/DEBIAN/control b/DEBIAN/control index b3d7026..8d81c2d 100644 --- a/DEBIAN/control +++ b/DEBIAN/control @@ -1,5 +1,5 @@ Package: system-installer -Version: 2.4.3 +Version: 2.4.4 Maintainer: Thomas Castleman Homepage: https://github.com/drauger-os-development/system-installer Section: admin diff --git a/usr/bin/system-installer.cxx b/usr/bin/system-installer.cxx index f2bd0cb..c4c562d 100644 --- a/usr/bin/system-installer.cxx +++ b/usr/bin/system-installer.cxx @@ -46,7 +46,7 @@ using namespace std; -str VERSION = "2.4.3"; +str VERSION = "2.4.4"; str R = "\033[0;31m"; str G = "\033[0;32m"; str Y = "\033[1;33m"; diff --git a/usr/share/system-installer/auto_partitioner.py b/usr/share/system-installer/auto_partitioner.py index e48fee7..1459c85 100755 --- a/usr/share/system-installer/auto_partitioner.py +++ b/usr/share/system-installer/auto_partitioner.py @@ -174,7 +174,11 @@ def size_of_part(part_path, bytes=False): def get_drive_path(part_path): """Get drive path from partition path""" if ("nvme" in part_path) or ("mmc" in part_path): - output = part_path[:part_path.index("p")] + try: + output = part_path[:part_path.index("p")] + except ValueError: + # this might be a device with no partitions. + return part_path else: count = 0 for each in part_path: diff --git a/usr/share/system-installer/tests/test_auto_partitioner.py b/usr/share/system-installer/tests/test_auto_partitioner.py index 81c0d67..a2284bf 100755 --- a/usr/share/system-installer/tests/test_auto_partitioner.py +++ b/usr/share/system-installer/tests/test_auto_partitioner.py @@ -24,6 +24,8 @@ """Tests for auto_partitioner""" import auto_partitioner as ap import os +import random +import json def test_get_min_root_size_with_swap_part(): """Make sure our math is correct to get the min root size, assuming no swap partition""" @@ -45,3 +47,114 @@ def test_get_min_root_size_without_swap_part(): def test_is_EFI(): """Check if the checks if a system is an EFI system are working""" assert os.path.isdir("/boot/efi") == ap.is_EFI() + + +def test_get_drive_path(): + """Ensure drive paths are always returned correctly""" + # initial setup + nvme = "/dev/nvme" + mmcblk = "/dev/mmcblk" + sata = "/dev/sd" + ide = "/dev/hd" + drive_letters = ["a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", + "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", + "w", "x", "y", "z"] + nvme_list = {} + mmcblk_list = {} + sata_list = {} + ide_list = {} + # NVMe setup + for each in range(random.randint(1, 45)): + nvme_list[nvme + str(each)] = {} + for each in nvme_list: + total_drive_count = random.randint(1, 256) + for current_drive_count in range(1, total_drive_count): + nvme_list[each][each + "n" + str(current_drive_count)] = [] + """ + At this point, `nvme_list` should be set up like this: + + { + "/dev/nvme1": { + "/dev/nvme1n1": [], + "/dev/nvme1n2": [] + }, + "/dev/nvme2": { + "/dev/nvme2n1": [], + "/dev/nvme2n2": [] + } + } + + But we want this: + + { + "/dev/nvme1": { + "/dev/nvme1n1": [ + "/dev/nvme1n1p1", + "/dev/nvme1n1p2", + "/dev/nvme1n1p3" + ], + "/dev/nvme1n2": ["/dev/nvme1n2p1"] + }, + "/dev/nvme2": { + "/dev/nvme2n1": [ + "/dev/nvme2n1p1", + "/dev/nvme2n1p2" + ], + "/dev/nvme2n2": [ + "/dev/nvme2n2p1", + "/dev/nvme2n2p2", + "/dev/nvme2n2p3", + "/dev/nvme2n2p4" + ] + } + } + + Just, larger. + """ + for each in nvme_list: + for each1 in nvme_list[each]: + for part_count in range(1, random.randint(1, 256)): + nvme_list[each][each1].append(each1 + "p" + str(part_count)) + # now we need to set up mmcblk, SATA, and IDE drive examples. Should be simple... + # SATA set up + for each in range(random.randint(1, len(drive_letters) - 1)): + sata_list[sata + drive_letters[each]] = [] + for each in range(1, random.randint(1, 256)): + for each1 in sata_list: + sata_list[each1].append(each1 + str(each)) + # IDE set up + for each in range(random.randint(1, len(drive_letters) - 1)): + ide_list[ide + drive_letters[each]] = [] + for each in range(1, random.randint(1, 256)): + for each1 in ide_list: + ide_list[each1].append(each1 + str(each)) + # now just to setup for mmcblk + for each in range(random.randint(1, 45)): + mmcblk_list[mmcblk + str(each)] = [] + for each in mmcblk_list: + total_drive_count = random.randint(1, 256) + for current_drive_count in range(1, total_drive_count): + mmcblk_list[each].append(each + "p" + str(current_drive_count)) + # check to make sure everything is valid + # check mmcblk + for each in mmcblk_list: + for each1 in mmcblk_list[each]: + assert each == ap.get_drive_path(each1) + assert each == ap.get_drive_path(each) + # check NVMe + for each in nvme_list: + # this, outter-most, loop needs no checks + for each1 in nvme_list[each]: + for each2 in nvme_list[each][each1]: + assert each1 == ap.get_drive_path(each2) + assert each1 == ap.get_drive_path(each1) + # check SATA + for each in sata_list: + for each1 in sata_list[each]: + assert each == ap.get_drive_path(each1) + assert each == ap.get_drive_path(each) + # check IDE + for each in ide_list: + for each1 in ide_list[each]: + assert each == ap.get_drive_path(each1) + assert each == ap.get_drive_path(each)