-
Notifications
You must be signed in to change notification settings - Fork 174
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
block_hotplug_with_max_map_count: creates new test case
Creates new test case that boots up a VM with a small max_map_count, then hotplugs 15 disks and checks the VM status. Signed-off-by: mcasquer <[email protected]>
- Loading branch information
Showing
2 changed files
with
81 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
from avocado.utils import process | ||
from virttest import env_process | ||
|
||
|
||
def run(test, params, env): | ||
""" | ||
Block hotplug with vm.max_map_count test | ||
1) Boot the VM with a small max_map_count | ||
2) Login and hotplug 15 block devices | ||
3) Check the VM status and set max_map_count original value | ||
:param test: QEMU test object | ||
:param params: Dictionary with the test parameters | ||
:param env: Dictionary with test environment | ||
""" | ||
|
||
try: | ||
max_map_value = params.get_numeric("max_map_value", 3072) | ||
test.log.info("Setting max_map_count to 3072") | ||
orig_value = process.system_output("sysctl -n vm.max_map_count", shell=True) | ||
process.system(f"sysctl vm.max_map_count={max_map_value}", shell=True) | ||
|
||
extra_image_number = params.get_numeric("extra_image_number", 15) | ||
timeout = params.get_numeric("login_timeout", 240) | ||
|
||
for img_number in range(extra_image_number): | ||
img = f"stg{img_number}" | ||
params[f"boot_drive_{img}"] = "no" | ||
params[f"image_name_{img}"] = f"images/{img}" | ||
params[f"image_size_{img}"] = "1G" | ||
params[f"remove_image_{img}"] = "yes" | ||
params[f"force_create_image_{img}"] = "yes" | ||
params[f"blk_extra_params_{img}"] = f"serial={img}" | ||
image_params = params.object_params(img) | ||
env_process.preprocess_image(test, image_params, img) | ||
|
||
params["start_vm"] = "yes" | ||
vm_name = params["main_vm"] | ||
env_process.preprocess_vm(test, params, env, vm_name) | ||
vm = env.get_vm(vm_name) | ||
vm.verify_alive() | ||
session = vm.wait_for_login(timeout=timeout) | ||
|
||
for img_number in range(extra_image_number): | ||
img = f"stg{img_number}" | ||
image_params = params.object_params(img) | ||
devs = vm.devices.images_define_by_params(img, image_params, "disk") | ||
for dev in devs: | ||
vm.devices.simple_hotplug(dev, vm.monitor) | ||
if "running" not in vm.monitor.get_status(): | ||
test.fail(f"VM is not running!, status: {vm.monitor.get_status()}") | ||
session.close() | ||
|
||
finally: | ||
test.log.info("Restoring max_map_count original value") | ||
process.system(f"sysctl vm.max_map_count={orig_value}", shell=True) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
- block_hotplug_with_max_map_count: | ||
only Linux | ||
only virtio_blk | ||
only x86_64 | ||
type = block_hotplug_with_max_map_count | ||
virt_test_type = qemu | ||
login_timeout = 240 | ||
start_vm = no | ||
slots_mem = 20 | ||
maxmem_mem = 80G | ||
mem = 4096 | ||
pcie_extra_root_port = 30 | ||
images += " stg1 stg2" | ||
extra_image_number = 15 | ||
image_name_stg1 = images/stg1 | ||
image_size_stg1 = 1G | ||
remove_image_stg1 = yes | ||
force_create_image_stg1 = yes | ||
blk_extra_params_stg1 = "serial=stg1" | ||
image_name_stg2 = images/stg2 | ||
image_size_stg2 = 1G | ||
remove_image_stg2 = yes | ||
force_create_image_stg2 = yes | ||
blk_extra_params_stg2 = "serial=stg2" | ||
max_map_value = 3072 |