Skip to content

Commit

Permalink
block_hotplug_with_max_map_count: creates new test case
Browse files Browse the repository at this point in the history
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
mcasquer committed Jan 10, 2025
1 parent 74b8d3f commit cfb8824
Show file tree
Hide file tree
Showing 2 changed files with 81 additions and 0 deletions.
56 changes: 56 additions & 0 deletions qemu/tests/block_hotplug_with_max_map_count.py
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)
25 changes: 25 additions & 0 deletions qemu/tests/cfg/block_hotplug_with_max_map_count.cfg
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

0 comments on commit cfb8824

Please sign in to comment.