1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
#
# live migration tests
#
# stdlib
import os
# avocado
import avocado
from avocado.utils import network
from avocado.utils import wait
# qemu
from qemu import QEMUMachine
# my bits
from drminfo import TestDRM
class Migration(TestDRM):
"""
qemu display device migration tests
:avocado: tags=x86_64
"""
timeout = 60
@staticmethod
def migration_finished(vm):
return vm.command('query-migrate')['status'] in ('completed', 'failed')
def _get_free_port(self):
port = network.find_free_port()
if port is None:
self.cancel('Failed to find a free port')
return port
def migrate_vm(self, vga, display = None):
self.log.info("### live migration: start ...")
dest_uri = 'tcp:localhost:%u' % self._get_free_port()
dest_vm = QEMUMachine(self.qemu_binary)
self.boot_gfx_vm(vga, display, dest_vm, dest_uri);
self.vm.qmp('migrate_set_speed', value = "1G")
self.vm.qmp('migrate', uri=dest_uri)
wait.wait_for(
self.migration_finished,
timeout=self.timeout,
step=0.1,
args=(self.vm,)
)
self.assertEqual(dest_vm.command('query-migrate')['status'], 'completed')
self.assertEqual(self.vm.command('query-migrate')['status'], 'completed')
self.assertEqual(dest_vm.command('query-status')['status'], 'running')
self.assertEqual(self.vm.command('query-status')['status'], 'postmigrate')
self.log.info("### live migration: OK")
# swap vm and console handles, so we can talk to the new vm ...
self.vm.shutdown()
self.vm = dest_vm
self.rconsole = self.vm.console_socket.makefile('r')
self.wconsole = self.vm.console_socket.makefile('w')
def migration_test(self, vga):
self.boot_gfx_vm(vga);
self.console_prepare();
self.console_run('drminfo -a')
drminfo = self.console_wait('---root---')
self.write_text(vga, "drminfo-pre-migration", drminfo)
if not "framebuffer formats" in drminfo:
self.fail("drm device missing");
self.migrate_vm(vga)
self.console_run('drminfo -a')
drminfo = self.console_wait('---root---')
self.write_text(vga, "drminfo-post-migration", drminfo)
if not "framebuffer formats" in drminfo:
self.fail("drm device missing");
@avocado.skipUnless(os.path.exists('/usr/bin/dracut'), "no dracut")
@avocado.skipUnless(os.path.exists('/usr/bin/drminfo'), "no drminfo")
def setUp(self):
TestDRM.setUp(self);
if not os.path.isfile(self.initrd):
self.prepare_kernel_initrd()
def test_stdvga(self):
vga = 'VGA'
self.migration_test(vga)
def test_bochs_dpy(self):
vga = 'bochs-display'
self.migration_test(vga)
def test_cirrus(self):
vga = "cirrus-vga"
self.migration_test(vga)
def test_qxl(self):
vga = "qxl-vga"
self.migration_test(vga)
def test_virtio_vga(self):
vga = "virtio-vga"
self.migration_test(vga)
|