Skip to content

Commit

Permalink
Reboot vm during virtiofs is working
Browse files Browse the repository at this point in the history
Signed-off-by: qcheng-redhat <qcheng@redhat.com>
  • Loading branch information
qcheng-redhat committed Dec 16, 2024
1 parent 2dca34c commit 291e9fa
Showing 1 changed file with 45 additions and 31 deletions.
76 changes: 45 additions & 31 deletions qemu/tests/virtio_fs_share_data.py
Original file line number Diff line number Diff line change
Expand Up @@ -1016,40 +1016,54 @@ def get_vfsd_num():
vfsd_num += len(vfsd_ps.strip().splitlines())
return vfsd_num

error_context.context(
"Check virtiofs daemon before reboot vm.", test.log.info
)
vfsd_num_bf = get_vfsd_num()
error_context.context(
"Reboot guest and check virtiofs daemon.", test.log.info
)
session = vm.reboot(session)
if not vm.is_alive():
test.fail("After rebooting vm quit unexpectedly.")
vfsd_num_af = get_vfsd_num()
if vfsd_num_bf != vfsd_num_af:
test.fail(
"Virtiofs daemon is different before and after reboot.\n"
"Before reboot: %s\n"
"After reboot: %s\n",
(vfsd_num_bf, vfsd_num_af),
for reboot_cmd in ["shell", "system_reset"]:
# Make sure virtiofs running in vm before reboot
if os_type == "linux":
if not utils_disk.mount(
fs_target, fs_dest, "virtiofs", session=session
):
test.fail(
"Mount virtiofs target failed before guest reboot."
)
if os_type == "windows":
virtio_fs_utils.start_viofs_service(test, params, session)

error_context.context(
"Check virtiofs daemon before reboot vm.", test.log.info
)
error_context.context(
"Start IO test on virtiofs after reboot vm.", test.log.info
)
if os_type == "windows":
virtio_fs_utils.start_viofs_service(test, params, session)
else:
vfsd_num_bf = get_vfsd_num()
error_context.context(
"Mount virtiofs target %s to %s inside"
"guest." % (fs_target, fs_dest),
test.log.info,
"Reboot guest and check virtiofs daemon.", test.log.info
)
if not utils_disk.mount(
fs_target, fs_dest, "virtiofs", session=session
):
test.fail("Mount virtiofs target failed.")
virtio_fs_utils.basic_io_test(test, params, session)

session = vm.reboot(session, reboot_cmd)
if not vm.is_alive():
test.fail("After rebooting vm quit unexpectedly.")
vfsd_num_af = get_vfsd_num()
if vfsd_num_bf != vfsd_num_af:
test.fail(
"Virtiofs daemon is different before "
"and after reboot.\n"
"Before reboot: %s\n"
"After reboot: %s\n",
(vfsd_num_bf, vfsd_num_af),
)
error_context.context(
"Start IO test on virtiofs after reboot vm.", test.log.info
)
if os_type == "windows":
virtio_fs_utils.start_viofs_service(test, params, session)
else:
error_context.context(
"Mount virtiofs target %s to %s inside"
"guest." % (fs_target, fs_dest),
test.log.info,
)
if not utils_disk.mount(
fs_target, fs_dest, "virtiofs", session=session
):
test.fail("Mount virtiofs target failed.")
virtio_fs_utils.basic_io_test(test, params, session)
finally:
if os_type == "linux":
utils_disk.umount(fs_target, fs_dest, "virtiofs", session=session)
Expand Down

0 comments on commit 291e9fa

Please sign in to comment.