Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
103 changes: 90 additions & 13 deletions test/bin/pyutils/build_bootc_images.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
# Switch to quay.io/centos-bootc/bootc-image-builder:latest if any new upstream
# features are required
BIB_IMAGE = "registry.redhat.io/rhel9/bootc-image-builder:latest"
IBC_IMAGE = "ghcr.io/osbuild/image-builder-cli:latest"
GOMPLATE = common.get_env_var('GOMPLATE')
MIRROR_REGISTRY = common.get_env_var('MIRROR_REGISTRY_URL')
FORCE_REBUILD = False
Expand All @@ -46,18 +47,19 @@ def cleanup_atexit(dry_run):
common.print_msg(f"Terminating {pid} PID")
common.terminate_process(pid)

# Terminate running bootc image builder containers
podman_args = [
"sudo", "podman", "ps",
"--filter", f"ancestor={BIB_IMAGE}",
"--format", "{{.ID}}"
]
cids = common.run_command_in_shell(podman_args, dry_run)
if cids:
# Make sure the ids are normalized in a single line
cids = re.sub(r'\s+', ' ', cids)
common.print_msg(f"Terminating '{cids}' container(s)")
common.run_command_in_shell(["sudo", "podman", "stop", cids], dry_run)
# Terminate running image builder containers
for builder_image in [BIB_IMAGE, IBC_IMAGE]:
podman_args = [
"sudo", "podman", "ps",
"--filter", f"ancestor={builder_image}",
"--format", "{{.ID}}"
]
cids = common.run_command_in_shell(podman_args, dry_run)
if cids:
# Make sure the ids are normalized in a single line
cids = re.sub(r'\s+', ' ', cids)
common.print_msg(f"Terminating '{cids}' container(s)")
common.run_command_in_shell(["sudo", "podman", "stop", cids], dry_run)


def find_latest_rpm(repo_path, version=""):
Expand Down Expand Up @@ -430,6 +432,76 @@ def should_skip(file):
os.rename(f"{bf_outdir}/bootiso/install.iso", bf_targetiso)


def process_image_installer(groupdir, installerfile, dry_run):
ii_path, ii_outname, ii_outdir, ii_logfile = get_process_file_names(
groupdir, installerfile, BOOTC_ISO_DIR)
ii_targetiso = os.path.join(VM_DISK_BASEDIR, f"{ii_outname}.iso")

def should_skip(file):
if FORCE_REBUILD:
common.print_msg(f"Forcing rebuild of '{file}'")
return False
if not os.path.exists(file):
return False
common.print_msg(f"The '{file}' already exists, skipping")
return True

if should_skip(ii_targetiso):
common.record_junit(ii_path, "process-image-installer", "SKIPPED")
return

os.makedirs(ii_outdir, exist_ok=True)
os.makedirs(VM_DISK_BASEDIR, exist_ok=True)
ii_outfile = os.path.join(BOOTC_IMAGE_DIR, installerfile)
run_template_cmd(ii_path, ii_outfile, dry_run)
if not dry_run:
if not common.file_has_valid_lines(ii_outfile):
common.print_msg(f"Skipping an empty {installerfile} file")
return

common.print_msg(f"Processing {installerfile} with logs in {ii_logfile}")
start_process_image_installer = time.time()
try:
with open(ii_logfile, 'w') as logfile:
ii_distro = common.read_file_valid_lines(ii_outfile).strip()

build_args = [
"sudo", "podman", "run",
"--rm", "-i", "--privileged",
"--network", "host",
"--pull=newer",
"--security-opt", "label=type:unconfined_t",
"-v", f"{ii_outdir}:/output",
]
if os.path.isdir("/etc/pki/entitlement"):
build_args += [
"-v", "/etc/pki/entitlement:/etc/pki/entitlement:ro",
"-v", "/etc/rhsm:/etc/rhsm:ro",
]
build_args += [
IBC_IMAGE,
"build", "--distro", ii_distro,
"image-installer"
]
start = time.time()
common.retry_on_exception(3, common.run_command_in_shell, build_args, dry_run, logfile, logfile)
common.record_junit(ii_path, "build-installer-image", "OK", start)
except Exception:
common.record_junit(ii_path, "process-image-installer", "FAILED", start_process_image_installer, log_filepath=ii_logfile)
raise
finally:
common.run_command(["sed", f"s/^/{ii_outname}: /", ii_logfile], dry_run)

