2 # Test virtio-scsi and virtio-blk queue settings for all machine types
4 # Copyright (c) 2019 Virtuozzo International GmbH
6 # This program is free software; you can redistribute it and/or modify
7 # it under the terms of the GNU General Public License as published by
8 # the Free Software Foundation; either version 2 of the License, or
9 # (at your option) any later version.
11 # This program is distributed in the hope that it will be useful,
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 # GNU General Public License for more details.
16 # You should have received a copy of the GNU General Public License
17 # along with this program. If not, see <http://www.gnu.org/licenses/>.
25 from qemu
.machine
import QEMUMachine
26 from avocado_qemu
import QemuSystemTest
27 from avocado
import skip
29 #list of machine types and virtqueue properties to test
30 VIRTIO_SCSI_PROPS
= {'seg_max_adjust': 'seg_max_adjust'}
31 VIRTIO_BLK_PROPS
= {'seg_max_adjust': 'seg-max-adjust'}
33 DEV_TYPES
= {'virtio-scsi-pci': VIRTIO_SCSI_PROPS
,
34 'virtio-blk-pci': VIRTIO_BLK_PROPS
}
36 VM_DEV_PARAMS
= {'virtio-scsi-pci': ['-device', 'virtio-scsi-pci,id=scsi0'],
37 'virtio-blk-pci': ['-device',
38 'virtio-blk-pci,id=scsi0,drive=drive0',
40 'driver=null-co,id=drive0,if=none']}
43 class VirtioMaxSegSettingsCheck(QemuSystemTest
):
45 def make_pattern(props
):
46 pattern_items
= ['{0} = \w+'.format(prop
) for prop
in props
]
47 return '|'.join(pattern_items
)
49 def query_virtqueue(self
, vm
, dev_type_name
):
54 output
= vm
.command('human-monitor-command',
55 command_line
= 'info qtree')
56 props_list
= DEV_TYPES
[dev_type_name
].values();
57 pattern
= self
.make_pattern(props_list
)
58 res
= re
.findall(pattern
, output
)
60 if len(res
) != len(props_list
):
61 props_list
= set(props_list
)
63 not_found
= props_list
.difference(res
)
64 not_found
= ', '.join(not_found
)
65 error
= '({0}): The following properties not found: {1}'\
66 .format(dev_type_name
, not_found
)
73 return query_ok
, props
, error
75 def check_mt(self
, mt
, dev_type_name
):
76 mt
['device'] = dev_type_name
# Only for the debug() call.
77 logger
= logging
.getLogger('machine')
79 with
QEMUMachine(self
.qemu_bin
) as vm
:
80 vm
.set_machine(mt
["name"])
81 vm
.add_args('-nodefaults')
82 for s
in VM_DEV_PARAMS
[dev_type_name
]:
86 query_ok
, props
, error
= self
.query_virtqueue(vm
, dev_type_name
)
89 error
= sys
.exc_info()[0]
92 self
.fail('machine type {0}: {1}'.format(mt
['name'], error
))
94 for prop_name
, prop_val
in props
.items():
95 expected_val
= mt
[prop_name
]
96 self
.assertEqual(expected_val
, prop_val
)
99 def seg_max_adjust_enabled(mt
):
100 # machine types >= 5.0 should have seg_max_adjust = true
101 # others seg_max_adjust = false
104 # machine types with one line name and name like pc-x.x
108 # machine types like pc-<chip_name>-x.x[.x]
110 ver
= ver
.split(".");
112 # versions >= 5.0 goes with seg_max_adjust enabled
119 @skip("break multi-arch CI")
120 def test_machine_types(self
):
121 # collect all machine types except 'none', 'isapc', 'microvm'
122 with
QEMUMachine(self
.qemu_bin
) as vm
:
124 machines
= [m
['name'] for m
in vm
.command('query-machines')]
126 machines
.remove('none')
127 machines
.remove('isapc')
128 machines
.remove('microvm')
130 for dev_type
in DEV_TYPES
:
131 # create the list of machine types and their parameters.
134 if self
.seg_max_adjust_enabled(m
):
138 mtypes
.append({'name': m
,
139 DEV_TYPES
[dev_type
]['seg_max_adjust']: enabled
})
141 # test each machine type for a device type
143 self
.check_mt(mt
, dev_type
)