From eb4f0bc17df4f327e6acfad35c9384199fce1d48 Mon Sep 17 00:00:00 2001 From: Chris Evich Date: Thu, 11 May 2023 15:16:45 -0400 Subject: [PATCH 1/2] Cirrus: Remove support for `[CI:COPR]` magic This magic string isn't often used and may cause confusion with future magic-string additions. Remove it. Signed-off-by: Chris Evich --- .cirrus.yml | 5 ----- contrib/cirrus/CIModes.md | 7 ------- 2 files changed, 12 deletions(-) diff --git a/.cirrus.yml b/.cirrus.yml index 0ad227805d..8537ff8607 100644 --- a/.cirrus.yml +++ b/.cirrus.yml @@ -300,7 +300,6 @@ bindings_task: only_if: >- $CIRRUS_PR != '' && $CIRRUS_CHANGE_TITLE !=~ '.*CI:DOCS.*' && - $CIRRUS_CHANGE_TITLE !=~ '.*CI:COPR.*' && $CIRRUS_CHANGE_TITLE !=~ '.*CI:BUILD.*' depends_on: - build @@ -459,7 +458,6 @@ docker-py_test_task: only_if: ¬_tag_branch_build_docs >- $CIRRUS_PR != '' && $CIRRUS_CHANGE_TITLE !=~ '.*CI:DOCS.*' && - $CIRRUS_CHANGE_TITLE !=~ '.*CI:COPR.*' && $CIRRUS_CHANGE_TITLE !=~ '.*CI:BUILD.*' depends_on: @@ -566,7 +564,6 @@ windows_smoke_test_task: $CIRRUS_TAG == '' && $CIRRUS_CRON != 'multiarch' && $CIRRUS_CHANGE_TITLE !=~ '.*CI:DOCS.*' && - $CIRRUS_CHANGE_TITLE !=~ '.*CI:COPR.*' && $CIRRUS_BRANCH !=~ 'v[0-9\.]+-rhel' && $CIRRUS_BASE_BRANCH !=~ 'v[0-9\.]+-rhel' depends_on: @@ -684,7 +681,6 @@ podman_machine_task: only_if: ¬_tag_build_docs_multiarch >- $CIRRUS_TAG == '' && $CIRRUS_CHANGE_TITLE !=~ '.*CI:DOCS.*' && - $CIRRUS_CHANGE_TITLE !=~ '.*CI:COPR.*' && $CIRRUS_CHANGE_TITLE !=~ '.*CI:BUILD.*' && $CIRRUS_CRON != 'multiarch' depends_on: @@ -1090,7 +1086,6 @@ artifacts_task: # Docs: ./contrib/cirrus/CIModes.md only_if: >- $CIRRUS_CHANGE_TITLE !=~ '.*CI:DOCS.*' && - $CIRRUS_CHANGE_TITLE !=~ '.*CI:COPR.*' && $CIRRUS_CRON != 'multiarch' && $CIRRUS_BRANCH !=~ 'v[0-9\.]+-rhel' && $CIRRUS_BASE_BRANCH !=~ 'v[0-9\.]+-rhel' diff --git a/contrib/cirrus/CIModes.md b/contrib/cirrus/CIModes.md index 383aa399a2..abf18e37c4 100644 --- a/contrib/cirrus/CIModes.md +++ b/contrib/cirrus/CIModes.md @@ -79,13 +79,6 @@ of this document, it's not possible to override the behavior of `$CIRRUS_PR`. + meta + success -### Intended `[CI:COPR]` PR Tasks: -+ *build* -+ validate -+ swagger -+ meta -+ success - ### Intended `[CI:BUILD]` PR Tasks: + *build* + validate From d1dcb0846bed92e013a4771253feaebc1645e4cf Mon Sep 17 00:00:00 2001 From: Chris Evich Date: Thu, 11 May 2023 15:17:47 -0400 Subject: [PATCH 2/2] Cirrus: Add support for `[CI:NEXT]` Rather than supporting a special-mode *just* for netavark/aardvark testing [in podman CI], support testing with all the latest `podman-next` COPR packages. The idea here is very similar to the netavark/aardvark special mode it replaces. Most podman-dependencies do not have the level of comprehensive CI as exist here. This new CI-mode allows testing upstream updates to podman-dependencies without needing to roll out a whole new package/release for them. Also update documentation for this new mode. Signed-off-by: Chris Evich --- contrib/cirrus/CIModes.md | 12 +++++------ contrib/cirrus/lib.sh | 33 ----------------------------- contrib/cirrus/setup_environment.sh | 22 +++++++++++++++++++ 3 files changed, 28 insertions(+), 39 deletions(-) diff --git a/contrib/cirrus/CIModes.md b/contrib/cirrus/CIModes.md index abf18e37c4..0f6a65ce44 100644 --- a/contrib/cirrus/CIModes.md +++ b/contrib/cirrus/CIModes.md @@ -89,13 +89,13 @@ of this document, it's not possible to override the behavior of `$CIRRUS_PR`. + success + artifacts -### Intended `[CI:NVAV=update]` or `[CI:NVAV=main]` behavior: +### Intended `[CI:NEXT]` behavior: -If and only if the PR is in **draft-mode**, either update Fedora CI VMs to the -latest Netavark/Aardvark-dns RPMs ("update" keyword), or install the most -recent package builds from their `main` branch ("main" keyword). These are -**runtime changes** only, and will not persist or impact other PRs -in any way. +If and only if the PR is in **draft-mode**, update Fedora CI VMs at runtime +to the latest packages available in the podman-next COPR repo. These packages +represent primary podman dependencies, and are regularly built from their +upstream repos. These are **runtime changes** only, and will not persist +or impact other PRs in any way. The intent is to temporarily support testing of updates with the latest podman code & tests. To help prevent accidents, when the PR is not in draft-mode, the diff --git a/contrib/cirrus/lib.sh b/contrib/cirrus/lib.sh index 9a6089bee8..265763b8b4 100644 --- a/contrib/cirrus/lib.sh +++ b/contrib/cirrus/lib.sh @@ -256,39 +256,6 @@ use_netavark() { # N/B: The CNI packages are still installed and available. This is # on purpose, since CI needs to verify the selection mechanisms are # functional when both are available. - - # See ./contrib/cirrus/CIModes.md. - # Vars defined by cirrus-ci - # shellcheck disable=SC2154 - if [[ ! "$OS_RELEASE_ID" =~ "debian" ]] && \ - [[ "$CIRRUS_CHANGE_TITLE" =~ CI:[AN]V[AN]V= ]] - then - # shellcheck disable=SC2154 - if [[ "$CIRRUS_PR_DRAFT" != "true" ]]; then - die "Magic 'CI:NVAV=*' string can only be used on DRAFT PRs" - fi - - magickind=$(sed -r -e 's~(.*CI:[AN]V[AN]V=)(\w+)(.*)~\2~' <<<"$CIRRUS_CHANGE_TITLE") - - # The update source scheme is defined during VM image build. - # See c/automation_images repo. cache_images/fedora_packaging.sh - repokind="updates-testing" # $DISTRO_NV==$FEDORA_NAME - # shellcheck disable=SC2154 - if [[ "$DISTRO_NV" =~ $PRIOR_FEDORA_NAME ]]; then - repokind="updates" - # else we're not running fedora, or .cirrus.yml env. vars are setup wrong. - fi - - if [[ "$magickind" == "update" ]]; then - warn "Updating netavark/aardvark RPM packages from ***the fedora $repokind repo.***" - elif [[ "$magickind" == "main" ]]; then - warn "Installing latest netavark/aardvark packages from their main branches using ***the podman-next COPR repo***" - showrun dnf copr enable rhcontainerbot/podman-next -y - else - die "Unknown CI:NVAV= '$magickind' keyword. Only 'update' and 'main' are supported." - fi - showrun dnf upgrade -y netavark aardvark-dns - fi } # Remove all files provided by the distro version of podman. diff --git a/contrib/cirrus/setup_environment.sh b/contrib/cirrus/setup_environment.sh index b315cd58cd..f3068787cb 100755 --- a/contrib/cirrus/setup_environment.sh +++ b/contrib/cirrus/setup_environment.sh @@ -395,6 +395,28 @@ case "$TEST_FLAVOR" in *) die_unknown TEST_FLAVOR esac +# See ./contrib/cirrus/CIModes.md. +# Vars defined by cirrus-ci +# shellcheck disable=SC2154 +if [[ ! "$OS_RELEASE_ID" =~ "debian" ]] && \ + [[ "$CIRRUS_CHANGE_TITLE" =~ CI:NEXT ]] +then + # shellcheck disable=SC2154 + if [[ "$CIRRUS_PR_DRAFT" != "true" ]]; then + die "Magic 'CI:NEXT' string can only be used on DRAFT PRs" + fi + + showrun dnf copr enable rhcontainerbot/podman-next -y + + # DNF ignores repos that don't exist. For example, updates-testing is not + # enabled on Fedora N-1 CI VMs. Don't updated everything, isolate just the + # podman-next COPR updates. + showrun dnf update -y \ + "--enablerepo=copr:copr.fedorainfracloud.org:rhcontainerbot:podman-next" \ + "--disablerepo=copr:copr.fedorainfracloud.org:sbrivio:passt" \ + "--disablerepo=fedora*" "--disablerepo=updates*" +fi + # Must be the very last command. Prevents setup from running twice. echo 'SETUP_ENVIRONMENT=1' >> /etc/ci_environment echo -e "\n# End of global variable definitions" \