From c945ed504635534c0619bd11804ca22f5b8a5cd1 Mon Sep 17 00:00:00 2001 From: Jonathan West Date: Thu, 5 Dec 2024 00:55:47 -0500 Subject: [PATCH 1/2] Update --- scripts/openshiftci-presubmit-all-tests.sh | 8 ++ scripts/run-kuttl-tests.sh | 52 ++++--- scripts/run-rollouts-e2e-tests.sh | 150 ++++++++++++++++++++- 3 files changed, 186 insertions(+), 24 deletions(-) diff --git a/scripts/openshiftci-presubmit-all-tests.sh b/scripts/openshiftci-presubmit-all-tests.sh index 852c05e92..c633eb6af 100755 --- a/scripts/openshiftci-presubmit-all-tests.sh +++ b/scripts/openshiftci-presubmit-all-tests.sh @@ -6,6 +6,10 @@ set -e # Do not show token in CI log set +x +# Get path containing the current script, usually (repo path)/scripts +SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd ) + + # show commands set -x export CI="prow" @@ -24,3 +28,7 @@ export KUBECONFIG=$TMP_DIR/kubeconfig # Run e2e test make test-e2e +# Run Rollouts E2E tests +cd "$SCRIPT_DIR" + +# "$SCRIPT_DIR/run-rollouts-e2e-tests.sh" diff --git a/scripts/run-kuttl-tests.sh b/scripts/run-kuttl-tests.sh index 8af2ab90e..5722ba76e 100755 --- a/scripts/run-kuttl-tests.sh +++ b/scripts/run-kuttl-tests.sh @@ -112,24 +112,36 @@ trap unexpectedError INT mkdir -p $WORK_DIR/results || exit 1 mkdir -p $DIR/results || exit 1 -case "$testsuite" in -"parallel") - header "Running $testsuite tests" - run_parallel $2 - ;; -"sequential") - header "Running $testsuite tests" - run_sequential $2 - ;; -"all") - header "Running $testsuite tests" - run_parallel - run_sequential - ;; -*) - echo "USAGE: $0 (parallel|sequential|all)" >&2 - exit 1 -esac +# Get path containing the current script, usually (repo path)/scripts +SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd ) + +# Run Rollouts E2E tests +cd "$SCRIPT_DIR" + +"$SCRIPT_DIR/run-rollouts-e2e-tests.sh" + + + + + +# case "$testsuite" in +# "parallel") +# header "Running $testsuite tests" +# run_parallel $2 +# ;; +# "sequential") +# header "Running $testsuite tests" +# run_sequential $2 +# ;; +# "all") +# header "Running $testsuite tests" +# run_parallel +# run_sequential +# ;; +# *) +# echo "USAGE: $0 (parallel|sequential|all)" >&2 +# exit 1 +# esac -(( failed )) && fail_test "$testsuite tests failed" -success $testsuite +# (( failed )) && fail_test "$testsuite tests failed" +# success $testsuite diff --git a/scripts/run-rollouts-e2e-tests.sh b/scripts/run-rollouts-e2e-tests.sh index 7ef5df8e2..4930e4035 100755 --- a/scripts/run-rollouts-e2e-tests.sh +++ b/scripts/run-rollouts-e2e-tests.sh @@ -1,11 +1,156 @@ #!/bin/bash # The goal of this script is to run the Argo Rollouts operator tests from the argo-rollouts-manager repo against gitops-operator: -# - Runs the (cluster-scoped) E2E tests of the Argo Rollouts operator +# - Runs the cluster-scoped/namespace-scoped E2E tests of the Argo Rollouts operator # - Runs the upstream E2E tests from the argo-rollouts repo set -ex +function wait_until_pods_running() { + echo -n "Waiting until all pods in namespace $1 are up" + + # Wait for there to be only a single Pod line in 'oc get pods' (there should be no more 'terminating' pods, etc) + timeout="true" + for i in {1..30}; do + local num_pods="$(oc get pods --no-headers -n $1 | wc -l 2>/dev/null)" + + # Check the number of lines + if [[ "$num_lines" == "1" ]]; then + echo "Waiting for a single Pod entry in Namespace '$1': $num_pods" + sleep 5 + else + timeout="false" + break + fi + done + if [ "$timeout" == "true" ]; then + echo -e "\n\nERROR: timeout waiting for expected number of pods" + return 1 + fi + + for i in {1..150}; do # timeout after 5 minutes + local pods="$(oc get pods --no-headers -n $1 2>/dev/null)" + # write it to tempfile + TempFile=$(mktemp) + oc get pods --no-headers -n $1 2>/dev/null >$TempFile + + # All pods must be running + local not_running=$(echo "${pods}" | grep -v Running | grep -v Completed | wc -l) + if [[ -n "${pods}" && ${not_running} -eq 0 ]]; then + local all_ready=1 + while read pod; do + local status=($(echo ${pod} | cut -f2 -d' ' | tr '/' ' ')) + # All containers must be ready + [[ -z ${status[0]} ]] && all_ready=0 && break + [[ -z ${status[1]} ]] && all_ready=0 && break + [[ ${status[0]} -lt 1 ]] && all_ready=0 && break + [[ ${status[1]} -lt 1 ]] && all_ready=0 && break + [[ ${status[0]} -ne ${status[1]} ]] && all_ready=0 && break + done <${TempFile} + if ((all_ready)); then + echo -e "\nAll pods are up:\n${pods}" + return 0 + fi + fi + echo -n "." + sleep 2 + done + echo -e "\n\nERROR: timeout waiting for pods to come up\n${pods}" + return 1 +} + +function enable_rollouts_cluster_scoped_namespaces() { + + # This functions add this env var to operator: + # - CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES="argo-rollouts,test-rom-ns-1,rom-ns-1" + + if ! [ -z $NON_OLM ]; then + oc set env deployment openshift-gitops-operator-controller-manager -n openshift-gitops-operator CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES="argo-rollouts,test-rom-ns-1,rom-ns-1" + + elif [ -z $CI ]; then + + oc patch -n openshift-gitops-operator subscription openshift-gitops-operator \ + --type merge --patch '{"spec": {"config": {"env": [{"name": "CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES", "value": "argo-rollouts,test-rom-ns-1,rom-ns-1"}]}}}' + + else + + oc patch -n openshift-gitops-operator subscription `subscription=gitops-operator- && oc get subscription --all-namespaces | grep $subscription | head -1 | awk '{print $2}'` \ + --type merge --patch '{"spec": {"config": {"env": [{"name": "CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES", "value": "argo-rollouts,test-rom-ns-1,rom-ns-1"}]}}}' + fi + + # Loop to wait until CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES is added to the OpenShift GitOps Operator Deployment + for i in {1..30}; do + if oc get deployment openshift-gitops-operator-controller-manager -n openshift-gitops-operator -o jsonpath='{.spec.template.spec.containers[0].env}' | grep -q '{"name":"CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES","value":"argo-rollouts,test-rom-ns-1,rom-ns-1"}'; then + echo "CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES to be set" + break + else + echo "Waiting for CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES to be set" + sleep 5 + fi + done + + # Verify the variable is set + if oc get deployment openshift-gitops-operator-controller-manager -n openshift-gitops-operator -o jsonpath='{.spec.template.spec.containers[0].env}' | grep -q '{"name":"CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES","value":"argo-rollouts,test-rom-ns-1,rom-ns-1"}'; then + echo "CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES is set." + else + echo "ERROR: CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES was never set." + exit 1 + fi + + # Deployment is correct, now wait for Pods to start + wait_until_pods_running "openshift-gitops-operator" + +} + +function disable_rollouts_cluster_scope_namespaces() { + + # Remove the env var we previously added to operator + + if ! [ -z $NON_OLM ]; then + + oc set env deployment openshift-gitops-operator-controller-manager -n openshift-gitops-operator CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES=null + + elif [ -z $CI ]; then + + oc patch -n openshift-gitops-operator subscription openshift-gitops-operator \ + --type json --patch '[{"op": "remove", "path": "/spec/config"}]' + else + + oc patch -n openshift-gitops-operator subscription `subscription=gitops-operator- && oc get subscription --all-namespaces | grep $subscription | head -1 | awk '{print $2}'` \ + --type json --patch '[{"op": "remove", "path": "/spec/config"}]' + fi + + + # Loop to wait until CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES is removed from the OpenShift GitOps Operator Deplyoment + for i in {1..30}; do + if oc get deployment openshift-gitops-operator-controller-manager -n openshift-gitops-operator -o jsonpath='{.spec.template.spec.containers[0].env}' | grep -q '{"name":"CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES","value":"argo-rollouts,test-rom-ns-1,rom-ns-1"}'; then + echo "Waiting for CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES to be removed" + sleep 5 + else + echo "CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES has been removed." + break + fi + done + + # Verify it has been removed. + if oc get deployment openshift-gitops-operator-controller-manager -n openshift-gitops-operator -o jsonpath='{.spec.template.spec.containers[0].env}' | grep -q '{"name":"CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES","value":"argo-rollouts,test-rom-ns-1,rom-ns-1"}'; then + echo "ERROR: CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES was not successfully removed." + exit 1 + else + echo "CLUSTER_SCOPED_ARGO_ROLLOUTS_NAMESPACES was successfuly removed." + fi + + # Wait for Pods to reflect the removal of the env var + wait_until_pods_running "openshift-gitops-operator" +} + + +enable_rollouts_cluster_scoped_namespaces + +trap disable_rollouts_cluster_scope_namespaces EXIT + + + ROLLOUTS_TMP_DIR=$(mktemp -d) cd $ROLLOUTS_TMP_DIR @@ -68,6 +213,3 @@ git checkout $TARGET_OPENSHIFT_ROUTE_ROLLOUT_PLUGIN_COMMIT make test-e2e - - - From d2ed165e615c19423c122dee7cca339c619eb176 Mon Sep 17 00:00:00 2001 From: Jonathan West Date: Thu, 5 Dec 2024 04:26:16 -0500 Subject: [PATCH 2/2] Update --- scripts/run-rollouts-e2e-tests.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/scripts/run-rollouts-e2e-tests.sh b/scripts/run-rollouts-e2e-tests.sh index 4930e4035..1312469b1 100755 --- a/scripts/run-rollouts-e2e-tests.sh +++ b/scripts/run-rollouts-e2e-tests.sh @@ -12,7 +12,7 @@ function wait_until_pods_running() { # Wait for there to be only a single Pod line in 'oc get pods' (there should be no more 'terminating' pods, etc) timeout="true" for i in {1..30}; do - local num_pods="$(oc get pods --no-headers -n $1 | wc -l 2>/dev/null)" + local num_pods="$(oc get pods --no-headers -n $1 | grep openshift-gitops-operator-controller-manager | wc -l 2>/dev/null)" # Check the number of lines if [[ "$num_lines" == "1" ]]; then @@ -29,7 +29,7 @@ function wait_until_pods_running() { fi for i in {1..150}; do # timeout after 5 minutes - local pods="$(oc get pods --no-headers -n $1 2>/dev/null)" + local pods="$(oc get pods --no-headers -n $1 | grep openshift-gitops-operator-controller-manager 2>/dev/null)" # write it to tempfile TempFile=$(mktemp) oc get pods --no-headers -n $1 2>/dev/null >$TempFile