def test_delete_host_partitions(): """ This test creates host partitions and the teardown deletes them. Arguments: * None Test Steps: * Create a partition on each host Teardown: * Re-create those partitions """ global partitions_to_restore partitions_to_restore = {} computes = system_helper.get_hosts(personality="compute") hosts = system_helper.get_controllers() + computes usable_disks = False for host in hosts: disks = storage_helper.get_host_disks(host) free_disks = storage_helper.get_host_disks_with_free_space(host, disks) if not free_disks: continue for disk_uuid in free_disks: size_gib = float(free_disks[disk_uuid]) partition_chunks = int(size_gib) if partition_chunks < 2: LOG.info( "Skip disk {} due to insufficient space".format(disk_uuid)) continue usable_disks = True LOG.info("Creating partition on {}".format(host)) rc, out = storage_helper.create_host_partition(host, disk_uuid, "1", fail_ok=False, wait=False) assert rc == 0, "Partition creation was expected to succeed but instead failed" # Check that first disk was created uuid = table_parser.get_value_two_col_table( table_parser.table(out), "uuid") storage_helper.wait_for_host_partition_status(host=host, uuid=uuid, timeout=CP_TIMEOUT) partitions_to_restore[host] = [] partitions_to_restore[host].append(uuid) # Only test one disk on each host break if not usable_disks: skip("Did not find disks with sufficient space to test with.")
def test_increase_host_partition_size_beyond_avail_disk_space(): """ This test attempts to increase the size of an existing host partition beyond the available space on disk. It is expected to fail. Assumptions: * Partitions are available in Ready state. Test steps: * Create partition * Modify the partition to consume over than the available disk space Teardown: * Delete created partitions """ global partitions_to_restore partitions_to_restore = {} computes = system_helper.get_hosts(personality="compute") hosts = system_helper.get_controllers() + computes usable_disks = False for host in hosts: disks = storage_helper.get_host_disks(host) free_disks = storage_helper.get_host_disks_with_free_space(host, disks) if not free_disks: continue for disk_uuid in free_disks: size_gib = float(free_disks[disk_uuid]) partition_chunks = int(size_gib) if partition_chunks < 2: LOG.info( "Skip disk {} due to insufficient space".format(disk_uuid)) continue usable_disks = True LOG.info("Creating partition on {}".format(host)) rc, out = storage_helper.create_host_partition(host, disk_uuid, "1", fail_ok=False, wait=False) assert rc == 0, "Partition creation was expected to succeed but instead failed" # Check that first disk was created uuid = table_parser.get_value_two_col_table( table_parser.table(out), "uuid") storage_helper.wait_for_host_partition_status(host=host, uuid=uuid, timeout=CP_TIMEOUT) partitions_to_restore[host] = [] partitions_to_restore[host].append(uuid) device_node = storage_helper.get_host_partition_values( host, uuid, "device_node")[0] device_node = device_node.rstrip(string.digits) if device_node.startswith("/dev/nvme"): device_node = device_node[:-1] size_gib += 1 LOG.tc_step( "Modifying partition {} from size 1 to size {} from host {} on device node {}" .format(uuid, int(size_gib), host, device_node)) rc, out = storage_helper.modify_host_partition(host, uuid, str(int(size_gib)), fail_ok=True) assert rc != 0, "Expected partition modification to fail and instead it succeeded" LOG.info(out) # Only test one disk on each host break if not usable_disks: skip("Did not find disks with sufficient space to test with.")
def test_decrease_host_partition_size(): """ This test attempts to decrease the size of an existing host partition. It is expected to fail since decreasing the size of a partition is not supported. Test Steps: * Create a partition * Modify the partition to decrease its size Teardown: * Delete created partition """ global partitions_to_restore partitions_to_restore = {} computes = system_helper.get_hosts(personality="compute") hosts = system_helper.get_controllers() + computes usable_disks = False for host in hosts: disks = storage_helper.get_host_disks(host) free_disks = storage_helper.get_host_disks_with_free_space(host, disks) if not free_disks: continue for disk_uuid in free_disks: size_gib = float(free_disks[disk_uuid]) partition_chunks = int(size_gib) if partition_chunks < 2: LOG.info( "Skip disk {} due to insufficient space".format(disk_uuid)) continue usable_disks = True LOG.info("Creating partition on {}".format(host)) rc, out = storage_helper.create_host_partition(host, disk_uuid, "1", fail_ok=False, wait=False) assert rc == 0, "Partition creation was expected to succeed but instead failed" # Check that first disk was created uuid = table_parser.get_value_two_col_table( table_parser.table(out), "uuid") storage_helper.wait_for_host_partition_status(host=host, uuid=uuid, timeout=CP_TIMEOUT) partitions_to_restore[host] = [] partitions_to_restore[host].append(uuid) device_node, size_gib = storage_helper.get_host_partition_values( host, uuid, ("device_node", "size_gib")) total_size = int(size_gib) - 1 LOG.tc_step( "Modifying partition {} from size {} to size {} from host {} on device node {}" .format(uuid, int(size_gib), str(total_size), host, device_node[:-1])) rc, out = storage_helper.modify_host_partition(host, uuid, str(total_size), fail_ok=True) assert rc != 0, "Expected partition modification to fail and instead it succeeded" # Only test one disk on each host break if not usable_disks: skip("Did not find disks with sufficient space to test with.")
def test_attempt_host_unlock_during_partition_creation(): """ This test attempts to unlock a host while a partition is being created. It is expected to fail. Assumptions: * There's some free disk space available Test steps: * Query the hosts to determine disk space * Lock host * Create a partition but don't wait for completion * Attempt to unlock the host that is hosting the partition that is created Teardown: * Delete created partitions DISABLED since unlock while creating is not blocked. """ global partitions_to_restore partitions_to_restore = {} computes = system_helper.get_hosts(personality="compute") hosts = system_helper.get_controllers() + computes # Filter out active controller active_controller = system_helper.get_active_controller_name() print("This is active controller: {}".format(active_controller)) hosts.remove(active_controller) usable_disks = False for host in hosts: disks = storage_helper.get_host_disks(host) free_disks = storage_helper.get_host_disks_with_free_space(host, disks) if not free_disks: continue for uuid in free_disks: size_gib = float(free_disks[uuid]) if size_gib < 2.0: LOG.info("Skip this disk due to insufficient space") continue LOG.tc_step("Lock {} and create a partition for disk {}".format( host, uuid)) HostsToRecover.add(host) host_helper.lock_host(host) usable_disks = True LOG.info("Creating partition on {}".format(host)) rc, out = storage_helper.create_host_partition(host, uuid, int(size_gib), wait=False) uuid = table_parser.get_value_two_col_table( table_parser.table(out), "uuid") partitions_to_restore[host] = [] partitions_to_restore[host].append(uuid) LOG.tc_step( "Attempt to unlock host and ensure it's rejected when partition is " "being created") rc_ = host_helper.unlock_host(host, fail_ok=True, check_first=False)[0] assert rc_ != 0, "Unlock attempt unexpectedly passed" LOG.tc_step("wait for partition to be created") storage_helper.wait_for_host_partition_status(host=host, uuid=uuid, timeout=CP_TIMEOUT) container_helper.wait_for_apps_status(apps='platform-integ-apps', status=AppStatus.APPLIED, check_interval=10) # Only test one disk on each host break # Do it on one host only break if not usable_disks: skip("Did not find disks with sufficient space to test with.")
def _test_create_partition_and_associate_with_pv_cgts_vg(): """ This test attempt to create a partition and then associate it with a PV (physical volume), resulting in the partition being In-use. Assumptions: * There's some free disk space available Test steps: * Query hosts to determine disk space * Create partition * Associate it with cgts-vg PV * Checks the partition is in-use state * Attempts to delete the partition that is in-use. It should fail. * Attempt to assign the in-use partition to another PV. It should fail. Teardown: * None DISABLING: This fails since the partition says 'adding on unlock'. Should it be in-service? Follow up with dev. """ global partitions_to_restore partitions_to_restore = {} if not system_helper.is_aio_system(): skip("This test requires an AIO system.") hosts = system_helper.get_controllers() for host in hosts: disks = storage_helper.get_host_disks(host) free_disks = storage_helper.get_host_disks_with_free_space(host, disks) if not free_disks: continue for uuid in free_disks: size_gib = float(free_disks[uuid]) if size_gib <= 1: LOG.tc_step("Skip this disk due to insufficient space") continue LOG.info("Creating partition on {}".format(host)) rc, out = storage_helper.create_host_partition(host, uuid, "1") uuid = table_parser.get_value_two_col_table( table_parser.table(out), "uuid") partitions_to_restore[host] = [] partitions_to_restore[host].append(uuid) LOG.tc_step("Associating partition {} with cgts-vg".format(uuid)) # cmd = "host-pv-add -t partition {} cgts-vg {}".format(host, uuid) cmd = "host-pv-add {} cgts-vg {}".format(host, uuid) rc, out = cli.system(cmd) assert rc == 0, "Associating partition with PV failed" LOG.tc_step("Check that partition is In-use state") storage_helper.wait_for_host_partition_status( host=host, uuid=uuid, final_status=PartitionStatus.IN_USE, interim_status=PartitionStatus.READY, timeout=CP_TIMEOUT) LOG.tc_step("Attempt to delete In-Use partition") rc, out = storage_helper.delete_host_partition(host, uuid, fail_ok=True) assert rc != 0, "Partition deletion was expected to fail but instead passed" LOG.tc_step( "Attempt to associate the In-Use partition with another PV") # cmd = "host-pv-add -t partition {} nova-local {}".format(host, uuid) cmd = "host-pv-add {} nova-local {}".format(host, uuid) rc, out = cli.system(cmd) assert rc != 0, "Partition association succeeded but was expected to fail" # Only test one disk on each host break # Do it on one host only break
def test_create_multiple_partitions_on_single_host(): """ This test attempts to create multiple partitions at once on a single host. While the first partition is being created, we will attempt to create a second partition. The creation of the second partition should be rejected but the creation of the first partition should be successful. Assumptions: * There's some free disk space available Test steps: * Query the hosts to determine disk space * Create a small partition but don't wait for creation * Immediately create a second small partition * Check that the second partition creation is rejected * Check the first partition was successfully created * Repeat on all applicable hosts Teardown: * Delete created partitions """ global partitions_to_restore partitions_to_restore = {} computes = system_helper.get_hosts(personality="compute") hosts = system_helper.get_controllers() + computes usable_disks = False for host in hosts: disks = storage_helper.get_host_disks(host) free_disks = storage_helper.get_host_disks_with_free_space(host, disks) if not free_disks: continue for disk_uuid in free_disks: size_gib = float(free_disks[disk_uuid]) partition_chunks = int(size_gib) if partition_chunks < 2: LOG.info( "Skip disk {} due to insufficient space".format(disk_uuid)) continue usable_disks = True LOG.info("Creating first partition on {}".format(host)) rc1, out1 = storage_helper.create_host_partition(host, disk_uuid, "1", fail_ok=False, wait=False) LOG.info("Creating second partition on {}".format(host)) rc, out = storage_helper.create_host_partition(host, disk_uuid, "1", fail_ok=True) assert rc != 0, "Partition creation was expected to fail but was instead successful" # Check that first disk was created uuid = table_parser.get_value_two_col_table( table_parser.table(out1), "uuid") storage_helper.wait_for_host_partition_status(host=host, uuid=uuid, timeout=CP_TIMEOUT) partitions_to_restore[host] = [] partitions_to_restore[host].append(uuid) # Only test one disk on each host break if not usable_disks: skip("Did not find disks with sufficient space to test with.")
def test_increase_host_partition_size(): """ Create a partition and then modify it to consume the entire disk Arguments: * None Test Steps: * Create a partition * Modify the partition so we consume all available space on the disk * Check that the disk available space goes to zero * Delete the partition * Check that the available space is freed Teardown: * Delete the partitions """ global partitions_to_restore partitions_to_restore = {} computes = system_helper.get_hosts(personality="compute") hosts = system_helper.get_controllers() + computes usable_disks = False for host in hosts: disks = storage_helper.get_host_disks(host) free_disks = storage_helper.get_host_disks_with_free_space(host, disks) if not free_disks: continue for disk_uuid in free_disks: size_gib = float(free_disks[disk_uuid]) partition_chunks = int(size_gib) if partition_chunks < 2: LOG.info( "Skip disk {} due to insufficient space".format(disk_uuid)) continue usable_disks = True LOG.info("Creating partition on {}".format(host)) rc, out = storage_helper.create_host_partition(host, disk_uuid, "1", fail_ok=False, wait=False) assert rc == 0, "Partition creation was expected to succeed but instead failed" # Check that first disk was created uuid = table_parser.get_value_two_col_table( table_parser.table(out), "uuid") storage_helper.wait_for_host_partition_status(host=host, uuid=uuid, timeout=CP_TIMEOUT) partitions_to_restore[host] = [] partitions_to_restore[host].append(uuid) device_node = storage_helper.get_host_partition_values( host, uuid, "device_node")[0] device_node = device_node.rstrip(string.digits) if device_node.startswith("/dev/nvme"): device_node = device_node[:-1] LOG.tc_step( "Modifying partition {} from size 1 to size {} from host {} on device node {}" .format(uuid, int(size_gib) - 2, host, device_node)) storage_helper.modify_host_partition(host, uuid, str(int(size_gib) - 2)) new_disk_available_gib = storage_helper.get_host_disk_values( host, device_node, "available_gib")[0] assert 0 <= int(float(new_disk_available_gib)) <= 3, \ "Expected disk space to be consumed but instead we have {} available".format(new_disk_available_gib) # Only test one disk on each host break if not usable_disks: skip("Did not find disks with sufficient space to test with.")