Skip to content

Commit

Permalink
github,tmt: run the bib integration tests
Browse files Browse the repository at this point in the history
This commit runs parameterized `bootc-image-builder` integration tests
as part of the testing. The parameterization requires [0]. The test
matrix right now is to generated a "qcow2" and "ami" image and
for both:
1. test_image_is_generated(): just checks that the image can be build
2. test_image_boots(): the image boots in qemu and can be accessed
   via ssh
3. test_image_build_without_se_linux_denials(): ensure that the
   image is build without selinux denials

Only test (3) strictly requires testing farm because it can only run
inside a host that runs with a RHEL/fedora kernel and selinux enabled
and it is not relevant for your testing (only required for
bootc-image-builder). This is why this commit also adds a normal
GH action - they support building the images and booting them
with qemu so for this project testing farm is slightly less
important.

We can run arbitrary post-boot tests in step (2) if we want, at
this point we have a ssh connection to the booted image so we
can do any post-boot checks we consider important (code for this
needs to be written though but shoudl be easy).

Caveats:
- bootc-image-builder cannot build quay.io/centos-bootc/centos-bootc:stream9
  right now [1]. This is being worked on and we could start with
  testing the quay.io/centos-bootc/fedora-bootc:eln images until bib
  supports centos.

Some ideas for further improvements:
- tests could be extracted from bootc-image-builder into a shared
  bootc-testing repo
- post-boot tests
- upgrade tests, e.g. by building an image from the current "stable"
  bootc first and then upgrading to the bootc container that is
  tested

I hope this is helpful!

[0] osbuild/bootc-image-builder#87
[1] osbuild/bootc-image-builder#20
  • Loading branch information
mvo5 committed Jan 5, 2024
1 parent 198805f commit 3401e2b
Show file tree
Hide file tree
Showing 3 changed files with 64 additions and 7 deletions.
37 changes: 37 additions & 0 deletions .github/workflows/tests.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
---
name: Tests

on:
pull_request:
branches:
- "*"
push:
branches:
- main
# for merge queue
merge_group:

jobs:
integration:
name: "Integration"
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v4
- name: Setup up python
uses: actions/setup-python@v5
- name: Install test dependencies
run: |
sudo apt install -y podman python3-pytest python3-paramiko flake8 qemu-system-x86
- name: Run tests
run: |
# XXX: move tests out of main bootc-image-builder repo into a shared one?
git clone https://github.com/osbuild/bootc-image-builder
cd bootc-image-builder
BIB_TEST_BUILD_CONTAINER_TAG=quay.io/centos-bootc/bootc-image-builder:latest \
# TODO: replace with the freshly generated bootc image that needs to
# get tested
BIB_TEST_BOOTC_CONTAINER_TAG=quay.io/centos-bootc/fedora-bootc:eln \
# podman needs (parts of) the environment but will break when
# XDG_RUNTIME_DIR is set.
# TODO: figure out what exactly podman needs
sudo -E XDG_RUNTIME_DIR= pytest-3 -s -vv
27 changes: 27 additions & 0 deletions plans/bib-tests.fmf
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
summary: Run all tests inside a VM environment
provision:
how: virtual
image: fedora:39
hardware:
virtualization:
is-supported: true
prepare:
how: install
package:
- podman
- pytest
- python3-flake8
- python3-paramiko
- qemu-kvm
execute:
how: tmt
script: |
# XXX: move tests out of main bootc-image-builder repo into a shared one?
git clone https://github.com/osbuild/bootc-image-builder
cd bootc-image-builder
# testing farm runs as root already
BIB_TEST_BUILD_CONTAINER_TAG=quay.io/centos-bootc/bootc-image-builder:latest \
# TODO: replace with the freshly generated bootc image that needs to
# get tested
BIB_TEST_BOOTC_CONTAINER_TAG=quay.io/centos-bootc/fedora-bootc:eln \
pytest -s -vv
7 changes: 0 additions & 7 deletions plans/example.fmf

This file was deleted.

0 comments on commit 3401e2b

Please sign in to comment.