if not dry_run:
common.run_command(
["sudo", "chown", "-R", f"{getpass.getuser()}.", ii_outdir],
dry_run)
iso_candidates = glob.glob(f"{ii_outdir}/**/*.iso", recursive=True)
if not iso_candidates:
raise Exception(f"No ISO found in {ii_outdir}")
os.rename(iso_candidates[0], ii_targetiso)


def process_container_encapsulate(groupdir, containerfile, dry_run):
ce_path, ce_outname, _, ce_logfile = get_process_file_names(
groupdir, containerfile, BOOTC_IMAGE_DIR)
Expand Down Expand Up @@ -546,6 +618,11 @@ def process_group(groupdir, build_type, pattern="*", dry_run=False):
common.print_msg(f"Skipping '{file}' due to '{build_type}' filter")
continue
futures.append(executor.submit(process_image_bootc, groupdir, file, dry_run))
elif file.endswith(".image-installer"):
if build_type and build_type != "image-installer":
common.print_msg(f"Skipping '{file}' due to '{build_type}' filter")
continue
futures.append(executor.submit(process_image_installer, groupdir, file, dry_run))
elif file.endswith(".container-encapsulate"):
if build_type and build_type != "container-encapsulate":
common.print_msg(f"Skipping '{file}' due to '{build_type}' filter")
Expand Down Expand Up @@ -580,7 +657,7 @@ def main():
parser.add_argument("-E", "--no-extract-images", action="store_true", help="Skip container image extraction.")
parser.add_argument("-X", "--skip-all-builds", action="store_true", help="Skip all image builds.")
parser.add_argument("-b", "--build-type",
choices=["image-bootc", "containerfile", "container-encapsulate"],
choices=["image-bootc", "image-installer", "containerfile", "container-encapsulate"],
help="Only build images of the specified type.")
dirgroup = parser.add_mutually_exclusive_group(required=False)
dirgroup.add_argument("-l", "--layer-dir", type=str, help="Path to the layer directory to process.")
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@

# TODO: Replace this by a RHEL 10.2 image when its RPM repositories are released.
# rhel-10.2
rhel-10.1
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@

# TODO: Replace this by a RHEL 9.8 image when its RPM repositories are released.
# rhel-9.8
rhel-9.7
119 changes: 119 additions & 0 deletions test/scenarios-bootc/el10/presubmits/el102-src@rpm-install.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,119 @@
#!/bin/bash

# Sourced from scenario.sh and uses functions defined there.

# The RPM-based image used to create the VM for this test does not
# include MicroShift or greenboot, so tell the framework not to wait
# for greenboot to finish when creating the VM.
export SKIP_GREENBOOT=true

# NOTE: Unlike most suites, these tests rely on being run IN ORDER to
# ensure the host is in a good state at the start of each test. We
# could have separated them and run them as separate scenarios, but
# did not want to spend the resources on a new VM.
export TEST_RANDOMIZATION=none

configure_microshift_mirror() {
local -r repo=$1

# `repo` might be empty if we install microshift from rhocp
if [[ -z "${repo}" ]] ; then
return
fi

# `repo` might be an enabled repo from a released version instead
# of a mirror.
if [[ ! "${repo}" =~ ^http ]]; then
return
fi

local -r tmp_file=$(mktemp)
tee "${tmp_file}" >/dev/null <<EOF
[microshift-mirror-rpms]
name=MicroShift Mirror
baseurl=${repo}
enabled=1
gpgcheck=0
skip_if_unavailable=0
EOF
copy_file_to_vm host1 "${tmp_file}" "${tmp_file}"
run_command_on_vm host1 "sudo cp ${tmp_file} /etc/yum.repos.d/microshift-mirror-rpms.repo"
rm -f "${tmp_file}"
}

