Acceptance Tests: support choosing specific distro and version

The tests based on the LinuxTest class give the test writer a ready to
use guest operating system, currently pinned to Fedora 31.

With this change, it's now possible to choose different distros and
versions, similar to how other tags and parameter can be set for the
target arch, accelerator, etc.

One of the reasons for this work, is that some development features
depend on updates on the guest side.  For instance the tests on
virtiofs_submounts.py, require newer kernels, and may benefit from
running, say on Fedora 34, without the need for a custom kernel.

Please notice that the pre-caching of the Fedora 31 images done during
the early stages of `make check-acceptance` (before the tests are
actually executed) are not expanded here to cover every new image
added.  But, the tests will download other needed images (and cache
them) during the first execution.

Signed-off-by: Cleber Rosa <crosa@redhat.com>
Message-Id: <20210414221457.1653745-4-crosa@redhat.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Reviewed-by: Willian Rampazzo <willianr@redhat.com>
Signed-off-by: Cleber Rosa <crosa@redhat.com>
This commit is contained in:
Cleber Rosa 2021-04-14 18:14:57 -04:00
parent 889554f09e
commit d5adf9d52b
2 changed files with 102 additions and 10 deletions
docs/devel
tests/acceptance/avocado_qemu

View File

@ -922,6 +922,39 @@ The preserved value of the ``qemu_bin`` parameter or the result of the
dynamic probe for a QEMU binary in the current working directory or dynamic probe for a QEMU binary in the current working directory or
source tree. source tree.
LinuxTest
~~~~~~~~~
Besides the attributes present on the ``avocado_qemu.Test`` base
class, the ``avocado_qemu.LinuxTest`` adds the following attributes:
distro
......
The name of the Linux distribution used as the guest image for the
test. The name should match the **Provider** column on the list
of images supported by the avocado.utils.vmimage library:
https://avocado-framework.readthedocs.io/en/latest/guides/writer/libs/vmimage.html#supported-images
distro_version
..............
The version of the Linux distribution as the guest image for the
test. The name should match the **Version** column on the list
of images supported by the avocado.utils.vmimage library:
https://avocado-framework.readthedocs.io/en/latest/guides/writer/libs/vmimage.html#supported-images
distro_checksum
...............
The sha256 hash of the guest image file used for the test.
If this value is not set in the code or by a test parameter (with the
same name), no validation on the integrity of the image will be
performed.
Parameter reference Parameter reference
------------------- -------------------
@ -962,6 +995,38 @@ qemu_bin
The exact QEMU binary to be used on QEMUMachine. The exact QEMU binary to be used on QEMUMachine.
LinuxTest
~~~~~~~~~
Besides the parameters present on the ``avocado_qemu.Test`` base
class, the ``avocado_qemu.LinuxTest`` adds the following parameters:
distro
......
The name of the Linux distribution used as the guest image for the
test. The name should match the **Provider** column on the list
of images supported by the avocado.utils.vmimage library:
https://avocado-framework.readthedocs.io/en/latest/guides/writer/libs/vmimage.html#supported-images
distro_version
..............
The version of the Linux distribution as the guest image for the
test. The name should match the **Version** column on the list
of images supported by the avocado.utils.vmimage library:
https://avocado-framework.readthedocs.io/en/latest/guides/writer/libs/vmimage.html#supported-images
distro_checksum
...............
The sha256 hash of the guest image file used for the test.
If this value is not set in the code or by this parameter no
validation on the integrity of the image will be performed.
Skipping tests Skipping tests
-------------- --------------
The Avocado framework provides Python decorators which allow for easily skip The Avocado framework provides Python decorators which allow for easily skip

View File

@ -345,8 +345,39 @@ class LinuxTest(Test, LinuxSSHMixIn):
username = 'root' username = 'root'
password = 'password' password = 'password'
def _set_distro(self):
distro = self.params.get(
'distro',
default=self._get_unique_tag_val('distro'))
if not distro:
distro = 'fedora'
self.distro = distro
distro_version = self.params.get(
'distro_version',
default=self._get_unique_tag_val('distro_version'))
if not distro_version:
distro_version = '31'
self.distro_version = distro_version
# The distro checksum behaves differently than distro name and
# version. First, it does not respect a tag with the same
# name, given that it's not expected to be used for filtering
# (distro name versions are the natural choice). Second, the
# order of precedence is: parameter, attribute and then value
# from KNOWN_DISTROS.
distro_checksum = self.params.get('distro_checksum',
default=self.distro_checksum)
if not distro_checksum:
distro_checksum = get_known_distro_checksum(self.distro,
self.distro_version,
self.arch)
if distro_checksum:
self.distro_checksum = distro_checksum
def setUp(self, ssh_pubkey=None, network_device_type='virtio-net'): def setUp(self, ssh_pubkey=None, network_device_type='virtio-net'):
super(LinuxTest, self).setUp() super(LinuxTest, self).setUp()
self._set_distro()
self.vm.add_args('-smp', '2') self.vm.add_args('-smp', '2')
self.vm.add_args('-m', '1024') self.vm.add_args('-m', '1024')
# The following network device allows for SSH connections # The following network device allows for SSH connections
@ -382,20 +413,16 @@ class LinuxTest(Test, LinuxSSHMixIn):
vmimage.QEMU_IMG = qemu_img vmimage.QEMU_IMG = qemu_img
self.log.info('Downloading/preparing boot image') self.log.info('Downloading/preparing boot image')
distro = 'fedora'
distro_version = '31'
known_distro_checksum = get_known_distro_checksum(distro,
distro_version,
self.arch)
distro_checksum = self.distro_checksum or known_distro_checksum
# Fedora 31 only provides ppc64le images # Fedora 31 only provides ppc64le images
image_arch = self.arch image_arch = self.arch
if image_arch == 'ppc64': if self.distro == 'fedora':
image_arch = 'ppc64le' if image_arch == 'ppc64':
image_arch = 'ppc64le'
try: try:
boot = vmimage.get( boot = vmimage.get(
distro, arch=image_arch, version=distro_version, self.distro, arch=image_arch, version=self.distro_version,
checksum=distro_checksum, checksum=self.distro_checksum,
algorithm='sha256', algorithm='sha256',
cache_dir=self.cache_dirs[0], cache_dir=self.cache_dirs[0],
snapshot_dir=self.workdir) snapshot_dir=self.workdir)