metadata: annotations: description: Periodically tests latest Scylla Operator on GKE in multi-datacenter setup. prow.k8s.io/context: "" prow.k8s.io/job: ci-scylla-operator-v1.15-e2e-gke-multi-datacenter-parallel creationTimestamp: "2025-03-31T06:00:07Z" generation: 7 labels: app: scylla-operator created-by-prow: "true" prow.k8s.io/build-id: "1906587290407276544" prow.k8s.io/context: "" prow.k8s.io/id: d09a6939-ba2b-4427-9725-c28970e651ab prow.k8s.io/job: ci-scylla-operator-v1.15-e2e-gke-multi-datacenter-parallel prow.k8s.io/refs.base_ref: v1.15 prow.k8s.io/refs.org: scylladb prow.k8s.io/refs.repo: scylla-operator prow.k8s.io/type: periodic name: d09a6939-ba2b-4427-9725-c28970e651ab namespace: prow-workspace resourceVersion: "614020260" uid: ff01caf5-0082-4cb1-9894-db4357c23509 spec: agent: kubernetes cluster: default decoration_config: gcs_configuration: bucket: gs://scylla-operator-prow path_strategy: explicit gcs_credentials_secret: gcs-credentials github_api_endpoints: - http://ghproxy.prow.svc - https://api.github.com github_app_id: "112385" github_app_private_key_secret: key: cert name: github-token grace_period: 15m0s resources: clonerefs: requests: cpu: 100m initupload: requests: cpu: 100m place_entrypoint: requests: cpu: 100m sidecar: requests: cpu: 100m timeout: 4h0m0s utility_images: clonerefs: us-docker.pkg.dev/k8s-infra-prow/images/clonerefs:v20240802-66b115076 entrypoint: us-docker.pkg.dev/k8s-infra-prow/images/entrypoint:v20240802-66b115076 initupload: us-docker.pkg.dev/k8s-infra-prow/images/initupload:v20240802-66b115076 sidecar: us-docker.pkg.dev/k8s-infra-prow/images/sidecar:v20240802-66b115076 extra_refs: - base_ref: v1.15 org: scylladb path_alias: github.com/scylladb/scylla-operator repo: scylla-operator workdir: true job: ci-scylla-operator-v1.15-e2e-gke-multi-datacenter-parallel max_concurrency: 1 namespace: prow-workspace pod_spec: containers: - args: - | function cleanup { touch /tmp/shared/setup.finished kubectl -n ci-clusters delete --wait=false --ignore-not-found kubernetesclusterset/"${POD_UID}" } trap cleanup EXIT kubectl -n ci-clusters create -f - < /tmp/shared/kubeconfigs.init/"${1}".kubeconfig kubectl --kubeconfig=/tmp/shared/kubeconfigs.init/"${1}".kubeconfig config set-context --current --namespace 'default-unexisting-namespace' } mkdir /tmp/shared/kubeconfigs.init for name in "europe-west1" "europe-west3" "europe-west4"; do get_kubeconfig "${name}" # Sanity check. kubectl --kubeconfig=/tmp/shared/kubeconfigs.init/"${name}".kubeconfig version -o yaml kubectl --kubeconfig=/tmp/shared/kubeconfigs.init/"${name}".kubeconfig config view done # Signal cluster bootstrap by sharing the kubeconfigs. mv /tmp/shared/kubeconfigs{.init,} set +x # TODO: Wait on active signal like updating a file every X seconds # so we can deal with the other container being OOM killed. echo "Waiting for test to finish..." until [[ -f "/tmp/shared/test.finished" ]]; do sleep 1; done echo "Test has finished." set -x command: - /usr/bin/bash - -euExo - pipefail - -O - inherit_errexit - -c env: - name: POD_UID valueFrom: fieldRef: fieldPath: metadata.uid image: quay.io/scylladb/scylla-operator-images:kube-tools imagePullPolicy: Always name: setup resources: limits: cpu: 100m memory: 200Mi securityContext: allowPrivilegeEscalation: false capabilities: drop: - ALL seccompProfile: type: RuntimeDefault volumeMounts: - mountPath: /var/run/secrets/kubernetes.io/serviceaccount/ name: kube-api-access - mountPath: /tmp/shared name: shared-data - args: - | trap 'touch /tmp/shared/test.finished' EXIT set +x echo "Waiting for cluster to be provisioned..." until [[ -d "${KUBECONFIG_DIR}" ]] || [[ -f /tmp/shared/setup.finished ]]; do sleep 1; done if [[ -f /tmp/shared/setup.finished ]]; then echo "Cluster provisioning failed. Exiting." exit 1 fi echo "Cluster provisioning has finished." set -x for f in $( find "$( realpath "${KUBECONFIG_DIR}" )" -maxdepth 1 -type f -name '*.kubeconfig' ); do # Setup info and kubeconfig sanity check kubectl --kubeconfig="${f}" config view kubectl --kubeconfig="${f}" version -o yaml kubectl --kubeconfig="${f}" cluster-info done function resolve-image { ( set -euEo pipefail local digest digest=$( skopeo inspect --raw docker://"${1}" | skopeo manifest-digest /dev/stdin ) echo "${1}@${digest}" ) } SO_NODECONFIG_PATH="./hack/.ci/manifests/cluster/nodeconfig.yaml" export SO_NODECONFIG_PATH SO_CSI_DRIVER_PATH="./hack/.ci/manifests/namespaces/local-csi-driver/" export SO_CSI_DRIVER_PATH SO_IMAGE="$( resolve-image docker.io/scylladb/scylla-operator:1.15 )" # We need to strip the tag because skopeo doesn't support references with both a tag and a digest. SO_IMAGE="${SO_IMAGE/:*([^:\/])@/@}" export SO_IMAGE SO_SUITE=scylla-operator/conformance/multi-datacenter-parallel export SO_SUITE SO_SCYLLACLUSTER_NODE_SERVICE_TYPE=Headless export SO_SCYLLACLUSTER_NODE_SERVICE_TYPE SO_SCYLLACLUSTER_NODES_BROADCAST_ADDRESS_TYPE=PodIP export SO_SCYLLACLUSTER_NODES_BROADCAST_ADDRESS_TYPE SO_SCYLLACLUSTER_CLIENTS_BROADCAST_ADDRESS_TYPE=PodIP export SO_SCYLLACLUSTER_CLIENTS_BROADCAST_ADDRESS_TYPE timeout -v 4h ./hack/.ci/run-e2e-gke-release.sh command: - /usr/bin/bash - -euExo - pipefail - -O - inherit_errexit - -O - extglob - -c env: - name: POD_UID valueFrom: fieldRef: fieldPath: metadata.uid - name: KUBECONFIG_DIR value: /tmp/shared/kubeconfigs image: quay.io/scylladb/scylla-operator-images:kube-tools imagePullPolicy: Always name: test resources: limits: cpu: 100m memory: 1200Mi securityContext: allowPrivilegeEscalation: false capabilities: drop: - ALL seccompProfile: type: RuntimeDefault volumeMounts: - mountPath: /tmp/shared name: shared-data serviceAccountName: e2e volumes: - emptyDir: {} name: shared-data - name: kube-api-access projected: defaultMode: 400 sources: - serviceAccountToken: path: token - configMap: items: - key: ca.crt path: ca.crt name: kube-root-ca.crt - downwardAPI: items: - fieldRef: apiVersion: v1 fieldPath: metadata.namespace path: namespace prowjob_defaults: tenant_id: GlobalDefaultID report: true type: periodic status: build_id: "1906587290407276544" completionTime: "2025-03-31T07:15:53Z" description: Job succeeded. pendingTime: "2025-03-31T06:00:07Z" pod_name: d09a6939-ba2b-4427-9725-c28970e651ab prev_report_states: gcsk8sreporter: success gcsreporter: success startTime: "2025-03-31T06:00:07Z" state: success url: https://prow.scylla-operator.scylladb.com/view/gs/scylla-operator-prow/logs/ci-scylla-operator-v1.15-e2e-gke-multi-datacenter-parallel/1906587290407276544