From 43d8d17592eba1b48cb81bfd136fdde18da42cf3 Mon Sep 17 00:00:00 2001 From: qcheng-redhat Date: Wed, 27 Nov 2024 17:29:43 +0800 Subject: [PATCH] Reboot vm during virtiofs is working Signed-off-by: qcheng-redhat --- qemu/tests/virtio_fs_share_data.py | 65 ++++++++++++++++-------------- 1 file changed, 34 insertions(+), 31 deletions(-) diff --git a/qemu/tests/virtio_fs_share_data.py b/qemu/tests/virtio_fs_share_data.py index 58ad7ccd6e..c9ec132a62 100644 --- a/qemu/tests/virtio_fs_share_data.py +++ b/qemu/tests/virtio_fs_share_data.py @@ -1016,40 +1016,43 @@ 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"]: + 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)