configure_rhocp_repo() {
local -r rhocp=$1
local -r major=$2
local -r minor=$3

# The repository may be empty if the beta mirror is not up yet
if [[ -z "${rhocp}" ]] ; then
return
fi

if [[ "${rhocp}" =~ ^[0-9]{1,2}$ ]]; then
run_command_on_vm host1 "sudo subscription-manager repos --enable rhocp-${major}.${rhocp}-for-rhel-9-\$(uname -m)-rpms"
elif [[ "${rhocp}" =~ ^http ]]; then
local -r ocp_repo_name="rhocp-${major}.${minor}-for-rhel-9-mirrorbeta-rpms"
local -r tmp_file=$(mktemp)

tee "${tmp_file}" >/dev/null <<EOF
[${ocp_repo_name}]
name=Beta rhocp RPMs for RHEL 9
baseurl=${rhocp}
enabled=1
gpgcheck=0
skip_if_unavailable=0
EOF
copy_file_to_vm host1 "${tmp_file}" "${tmp_file}"
run_command_on_vm host1 "sudo cp ${tmp_file} /etc/yum.repos.d/${ocp_repo_name}.repo"
rm -f "${tmp_file}"
fi
}

scenario_create_vms() {
prepare_kickstart host1 kickstart-liveimg.ks.template ""
launch_vm rhel102-installer

# Open the firewall ports. Other scenarios get this behavior by
# embedding settings in the blueprint, but there is no blueprint
# for this scenario. We need do this step before running the RF
# suite so that suite can assume it can reach all of the same
# ports as for any other test.
configure_vm_firewall host1

# Register the host with subscription manager so we can install
# dependencies.
subscription_manager_register host1
}

scenario_remove_vms() {
remove_vm host1
}

scenario_run_tests() {
local -r source_reponame=$(basename "${LOCAL_REPO}")
local -r source_repo_url="${WEB_SERVER_URL}/rpm-repos/${source_reponame}"
local -r target_version=$(local_rpm_version)

# Enable the rhocp and dependency repositories.
#
# Note that rhocp or beta dependencies repository may not yet exist
# for the current version. Then, just use whatever we can get for
# the previous minor version.
configure_rhocp_repo "${RHOCP_MINOR_Y}" "${MAJOR_VERSION}" "${MINOR_VERSION}"
configure_rhocp_repo "${RHOCP_MINOR_Y_BETA}" "${MAJOR_VERSION}" "${MINOR_VERSION}"
configure_rhocp_repo "${RHOCP_MINOR_Y1}" "${PREVIOUS_MAJOR_VERSION}" "${PREVIOUS_MINOR_VERSION}"
configure_rhocp_repo "${RHOCP_MINOR_Y1_BETA}" "${PREVIOUS_MAJOR_VERSION}" "${PREVIOUS_MINOR_VERSION}"
configure_microshift_mirror "${PREVIOUS_RELEASE_REPO}"
run_command_on_vm host1 "sudo subscription-manager repos --enable fast-datapath-for-rhel-10-\$(uname -m)-rpms"

run_tests host1 \
--exitonfailure \
--variable "SOURCE_REPO_URL:${source_repo_url}" \
--variable "TARGET_VERSION:${target_version}" \
--variable "PREVIOUS_MINOR_VERSION:${PREVIOUS_MINOR_VERSION}" \
suites/rpm/install.robot \
suites/rpm/remove.robot \
suites/rpm/upgrade-successful.robot
}
119 changes: 119 additions & 0 deletions test/scenarios-bootc/el9/presubmits/el98-src@rpm-install.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,119 @@
#!/bin/bash

# Sourced from scenario.sh and uses functions defined there.

# The RPM-based image used to create the VM for this test does not
# include MicroShift or greenboot, so tell the framework not to wait
# for greenboot to finish when creating the VM.
export SKIP_GREENBOOT=true

# NOTE: Unlike most suites, these tests rely on being run IN ORDER to
# ensure the host is in a good state at the start of each test. We
# could have separated them and run them as separate scenarios, but
# did not want to spend the resources on a new VM.
export TEST_RANDOMIZATION=none

