From: Steve Sistare <steven.sistare@oracle.com>
To: qemu-devel@nongnu.org
Cc: "Paolo Bonzini" <pbonzini@redhat.com>,
"Stefan Hajnoczi" <stefanha@redhat.com>,
"Marc-André Lureau" <marcandre.lureau@redhat.com>,
"Alex Bennée" <alex.bennee@linaro.org>,
"Dr. David Alan Gilbert" <dgilbert@redhat.com>,
"Michael S. Tsirkin" <mst@redhat.com>,
"Marcel Apfelbaum" <marcel.apfelbaum@gmail.com>,
"Alex Williamson" <alex.williamson@redhat.com>,
"Daniel P. Berrange" <berrange@redhat.com>,
"Juan Quintela" <quintela@redhat.com>,
"Markus Armbruster" <armbru@redhat.com>,
"Eric Blake" <eblake@redhat.com>,
"Jason Zeng" <jason.zeng@linux.intel.com>,
"Zheng Chuan" <zhengchuan@huawei.com>,
"Steve Sistare" <steven.sistare@oracle.com>,
"Mark Kanda" <mark.kanda@oracle.com>,
"Guoyi Tu" <tugy@chinatelecom.cn>,
"Peter Maydell" <peter.maydell@linaro.org>,
"Philippe Mathieu-Daudé" <philippe.mathieu.daude@gmail.com>,
"Igor Mammedov" <imammedo@redhat.com>,
"David Hildenbrand" <david@redhat.com>,
"John Snow" <jsnow@redhat.com>
Subject: [PATCH V8 39/39] tests/avocado: add cpr regression test
Date: Wed, 15 Jun 2022 07:52:26 -0700 [thread overview]
Message-ID: <1655304746-102776-40-git-send-email-steven.sistare@oracle.com> (raw)
In-Reply-To: <1655304746-102776-1-git-send-email-steven.sistare@oracle.com>
Signed-off-by: Steve Sistare <steven.sistare@oracle.com>
---
MAINTAINERS | 1 +
tests/avocado/cpr.py | 152 +++++++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 153 insertions(+)
create mode 100644 tests/avocado/cpr.py
diff --git a/MAINTAINERS b/MAINTAINERS
index 864aec6..4e6e7ab 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -3164,6 +3164,7 @@ F: stubs/cpr.c
F: tests/unit/test-strlist.c
F: migration/cpr-state.c
F: stubs/cpr-state.c
+F: tests/avocado/cpr.py
Record/replay
M: Pavel Dovgalyuk <pavel.dovgaluk@ispras.ru>
diff --git a/tests/avocado/cpr.py b/tests/avocado/cpr.py
new file mode 100644
index 0000000..feb43d1
--- /dev/null
+++ b/tests/avocado/cpr.py
@@ -0,0 +1,152 @@
+# cpr test
+
+# Copyright (c) 2021, 2022 Oracle and/or its affiliates.
+#
+# This work is licensed under the terms of the GNU GPL, version 2.
+# See the COPYING file in the top-level directory.
+
+import tempfile
+from avocado_qemu import QemuSystemTest
+from avocado.utils import wait
+
+class Cpr(QemuSystemTest):
+ """
+ :avocado: tags=cpr
+ """
+
+ timeout = 5
+ fast_timeout = 1
+
+ @staticmethod
+ def has_status(vm, status):
+ return vm.command('query-status')['status'] == status
+
+ def wait_for_status(self, vm, status):
+ wait.wait_for(self.has_status,
+ timeout=self.timeout,
+ step=0.1,
+ args=(vm,status,))
+
+ def run_and_fail(self, vm, msg):
+ # Qemu will fail fast, so disable monitor to avoid timeout in accept
+ vm.set_qmp_monitor(False)
+ vm.launch()
+ vm.wait(self.timeout)
+ self.assertRegex(vm.get_log(), msg)
+
+ def do_cpr_restart(self, vmstate_name):
+ vm = self.get_vm('-nodefaults',
+ '-cpr-enable', 'restart',
+ '-object', 'memory-backend-memfd,id=pc.ram,size=8M',
+ '-machine', 'memory-backend=pc.ram')
+
+ vm.launch()
+
+ vm.qmp('cpr-save', filename=vmstate_name, mode='restart')
+ vm.event_wait(name='STOP', timeout=self.fast_timeout)
+
+ args = vm.full_args + ['-S']
+ vm.qmp('cpr-exec', argv=args)
+
+ # exec closes the monitor socket, so reopen it.
+ vm.reopen_qmp_connection()
+
+ self.wait_for_status(vm, 'prelaunch')
+ vm.qmp('cpr-load', filename=vmstate_name, mode='restart')
+ vm.event_wait(name='RESUME', timeout=self.fast_timeout)
+
+ self.assertEqual(vm.command('query-status')['status'], 'running')
+
+ def do_cpr_reboot(self, vmstate_name):
+ old_vm = self.get_vm('-nodefaults',
+ '-cpr-enable', 'reboot')
+ old_vm.launch()
+
+ old_vm.qmp('cpr-save', filename=vmstate_name, mode='reboot')
+ old_vm.event_wait(name='STOP', timeout=self.fast_timeout)
+
+ new_vm = self.get_vm('-nodefaults',
+ '-cpr-enable', 'reboot',
+ '-S')
+ new_vm.launch()
+ self.wait_for_status(new_vm, 'prelaunch')
+
+ new_vm.qmp('cpr-load', filename=vmstate_name, mode='reboot')
+ new_vm.event_wait(name='RESUME', timeout=self.fast_timeout)
+
+ self.assertEqual(new_vm.command('query-status')['status'], 'running')
+
+ def test_cpr_restart(self):
+ """
+ Verify that cpr restart mode works
+ """
+ with tempfile.NamedTemporaryFile() as vmstate_file:
+ self.do_cpr_restart(vmstate_file.name)
+
+ def test_cpr_reboot(self):
+ """
+ Verify that cpr reboot mode works
+ """
+ with tempfile.NamedTemporaryFile() as vmstate_file:
+ self.do_cpr_reboot(vmstate_file.name)
+
+ def test_cpr_block_cpr_save(self):
+
+ """
+ Verify that qemu rejects cpr-save for volatile memory
+ """
+ vm = self.get_vm('-nodefaults',
+ '-cpr-enable', 'restart')
+ vm.launch()
+ rsp = vm.qmp('cpr-save', filename='/dev/null', mode='restart')
+ vm.qmp('quit')
+
+ expect = r'Memory region .* is volatile'
+ self.assertRegex(rsp['error']['desc'], expect)
+
+ def test_cpr_block_memfd(self):
+
+ """
+ Verify that qemu complains for only-cpr-capable and volatile memory
+ """
+ vm = self.get_vm('-nodefaults',
+ '-cpr-enable', 'restart',
+ '-only-cpr-capable')
+ self.run_and_fail(vm, r'only-cpr-capable specified.* Memory ')
+
+ def test_cpr_block_replay(self):
+ """
+ Verify that qemu complains for only-cpr-capable and replay
+ """
+ vm = self.get_vm('-nodefaults',
+ '-cpr-enable', 'restart',
+ '-object', 'memory-backend-memfd,id=pc.ram,size=8M',
+ '-machine', 'memory-backend=pc.ram',
+ '-only-cpr-capable',
+ '-icount', 'shift=10,rr=record,rrfile=/dev/null')
+ self.run_and_fail(vm, r'only-cpr-capable specified.* replay ')
+
+ def test_cpr_block_chardev(self):
+ """
+ Verify that qemu complains for only-cpr-capable and unsupported chardev
+ """
+ vm = self.get_vm('-nodefaults',
+ '-cpr-enable', 'restart',
+ '-object', 'memory-backend-memfd,id=pc.ram,size=8M',
+ '-machine', 'memory-backend=pc.ram',
+ '-only-cpr-capable',
+ '-chardev', 'vc,id=vc1')
+ self.run_and_fail(vm, r'only-cpr-capable specified.* vc1 ')
+
+ def test_cpr_allow_chardev(self):
+ """
+ Verify that qemu allows unsupported chardev with reopen-on-cpr
+ """
+ vm = self.get_vm('-nodefaults',
+ '-cpr-enable', 'restart',
+ '-object', 'memory-backend-memfd,id=pc.ram,size=8M',
+ '-machine', 'memory-backend=pc.ram',
+ '-only-cpr-capable',
+ '-chardev', 'vc,id=vc1,reopen-on-cpr=on')
+ vm.launch()
+ self.wait_for_status(vm, 'running')
--
1.8.3.1
prev parent reply other threads:[~2022-06-15 15:22 UTC|newest]
Thread overview: 84+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-06-15 14:51 [PATCH V8 00/39] Live Update Steve Sistare
2022-06-15 14:51 ` [PATCH V8 01/39] migration: fix populate_vfio_info Steve Sistare
2022-06-16 14:41 ` Marc-André Lureau
2022-06-15 14:51 ` [PATCH V8 02/39] migration: qemu file wrappers Steve Sistare
2022-06-16 2:18 ` Guoyi Tu
2022-07-05 18:24 ` Steven Sistare
2022-06-16 14:55 ` Marc-André Lureau
2022-07-05 18:25 ` Steven Sistare
2022-06-16 15:29 ` Daniel P. Berrangé
2022-07-05 18:25 ` Steven Sistare
2022-06-15 14:51 ` [PATCH V8 03/39] migration: simplify savevm Steve Sistare
2022-06-16 14:59 ` Marc-André Lureau
2022-06-15 14:51 ` [PATCH V8 04/39] memory: RAM_ANON flag Steve Sistare
2022-06-15 20:25 ` David Hildenbrand
2022-07-05 18:23 ` Steven Sistare
2022-06-15 14:51 ` [PATCH V8 05/39] vl: start on wakeup request Steve Sistare
2022-06-16 15:55 ` Marc-André Lureau
2022-07-05 18:26 ` Steven Sistare
2022-06-15 14:51 ` [PATCH V8 06/39] cpr: reboot mode Steve Sistare
2022-06-16 11:10 ` Daniel P. Berrangé
2022-07-05 18:26 ` Steven Sistare
2022-06-15 14:51 ` [PATCH V8 07/39] cpr: reboot HMP interfaces Steve Sistare
2022-06-15 14:51 ` [PATCH V8 08/39] cpr: blockers Steve Sistare
2022-06-15 14:51 ` [PATCH V8 09/39] cpr: register blockers Steve Sistare
2022-06-15 14:51 ` [PATCH V8 10/39] cpr: cpr-enable option Steve Sistare
2022-06-15 14:51 ` [PATCH V8 11/39] cpr: save ram blocks Steve Sistare
2022-06-15 14:51 ` [PATCH V8 12/39] memory: flat section iterator Steve Sistare
2022-07-03 7:52 ` Peng Liang
2022-07-05 18:26 ` Steven Sistare
2022-06-15 14:52 ` [PATCH V8 13/39] oslib: qemu_clear_cloexec Steve Sistare
2022-06-16 16:01 ` Marc-André Lureau
2022-06-16 16:07 ` Daniel P. Berrangé
2022-07-05 18:27 ` Steven Sistare
2022-06-15 14:52 ` [PATCH V8 14/39] qapi: strList_from_string Steve Sistare
2022-06-16 16:04 ` Marc-André Lureau
2022-07-05 18:28 ` Steven Sistare
2022-06-15 14:52 ` [PATCH V8 15/39] qapi: QAPI_LIST_LENGTH Steve Sistare
2022-06-16 16:06 ` Marc-André Lureau
2022-06-15 14:52 ` [PATCH V8 16/39] qapi: strv_from_strList Steve Sistare
2022-06-16 16:08 ` Marc-André Lureau
2022-07-05 18:28 ` Steven Sistare
2022-06-15 14:52 ` [PATCH V8 17/39] qapi: strList unit tests Steve Sistare
2022-06-16 16:10 ` Marc-André Lureau
2022-06-15 14:52 ` [PATCH V8 18/39] vl: helper to request re-exec Steve Sistare
2022-06-15 14:52 ` [PATCH V8 19/39] cpr: preserve extra state Steve Sistare
2022-06-15 14:52 ` [PATCH V8 20/39] cpr: restart mode Steve Sistare
2022-07-03 8:15 ` Peng Liang
2022-07-05 18:29 ` Steven Sistare
2022-07-06 0:15 ` Peng Liang
2022-06-15 14:52 ` [PATCH V8 21/39] cpr: restart HMP interfaces Steve Sistare
2022-06-15 14:52 ` [PATCH V8 22/39] cpr: ram block blockers Steve Sistare
2022-06-15 14:52 ` [PATCH V8 23/39] hostmem-memfd: cpr for memory-backend-memfd Steve Sistare
2022-06-15 14:52 ` [PATCH V8 24/39] pci: export export msix_is_pending Steve Sistare
2022-06-27 22:44 ` Michael S. Tsirkin
2022-07-05 18:29 ` Steven Sistare
2022-06-15 14:52 ` [PATCH V8 25/39] cpr: notifiers Steve Sistare
2022-06-15 14:52 ` [PATCH V8 26/39] vfio-pci: refactor for cpr Steve Sistare
2022-06-15 14:52 ` [PATCH V8 27/39] vfio-pci: cpr part 1 (fd and dma) Steve Sistare
2022-06-29 19:14 ` Alex Williamson
2022-07-06 17:45 ` Steven Sistare
2022-07-03 8:32 ` Peng Liang
2022-07-05 18:29 ` Steven Sistare
2022-06-15 14:52 ` [PATCH V8 28/39] vfio-pci: cpr part 2 (msi) Steve Sistare
2022-06-29 20:19 ` Alex Williamson
2022-07-06 17:46 ` Steven Sistare
2022-06-15 14:52 ` [PATCH V8 29/39] vfio-pci: cpr part 3 (intx) Steve Sistare
2022-06-29 20:43 ` Alex Williamson
2022-07-06 17:46 ` Steven Sistare
2022-06-15 14:52 ` [PATCH V8 30/39] vfio-pci: recover from unmap-all-vaddr failure Steve Sistare
2022-06-29 22:58 ` Alex Williamson
2022-07-06 17:46 ` Steven Sistare
2022-06-15 14:52 ` [PATCH V8 31/39] vhost: reset vhost devices for cpr Steve Sistare
2022-06-15 14:52 ` [PATCH V8 32/39] loader: suppress rom_reset during cpr Steve Sistare
2022-06-15 14:52 ` [PATCH V8 33/39] chardev: cpr framework Steve Sistare
2022-06-15 14:52 ` [PATCH V8 34/39] chardev: cpr for simple devices Steve Sistare
2022-06-15 14:52 ` [PATCH V8 35/39] chardev: cpr for pty Steve Sistare
2022-06-15 14:52 ` [PATCH V8 36/39] chardev: cpr for sockets Steve Sistare
2022-07-03 8:19 ` Peng Liang
2022-07-05 18:29 ` Steven Sistare
2022-06-15 14:52 ` [PATCH V8 37/39] cpr: only-cpr-capable option Steve Sistare
2022-06-15 14:52 ` [PATCH V8 38/39] python/machine: add QEMUMachine accessors Steve Sistare
2022-06-17 14:16 ` John Snow
2022-07-05 18:30 ` Steven Sistare
2022-06-15 14:52 ` Steve Sistare [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1655304746-102776-40-git-send-email-steven.sistare@oracle.com \
--to=steven.sistare@oracle.com \
--cc=alex.bennee@linaro.org \
--cc=alex.williamson@redhat.com \
--cc=armbru@redhat.com \
--cc=berrange@redhat.com \
--cc=david@redhat.com \
--cc=dgilbert@redhat.com \
--cc=eblake@redhat.com \
--cc=imammedo@redhat.com \
--cc=jason.zeng@linux.intel.com \
--cc=jsnow@redhat.com \
--cc=marcandre.lureau@redhat.com \
--cc=marcel.apfelbaum@gmail.com \
--cc=mark.kanda@oracle.com \
--cc=mst@redhat.com \
--cc=pbonzini@redhat.com \
--cc=peter.maydell@linaro.org \
--cc=philippe.mathieu.daude@gmail.com \
--cc=qemu-devel@nongnu.org \
--cc=quintela@redhat.com \
--cc=stefanha@redhat.com \
--cc=tugy@chinatelecom.cn \
--cc=zhengchuan@huawei.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).