Skip to content

Commit

Permalink
Add osbuild-ci images based on c8s and c9s
Browse files Browse the repository at this point in the history
Rename the original osbuild-ci image to osbuild-ci-fedora and add two
new variants based on c8s and c9s.

CentOS Stream is lacking some packages. Install all of the unavailable
python packages using pip and also pytest on cXs images. The reason is
for not installing pytest from cXs repositories is to get the latest
version of it to not have to deal with lack of features on older
releases.

The intention is that these cXs images will be used mostly to run the
unit tests. The Fedora image should be used for all the additional
testing (such as pylint, mypy, isort, ...), including unit tests.

Signed-off-by: Tomáš Hozza <[email protected]>
  • Loading branch information
thozza committed Jan 17, 2024
1 parent 13c129e commit df4670f
Show file tree
Hide file tree
Showing 3 changed files with 209 additions and 7 deletions.
122 changes: 115 additions & 7 deletions docker-bake.hcl
Original file line number Diff line number Diff line change
Expand Up @@ -215,16 +215,29 @@ target "nfsd-latest" {
* osbuild-ci - OSBuild CI Images
*
* The following groups and targets build the CI images used by osbuild. They
* build on the official fedora images.
* build on the official fedora and cXs images.
*
* The `osbuild-ci-cXs-latest` images are missing some packages, compared to
* the `osbuild-ci-fedora-latest` images, because they are not available in
* the cXs repositories. Their main purpose is to use them only to run unit
* tests in osbuild upstream. The Fedora image should be used for all the
* other tests, such as linters and running unit tests on multiple Python
* versions.
*
* NB: Docker bake HCL does not support definig arrays as a variable or calling
* functions in variable definitions, so we need to duplicate the package list
* in Fedora and cXs targets.
*/

group "all-osbuild-ci" {
targets = [
"osbuild-ci-latest",
"osbuild-ci-fedora-latest",
"osbuild-ci-c8s-latest",
"osbuild-ci-c9s-latest",
]
}

target "virtual-osbuild-ci" {
target "virtual-osbuild-ci-base" {
args = {
OSB_DNF_PACKAGES = join(",", [
"bash",
Expand Down Expand Up @@ -299,15 +312,110 @@ target "virtual-osbuild-ci" {
]
}

target "osbuild-ci-latest" {
target "osbuild-ci-fedora-latest" {
args = {
OSB_FROM = "docker.io/library/fedora:latest",
OSB_FROM = "registry.fedoraproject.org/fedora:latest",
}
inherits = [
"virtual-osbuild-ci-base",
]
tags = concat(
mirror("osbuild-ci-fedora", "latest", "", OSB_UNIQUEID),
)
}

target "virtual-osbuild-ci-cXs" {
args = {
OSB_DNF_PACKAGES = join(",", [
"bash",
//"btrfs-progs", // not available in cXs
"bubblewrap",
"coreutils",
"cryptsetup",
"curl",
"dnf",
"dnf-plugins-core",
"dosfstools",
"e2fsprogs",
"findutils",
"git",
"glibc",
"iproute",
"lvm2",
"make",
//"nbd", // not available in cXs
//"nbd-cli", // not available in cXs
"ostree",
//"pacman", // not available in cXs
"policycoreutils",
"pylint",
"python-rpm-macros",
"python3", // install just the default version
//"python3.6",
//"python3.7",
//"python3.8",
//"python3.9",
//"python3.10",
//"python3.12",
//"python3-autopep8", // not available in cXs
//"python3-boto3", // not available in cXs
//"python3-botocore", // not available in cXs
"python3-docutils",
"python3-devel",
"python3-iniparse",
//"python3-isort", // not available in cXs
"python3-jsonschema",
"python3-librepo",
"python3-mako",
//"python3-mypy", // not available in cXs
"python3-pip",
//"python3-pylint", // not available in cXs
//"python3-pytest", // too old in cXs
//"python3-pytest-cov", // not available in cXs
"python3-pyyaml",
"python3-rpm-generators",
"python3-rpm-macros",
"qemu-img",
//"qemu-system-x86", // not available in cXs
"rpm",
"rpm-build",
"rpm-ostree",
"rpmdevtools",
"skopeo",
"systemd",
"systemd-container",
"tar",
//"tox", // not available in cXs
"util-linux",
]),
}
dockerfile = "src/images/osbuild-ci-cstream.Dockerfile"
inherits = [
"virtual-osbuild-ci-base",
]
}

target "osbuild-ci-c8s-latest" {
args = {
OSB_FROM = "quay.io/centos/centos:stream8",
}
inherits = [
"virtual-osbuild-ci-cXs",
]
tags = concat(
mirror("osbuild-ci-c8s", "latest", "", OSB_UNIQUEID),
)
}

target "osbuild-ci-c9s-latest" {
args = {
OSB_FROM = "quay.io/centos/centos:stream9",
}
inherits = [
"virtual-osbuild-ci",
"virtual-osbuild-ci-base",
]
tags = concat(
mirror("osbuild-ci", "latest", "", OSB_UNIQUEID),
mirror("osbuild-ci-c9s", "latest", "", OSB_UNIQUEID),
)
}

Expand Down
62 changes: 62 additions & 0 deletions src/images/osbuild-ci-cstream.Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
#
# osbuild-ci - OSBuild CI Images
#
# This image provides the OS environment for the osbuild continuous integration
# on GitHub Actions. It is based on CesnOS Stream and includes all the required
# packages and utilities for running unit-tests.
#
# Arguments:
#
# * OSB_FROM="quay.io/centos/centos:stream9"
# This controls the host container used as base for the CI image.
#
# * OSB_DNF_PACKAGES=""
# Specify the packages to install into the container. Separate packages
# by comma. By default, no package is pulled in.
#
# * OSB_DNF_GROUPS=""
# Specify the package groups to install into the container. Separate
# groups by comma. By default, no group is pulled in.
#
# * OSB_PIP_PACKAGES=""
# Specify the packages to install into the container using pip. Separate
# packages by comma. By default, no packages are installed.
#

ARG OSB_FROM="quay.io/centos/centos:stream9"
FROM "${OSB_FROM}" AS target

#
# Import our build sources and prepare the target environment. When finished,
# we drop the build sources again, to keep the target image small.
#

WORKDIR /osb
COPY src src

ARG OSB_DNF_PACKAGES=""
ARG OSB_DNF_GROUPS=""
ARG OSB_PIP_PACKAGES=""
RUN ./src/scripts/dnf.sh "${OSB_DNF_PACKAGES}" "${OSB_DNF_GROUPS}"
RUN ./src/scripts/pip.sh "${OSB_PIP_PACKAGES}"
COPY src/scripts/osbuild-ci.sh .

RUN rm -rf /osb/src

#
# Allow cross-UID git access. Git users must be careful not to invoke git from
# within untrusted directory-paths.
#

RUN git config --global --add safe.directory '*'

#
# Rebuild from scratch to drop all intermediate layers and keep the final image
# as small as possible. Then setup the entrypoint.
#

FROM scratch
COPY --from=target . .

WORKDIR /osb/workdir
ENTRYPOINT ["/osb/osbuild-ci.sh"]
32 changes: 32 additions & 0 deletions src/scripts/pip.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
#!/bin/bash

#
# This script is a pip package install helper for container images. It takes
# packages as argument and then installs them via `pip3`.
#

set -eox pipefail

OSB_IFS=$IFS

#
# Parse command-line arguments into local variables. We accept:
# @1: Comma-separated list of packages to install.
#

if (( $# > 0 )) ; then
IFS=',' read -r -a PIP_PACKAGES <<< "$1"
IFS=$OSB_IFS
fi
if (( $# > 1 )) ; then
echo >&2 "ERROR: invalid number of arguments"
exit 1
fi

#
# Install the specified packages.
#

if (( ${#PIP_PACKAGES[@]} )) ; then
pip3 install --upgrade "${PIP_PACKAGES[@]}"
fi

0 comments on commit df4670f

Please sign in to comment.