configure_microshift_mirror() {
local -r repo=$1

# `repo` might be empty if we install microshift from rhocp
if [[ -z "${repo}" ]] ; then
return
fi

# `repo` might be an enabled repo from a released version instead
# of a mirror.
if [[ ! "${repo}" =~ ^http ]]; then
return
fi

local -r tmp_file=$(mktemp)
tee "${tmp_file}" >/dev/null <<EOF
[microshift-mirror-rpms]
name=MicroShift Mirror
baseurl=${repo}
enabled=1
gpgcheck=0
skip_if_unavailable=0
EOF
copy_file_to_vm host1 "${tmp_file}" "${tmp_file}"
run_command_on_vm host1 "sudo cp ${tmp_file} /etc/yum.repos.d/microshift-mirror-rpms.repo"
rm -f "${tmp_file}"
}

configure_rhocp_repo() {
local -r rhocp=$1
local -r major=$2
local -r minor=$3

# The repository may be empty if the beta mirror is not up yet
if [[ -z "${rhocp}" ]] ; then
return
fi

if [[ "${rhocp}" =~ ^[0-9]{1,2}$ ]]; then
run_command_on_vm host1 "sudo subscription-manager repos --enable rhocp-${major}.${rhocp}-for-rhel-9-\$(uname -m)-rpms"
elif [[ "${rhocp}" =~ ^http ]]; then
local -r ocp_repo_name="rhocp-${major}.${minor}-for-rhel-9-mirrorbeta-rpms"
local -r tmp_file=$(mktemp)

tee "${tmp_file}" >/dev/null <<EOF
[${ocp_repo_name}]
name=Beta rhocp RPMs for RHEL 9
baseurl=${rhocp}
enabled=1
gpgcheck=0
skip_if_unavailable=0
EOF
copy_file_to_vm host1 "${tmp_file}" "${tmp_file}"
run_command_on_vm host1 "sudo cp ${tmp_file} /etc/yum.repos.d/${ocp_repo_name}.repo"
rm -f "${tmp_file}"
fi
}

scenario_create_vms() {
prepare_kickstart host1 kickstart-liveimg.ks.template ""
launch_vm rhel98-installer

# Open the firewall ports. Other scenarios get this behavior by
# embedding settings in the blueprint, but there is no blueprint
# for this scenario. We need do this step before running the RF
# suite so that suite can assume it can reach all of the same
# ports as for any other test.
configure_vm_firewall host1

# Register the host with subscription manager so we can install
# dependencies.
subscription_manager_register host1
}

scenario_remove_vms() {
remove_vm host1
}

scenario_run_tests() {
local -r source_reponame=$(basename "${LOCAL_REPO}")
local -r source_repo_url="${WEB_SERVER_URL}/rpm-repos/${source_reponame}"
local -r target_version=$(local_rpm_version)

# Enable the rhocp and dependency repositories.
#
# Note that rhocp or beta dependencies repository may not yet exist
# for the current version. Then, just use whatever we can get for
# the previous minor version.
configure_rhocp_repo "${RHOCP_MINOR_Y}" "${MAJOR_VERSION}" "${MINOR_VERSION}"
configure_rhocp_repo "${RHOCP_MINOR_Y_BETA}" "${MAJOR_VERSION}" "${MINOR_VERSION}"
configure_rhocp_repo "${RHOCP_MINOR_Y1}" "${PREVIOUS_MAJOR_VERSION}" "${PREVIOUS_MINOR_VERSION}"
configure_rhocp_repo "${RHOCP_MINOR_Y1_BETA}" "${PREVIOUS_MAJOR_VERSION}" "${PREVIOUS_MINOR_VERSION}"
configure_microshift_mirror "${PREVIOUS_RELEASE_REPO}"
run_command_on_vm host1 "sudo subscription-manager repos --enable fast-datapath-for-rhel-9-\$(uname -m)-rpms"

run_tests host1 \
--exitonfailure \
--variable "SOURCE_REPO_URL:${source_repo_url}" \
--variable "TARGET_VERSION:${target_version}" \
--variable "PREVIOUS_MINOR_VERSION:${PREVIOUS_MINOR_VERSION}" \
suites/rpm/install.robot \
suites/rpm/remove.robot \
suites/rpm/upgrade-successful.robot
}