From ce2003fd63ca40b7ca8021fafeec00e86d1e8461 Mon Sep 17 00:00:00 2001 From: Andrea Panattoni Date: Tue, 10 Oct 2023 09:42:15 +0200 Subject: [PATCH] e2e: Allow testing custom cni and dp image Let `run-e2e-conformance-virtual-ocp.sh` and `run-e2e-conformance-virtual-cluster.sh` deploy clusters with specific SRIOV CNI and Device Plugin images. This will enable other projects to have full end-to-end test CI with operator's suite. Signed-off-by: Andrea Panattoni --- hack/run-e2e-conformance-common | 10 ++++++++++ hack/run-e2e-conformance-virtual-cluster.sh | 14 ++++++++++++++ hack/run-e2e-conformance-virtual-ocp.sh | 12 ++++++++++++ 3 files changed, 36 insertions(+) create mode 100644 hack/run-e2e-conformance-common diff --git a/hack/run-e2e-conformance-common b/hack/run-e2e-conformance-common new file mode 100644 index 0000000000..c2a71e518b --- /dev/null +++ b/hack/run-e2e-conformance-common @@ -0,0 +1,10 @@ +#!/bin/bash + +podman_tag_and_push() { + local_image=$1 + cluster_image=$2 + + echo "## Pushing ${local_image} to cluster registry ${cluster_image}" + podman tag ${local_image} ${cluster_image} + podman push --tls-verify=false ${cluster_image} +} diff --git a/hack/run-e2e-conformance-virtual-cluster.sh b/hack/run-e2e-conformance-virtual-cluster.sh index 8f9f2c4403..a463ad218e 100755 --- a/hack/run-e2e-conformance-virtual-cluster.sh +++ b/hack/run-e2e-conformance-virtual-cluster.sh @@ -1,6 +1,8 @@ #!/usr/bin/env bash + set -xeo pipefail + cluster_name=${CLUSTER_NAME:-virtual} domain_name=$cluster_name.lab @@ -11,6 +13,8 @@ HOME="/root" here="$(dirname "$(readlink --canonicalize "${BASH_SOURCE[0]}")")" root="$(readlink --canonicalize "$here/..")" +source $here/run-e2e-conformance-common + check_requirements() { for cmd in kcli virsh virt-edit podman make go; do if ! command -v "$cmd" &> /dev/null; then @@ -254,6 +258,16 @@ podman push --tls-verify=false "${SRIOV_NETWORK_OPERATOR_IMAGE}" podman push --tls-verify=false "${SRIOV_NETWORK_CONFIG_DAEMON_IMAGE}" podman push --tls-verify=false "${SRIOV_NETWORK_WEBHOOK_IMAGE}" + +if [[ -v LOCAL_SRIOV_CNI_IMAGE ]]; then + podman_tag_and_push ${LOCAL_SRIOV_CNI_IMAGE} "$controller_ip:5000/sriov-cni:latest" +fi + +if [[ -v LOCAL_SRIOV_DEVICE_PLUGIN_IMAGE ]]; then + podman_tag_and_push ${LOCAL_SRIOV_DEVICE_PLUGIN_IMAGE} "$controller_ip:5000/sriov-network-device-plugin:latest" +fi + + # remove the crio bridge and let flannel to recreate kcli ssh $cluster_name-ctlplane-0 << EOF sudo su diff --git a/hack/run-e2e-conformance-virtual-ocp.sh b/hack/run-e2e-conformance-virtual-ocp.sh index a23410b040..09f7d54e78 100755 --- a/hack/run-e2e-conformance-virtual-ocp.sh +++ b/hack/run-e2e-conformance-virtual-ocp.sh @@ -12,6 +12,8 @@ HOME="/root" here="$(dirname "$(readlink --canonicalize "${BASH_SOURCE[0]}")")" root="$(readlink --canonicalize "$here/..")" +source $here/run-e2e-conformance-common + check_requirements() { for cmd in kcli virsh podman make go jq base64 tar; do if ! command -v "$cmd" &> /dev/null; then @@ -204,6 +206,16 @@ podman push --tls-verify=false "${SRIOV_NETWORK_OPERATOR_IMAGE}" podman push --tls-verify=false "${SRIOV_NETWORK_CONFIG_DAEMON_IMAGE}" podman push --tls-verify=false "${SRIOV_NETWORK_WEBHOOK_IMAGE}" + +if [[ -v LOCAL_SRIOV_CNI_IMAGE ]]; then + podman_tag_and_push ${LOCAL_SRIOV_CNI_IMAGE} "$registry/$NAMESPACE/sriov-cni:latest" +fi + +if [[ -v LOCAL_SRIOV_DEVICE_PLUGIN_IMAGE ]]; then + podman_tag_and_push ${LOCAL_SRIOV_DEVICE_PLUGIN_IMAGE} "$registry/$NAMESPACE/sriov-network-device-plugin:latest" +fi + + podman logout $registry echo "## apply CRDs"