[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 7/9] tests/avocado: update replay_linux test
From: |
Pavel Dovgalyuk |
Subject: |
[PATCH v2 7/9] tests/avocado: update replay_linux test |
Date: |
Wed, 04 May 2022 12:39:28 +0300 |
User-agent: |
StGit/0.23 |
This patch updates replay_linux test to make it compatible with
new LinuxTest class.
Signed-off-by: Pavel Dovgalyuk <Pavel.Dovgalyuk@ispras.ru>
---
tests/avocado/replay_linux.py | 19 ++++++++++++++-----
1 file changed, 14 insertions(+), 5 deletions(-)
diff --git a/tests/avocado/replay_linux.py b/tests/avocado/replay_linux.py
index 15953f9e49..1099b5647f 100644
--- a/tests/avocado/replay_linux.py
+++ b/tests/avocado/replay_linux.py
@@ -32,9 +32,16 @@ class ReplayLinux(LinuxTest):
bus = 'ide'
def setUp(self):
- super(ReplayLinux, self).setUp()
+ # LinuxTest does many replay-incompatible things, but includes
+ # useful methods. Do not setup LinuxTest here and just
+ # call some functions.
+ super(LinuxTest, self).setUp()
+ self._set_distro()
self.boot_path = self.download_boot()
- self.cloudinit_path = self.prepare_cloudinit()
+ self.phone_server = cloudinit.PhoneHomeServer(('0.0.0.0', 0),
+ self.name)
+ ssh_pubkey, self.ssh_key = self.set_up_existing_ssh_keys()
+ self.cloudinit_path = self.prepare_cloudinit(ssh_pubkey)
def vm_add_disk(self, vm, path, id, device):
bus_string = ''
@@ -50,7 +57,9 @@ def launch_and_wait(self, record, args, shift):
vm = self.get_vm()
vm.add_args('-smp', '1')
vm.add_args('-m', '1024')
- vm.add_args('-object', 'filter-replay,id=replay,netdev=hub0port0')
+ vm.add_args('-netdev', 'user,id=vnet,hostfwd=:127.0.0.1:0-:22',
+ '-device', 'virtio-net,netdev=vnet')
+ vm.add_args('-object', 'filter-replay,id=replay,netdev=vnet')
if args:
vm.add_args(*args)
self.vm_add_disk(vm, self.boot_path, 0, self.hdd)
@@ -75,8 +84,8 @@ def launch_and_wait(self, record, args, shift):
stop_check=(lambda : not vm.is_running()))
console_drainer.start()
if record:
- cloudinit.wait_for_phone_home(('0.0.0.0', self.phone_home_port),
- self.name)
+ while not self.phone_server.instance_phoned_back:
+ self.phone_server.handle_request()
vm.shutdown()
logger.info('finished the recording with log size %s bytes'
% os.path.getsize(replay_path))
- [PATCH v2 0/9] Record/replay refactoring and stuff, Pavel Dovgalyuk, 2022/05/04
- [PATCH v2 1/9] replay: fix event queue flush for qemu shutdown, Pavel Dovgalyuk, 2022/05/04
- [PATCH v2 2/9] replay: notify vCPU when BH is scheduled, Pavel Dovgalyuk, 2022/05/04
- [PATCH v2 3/9] replay: rewrite async event handling, Pavel Dovgalyuk, 2022/05/04
- [PATCH v2 4/9] replay: simplify async event processing, Pavel Dovgalyuk, 2022/05/04
- [PATCH v2 5/9] docs: convert docs/devel/replay page to rst, Pavel Dovgalyuk, 2022/05/04
- [PATCH v2 6/9] docs: move replay docs to docs/system/replay.rst, Pavel Dovgalyuk, 2022/05/04
- [PATCH v2 7/9] tests/avocado: update replay_linux test,
Pavel Dovgalyuk <=
- [PATCH v2 8/9] tests/avocado: add replay Linux tests for virtio machine, Pavel Dovgalyuk, 2022/05/04
- [PATCH v2 9/9] tests/avocado: add replay Linux test for Aarch64 machines, Pavel Dovgalyuk, 2022/05/04