++ echo 'Log: /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/e2e-tests/logs/recover-no-primary.log' Log: /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/e2e-tests/logs/recover-no-primary.log ++ '[' -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/e2e-tests/conf/cloud-secret.yml ']' ++ SKIP_BACKUPS_TO_AWS_GCP_AZURE= ++ oc get projects ++ kubectl get nodes ++ grep '^minikube' +++ kubectl version -o json +++ jq -r .serverVersion.gitVersion +++ grep -eks- Warning: version difference between client (1.35) and server (1.32) exceeds the supported minor version skew of +/-1 ++ '[' ']' ++ EKS=0 +++ kubectl version -o json +++ jq -r .serverVersion.gitVersion +++ grep gke Warning: version difference between client (1.35) and server (1.32) exceeds the supported minor version skew of +/-1 ++ '[' v1.32.12-gke.1127000 ']' ++ GKE=1 +++ kubectl version -o json +++ jq -r '.serverVersion.major + "." + .serverVersion.minor' +++ /usr/sbin/sed -r 's/[^0-9.]+//g' Warning: version difference between client (1.35) and server (1.32) exceeds the supported minor version skew of +/-1 ++ KUBE_VERSION=1.32 + create_infra recover-no-primary-11707 + local ns=recover-no-primary-11707 + [[ 1 == 1 ]] + delete_crd + desc 'get and delete old CRDs and RBAC' + set +o xtrace ----------------------------------------------------------------------------------- get and delete old CRDs and RBAC ----------------------------------------------------------------------------------- + kubectl_bin delete -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/deploy/crd.yaml --ignore-not-found --wait=false ++ mktemp + local LAST_OUT=/tmp/tmp.Tzse3FdKPh ++ mktemp + local LAST_ERR=/tmp/tmp.vVI9tO29Uq + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl delete -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/deploy/crd.yaml --ignore-not-found --wait=false + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.Tzse3FdKPh customresourcedefinition.apiextensions.k8s.io "perconaservermongodbbackups.psmdb.percona.com" deleted customresourcedefinition.apiextensions.k8s.io "perconaservermongodbrestores.psmdb.percona.com" deleted customresourcedefinition.apiextensions.k8s.io "perconaservermongodbs.psmdb.percona.com" deleted + cat /tmp/tmp.vVI9tO29Uq + rm /tmp/tmp.Tzse3FdKPh /tmp/tmp.vVI9tO29Uq + return 0 ++ yq eval .metadata.name /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/deploy/crd.yaml ++ grep -v '\-\-\-' grep: warning: stray \ before - grep: warning: stray \ before - + for crd_name in $(yq eval '.metadata.name' "${src_dir}/deploy/crd.yaml" | grep -v '\-\-\-') + kubectl get perconaservermongodbbackups.psmdb.percona.com --all-namespaces -o wide + grep -v NAMESPACE + xargs -L 1 sh -xc 'kubectl patch perconaservermongodbbackups.psmdb.percona.com -n $0 $1 --type=merge -p "{\"metadata\":{\"finalizers\":[]}}"' error: the server doesn't have a resource type "perconaservermongodbbackups" + kubectl patch perconaservermongodbbackups.psmdb.percona.com -n sh --type=merge -p '{"metadata":{"finalizers":[]}}' error: the server doesn't have a resource type "perconaservermongodbbackups" + : + kubectl_bin wait --for=delete crd perconaservermongodbbackups.psmdb.percona.com ++ mktemp + local LAST_OUT=/tmp/tmp.F2yZAjlx4B ++ mktemp + local LAST_ERR=/tmp/tmp.kgrnCpT2Ri + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl wait --for=delete crd perconaservermongodbbackups.psmdb.percona.com + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.F2yZAjlx4B + cat /tmp/tmp.kgrnCpT2Ri + rm /tmp/tmp.F2yZAjlx4B /tmp/tmp.kgrnCpT2Ri + return 0 + for crd_name in $(yq eval '.metadata.name' "${src_dir}/deploy/crd.yaml" | grep -v '\-\-\-') + kubectl get perconaservermongodbrestores.psmdb.percona.com --all-namespaces -o wide + grep -v NAMESPACE + xargs -L 1 sh -xc 'kubectl patch perconaservermongodbrestores.psmdb.percona.com -n $0 $1 --type=merge -p "{\"metadata\":{\"finalizers\":[]}}"' error: the server doesn't have a resource type "perconaservermongodbrestores" + kubectl patch perconaservermongodbrestores.psmdb.percona.com -n sh --type=merge -p '{"metadata":{"finalizers":[]}}' error: the server doesn't have a resource type "perconaservermongodbrestores" + : + kubectl_bin wait --for=delete crd perconaservermongodbrestores.psmdb.percona.com ++ mktemp + local LAST_OUT=/tmp/tmp.eypLzhgJnI ++ mktemp + local LAST_ERR=/tmp/tmp.N3LJuQJZUX + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl wait --for=delete crd perconaservermongodbrestores.psmdb.percona.com + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.eypLzhgJnI + cat /tmp/tmp.N3LJuQJZUX + rm /tmp/tmp.eypLzhgJnI /tmp/tmp.N3LJuQJZUX + return 0 + for crd_name in $(yq eval '.metadata.name' "${src_dir}/deploy/crd.yaml" | grep -v '\-\-\-') + kubectl get perconaservermongodbs.psmdb.percona.com --all-namespaces -o wide + grep -v NAMESPACE + xargs -L 1 sh -xc 'kubectl patch perconaservermongodbs.psmdb.percona.com -n $0 $1 --type=merge -p "{\"metadata\":{\"finalizers\":[]}}"' No resources found + kubectl patch perconaservermongodbs.psmdb.percona.com -n sh --type=merge -p '{"metadata":{"finalizers":[]}}' error: resource(s) were provided, but no name was specified + : + kubectl_bin wait --for=delete crd perconaservermongodbs.psmdb.percona.com ++ mktemp + local LAST_OUT=/tmp/tmp.xNOQKdFWBL ++ mktemp + local LAST_ERR=/tmp/tmp.q1eTPajngP + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl wait --for=delete crd perconaservermongodbs.psmdb.percona.com + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.xNOQKdFWBL + cat /tmp/tmp.q1eTPajngP + rm /tmp/tmp.xNOQKdFWBL /tmp/tmp.q1eTPajngP + return 0 + local rbac_yaml=rbac.yaml + '[' -n psmdb-operator ']' + rbac_yaml=cw-rbac.yaml + kubectl_bin delete -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/deploy/cw-rbac.yaml --ignore-not-found ++ mktemp + local LAST_OUT=/tmp/tmp.jfqu9vShbD ++ mktemp + local LAST_ERR=/tmp/tmp.zOsdFHk1qF + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl delete -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/deploy/cw-rbac.yaml --ignore-not-found + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.jfqu9vShbD clusterrole.rbac.authorization.k8s.io "percona-server-mongodb-operator" deleted clusterrolebinding.rbac.authorization.k8s.io "service-account-percona-server-mongodb-operator" deleted + cat /tmp/tmp.zOsdFHk1qF + rm /tmp/tmp.jfqu9vShbD /tmp/tmp.zOsdFHk1qF + return 0 + check_crd_for_deletion PR-2277-0a1aa642f + local git_tag=PR-2277-0a1aa642f ++ curl -s https://raw.githubusercontent.com/percona/percona-server-mongodb-operator/PR-2277-0a1aa642f/deploy/crd.yaml ++ yq eval .metadata.name ++ /usr/sbin/sed ':a;N;$!ba;s/\n/ /g' ++ /usr/sbin/sed s/---//g + for crd_name in $(curl -s https://raw.githubusercontent.com/percona/percona-server-mongodb-operator/${git_tag}/deploy/crd.yaml | yq eval '.metadata.name' | $sed 's/---//g' | $sed ':a;N;$!ba;s/\n/ /g') ++ kubectl_bin get crd/null -o 'jsonpath={.status.conditions[-1].type}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.eMj5rqqbUa +++ mktemp ++ local LAST_ERR=/tmp/tmp.DmvzmXTpG0 ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get crd/null -o 'jsonpath={.status.conditions[-1].type}' ++ exit_status=1 ++ set -e ++ '[' 1 '!=' 0 -a -n 1 ']' ++ cat /tmp/tmp.eMj5rqqbUa ++ cat /tmp/tmp.DmvzmXTpG0 Error from server (NotFound): customresourcedefinitions.apiextensions.k8s.io "null" not found ++ sleep 0 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get crd/null -o 'jsonpath={.status.conditions[-1].type}' ++ exit_status=1 ++ set -e ++ '[' 1 '!=' 0 -a -n 1 ']' ++ cat /tmp/tmp.eMj5rqqbUa ++ cat /tmp/tmp.DmvzmXTpG0 Error from server (NotFound): customresourcedefinitions.apiextensions.k8s.io "null" not found ++ sleep 4 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get crd/null -o 'jsonpath={.status.conditions[-1].type}' ++ exit_status=1 ++ set -e ++ '[' 1 '!=' 0 -a -n 1 ']' ++ cat /tmp/tmp.eMj5rqqbUa ++ cat /tmp/tmp.DmvzmXTpG0 Error from server (NotFound): customresourcedefinitions.apiextensions.k8s.io "null" not found ++ sleep 8 ++ cat /tmp/tmp.eMj5rqqbUa ++ cat /tmp/tmp.DmvzmXTpG0 Error from server (NotFound): customresourcedefinitions.apiextensions.k8s.io "null" not found ++ rm /tmp/tmp.eMj5rqqbUa /tmp/tmp.DmvzmXTpG0 ++ return 1 + [[ '' == \T\e\r\m\i\n\a\t\i\n\g ]] + '[' -n psmdb-operator ']' + create_namespace psmdb-operator + local namespace=psmdb-operator + local skip_clean_namespace= + [[ 1 == 1 ]] + [[ -z '' ]] + destroy_chaos_mesh ++ helm list --all-namespaces --filter chaos-mesh ++ tail -n1 ++ awk '-F ' '{print $2}' ++ sed s/NAMESPACE// + local chaos_mesh_ns= + desc 'destroy chaos-mesh' + set +o xtrace ----------------------------------------------------------------------------------- destroy chaos-mesh ----------------------------------------------------------------------------------- + '[' -n '' ']' ++ kubectl get MutatingWebhookConfiguration ++ grep chaos-mesh ++ awk '{print $1}' + timeout 30 kubectl delete MutatingWebhookConfiguration error: resource(s) were provided, but no name was specified + : ++ kubectl get ValidatingWebhookConfiguration ++ grep chaos-mesh ++ awk '{print $1}' + timeout 30 kubectl delete ValidatingWebhookConfiguration error: resource(s) were provided, but no name was specified + : ++ kubectl get ValidatingWebhookConfiguration ++ grep validate-auth ++ awk '{print $1}' + timeout 30 kubectl delete ValidatingWebhookConfiguration error: resource(s) were provided, but no name was specified + : ++ kubectl api-resources ++ grep chaos-mesh ++ awk '{print $1}' ++ kubectl get crd ++ grep chaos-mesh.org ++ awk '{print $1}' + timeout 30 kubectl delete crd error: resource(s) were provided, but no name was specified + : ++ kubectl get clusterrolebinding ++ grep chaos-mesh ++ awk '{print $1}' + timeout 30 kubectl delete clusterrolebinding error: resource(s) were provided, but no name was specified + : ++ kubectl get clusterrole ++ grep chaos-mesh ++ awk '{print $1}' + timeout 30 kubectl delete clusterrole error: resource(s) were provided, but no name was specified + : + desc 'cleaned up all old namespaces' + set +o xtrace ----------------------------------------------------------------------------------- cleaned up all old namespaces ----------------------------------------------------------------------------------- + kubectl_bin get ns + grep -E -v '^kube-|^default|Terminating|psmdb-operator|openshift|^gke-|^gmp-|^NAME' + '[' -n '' ']' + desc 'cleaned up old namespaces psmdb-operator' + xargs kubectl delete ns + set +o xtrace + awk '{print$1}' ----------------------------------------------------------------------------------- cleaned up old namespaces psmdb-operator ----------------------------------------------------------------------------------- + kubectl_bin delete namespace psmdb-operator --ignore-not-found ++ mktemp ++ mktemp + local LAST_OUT=/tmp/tmp.sIAnhU0RKp ++ mktemp + local LAST_OUT=/tmp/tmp.Zqopd1mYib ++ mktemp + local LAST_ERR=/tmp/tmp.FRz0gMtTQU + local exit_status=0 + local LAST_ERR=/tmp/tmp.2HVfUFUvKl + local timeout=4 + local exit_status=0 + local timeout=4 ++ seq 0 2 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl get ns + for i in $(seq 0 2) + set +e + kubectl delete namespace psmdb-operator --ignore-not-found + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.sIAnhU0RKp + cat /tmp/tmp.2HVfUFUvKl + rm /tmp/tmp.sIAnhU0RKp /tmp/tmp.2HVfUFUvKl + return 0 namespace "recover-no-primary-31278" deleted + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.Zqopd1mYib namespace "psmdb-operator" deleted + cat /tmp/tmp.FRz0gMtTQU + rm /tmp/tmp.Zqopd1mYib /tmp/tmp.FRz0gMtTQU + return 0 + kubectl_bin wait --for=delete namespace psmdb-operator ++ mktemp + local LAST_OUT=/tmp/tmp.QjqQBP8vwB ++ mktemp + local LAST_ERR=/tmp/tmp.HBIXBZkvrE + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl wait --for=delete namespace psmdb-operator + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.QjqQBP8vwB + cat /tmp/tmp.HBIXBZkvrE + rm /tmp/tmp.QjqQBP8vwB /tmp/tmp.HBIXBZkvrE + return 0 + desc 'create namespace psmdb-operator' + set +o xtrace ----------------------------------------------------------------------------------- create namespace psmdb-operator ----------------------------------------------------------------------------------- + kubectl_bin create namespace psmdb-operator ++ mktemp + local LAST_OUT=/tmp/tmp.B7HStXnolI ++ mktemp + local LAST_ERR=/tmp/tmp.S0552FvA78 + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl create namespace psmdb-operator + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.B7HStXnolI namespace/psmdb-operator created + cat /tmp/tmp.S0552FvA78 + rm /tmp/tmp.B7HStXnolI /tmp/tmp.S0552FvA78 + return 0 + set_kube_ctx psmdb-operator + local namespace=psmdb-operator ++ kubectl_bin config current-context +++ mktemp ++ local LAST_OUT=/tmp/tmp.UxZgfR4I3T +++ mktemp ++ local LAST_ERR=/tmp/tmp.5LLxJqd29W ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl config current-context ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.UxZgfR4I3T ++ cat /tmp/tmp.5LLxJqd29W ++ rm /tmp/tmp.UxZgfR4I3T /tmp/tmp.5LLxJqd29W ++ return 0 + kubectl_bin config set-context gke_cloud-dev-112233_us-central1-a_jen-psmdb-2277-0a1aa642f-2-cluster9 --namespace=psmdb-operator ++ mktemp + local LAST_OUT=/tmp/tmp.mHZHjJHMyp ++ mktemp + local LAST_ERR=/tmp/tmp.2J2GuzpylM + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl config set-context gke_cloud-dev-112233_us-central1-a_jen-psmdb-2277-0a1aa642f-2-cluster9 --namespace=psmdb-operator + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.mHZHjJHMyp Context "gke_cloud-dev-112233_us-central1-a_jen-psmdb-2277-0a1aa642f-2-cluster9" modified. + cat /tmp/tmp.2J2GuzpylM + rm /tmp/tmp.mHZHjJHMyp /tmp/tmp.2J2GuzpylM + return 0 + deploy_operator + desc 'start PSMDB operator: docker.io/perconalab/percona-server-mongodb-operator:PR-2277-0a1aa642f' + set +o xtrace ----------------------------------------------------------------------------------- start PSMDB operator: docker.io/perconalab/percona-server-mongodb-operator:PR-2277-0a1aa642f ----------------------------------------------------------------------------------- + local cr_file + '[' -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/e2e-tests/recover-no-primary/conf/crd.yaml ']' + cr_file=/mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/deploy/crd.yaml + kubectl_bin apply --server-side --force-conflicts -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/deploy/crd.yaml ++ mktemp + local LAST_OUT=/tmp/tmp.T74SuLCp2Z ++ mktemp + local LAST_ERR=/tmp/tmp.a85FxGU1pY + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl apply --server-side --force-conflicts -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/deploy/crd.yaml + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.T74SuLCp2Z customresourcedefinition.apiextensions.k8s.io/perconaservermongodbbackups.psmdb.percona.com serverside-applied customresourcedefinition.apiextensions.k8s.io/perconaservermongodbrestores.psmdb.percona.com serverside-applied customresourcedefinition.apiextensions.k8s.io/perconaservermongodbs.psmdb.percona.com serverside-applied + cat /tmp/tmp.a85FxGU1pY + rm /tmp/tmp.T74SuLCp2Z /tmp/tmp.a85FxGU1pY + return 0 + '[' -n psmdb-operator ']' + apply_rbac cw-rbac + local operator_namespace=psmdb-operator + local rbac=cw-rbac + cat /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/deploy/cw-rbac.yaml + sed -e 's^namespace: .*^namespace: psmdb-operator^' + kubectl_bin apply -n psmdb-operator -f - ++ mktemp + local LAST_OUT=/tmp/tmp.0I2uGyV7yY ++ mktemp + local LAST_ERR=/tmp/tmp.w002tGN62U + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl apply -n psmdb-operator -f - + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.0I2uGyV7yY clusterrole.rbac.authorization.k8s.io/percona-server-mongodb-operator created serviceaccount/percona-server-mongodb-operator created clusterrolebinding.rbac.authorization.k8s.io/service-account-percona-server-mongodb-operator created + cat /tmp/tmp.w002tGN62U + rm /tmp/tmp.0I2uGyV7yY /tmp/tmp.w002tGN62U + return 0 + yq eval ' (.spec.template.spec.containers[].image = "docker.io/perconalab/percona-server-mongodb-operator:PR-2277-0a1aa642f") | ((.. | select(.[] == "DISABLE_TELEMETRY")) |= .value="true") | ((.. | select(.[] == "LOG_LEVEL")) |= .value="DEBUG")' /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/deploy/cw-operator.yaml + kubectl_bin apply -n psmdb-operator -f - ++ mktemp + local LAST_OUT=/tmp/tmp.f2dXrJLYRU ++ mktemp + local LAST_ERR=/tmp/tmp.4yXkzf6Itd + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl apply -n psmdb-operator -f - + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.f2dXrJLYRU deployment.apps/percona-server-mongodb-operator created + cat /tmp/tmp.4yXkzf6Itd + rm /tmp/tmp.f2dXrJLYRU /tmp/tmp.4yXkzf6Itd + return 0 + sleep 20 ++ get_operator_pod ++ kubectl_bin get pods --selector=name=percona-server-mongodb-operator -o 'jsonpath={.items[].metadata.name}' -n psmdb-operator +++ mktemp ++ local LAST_OUT=/tmp/tmp.IALl3BY31x +++ mktemp ++ local LAST_ERR=/tmp/tmp.P84E43GjWK ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods --selector=name=percona-server-mongodb-operator -o 'jsonpath={.items[].metadata.name}' -n psmdb-operator ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.IALl3BY31x ++ cat /tmp/tmp.P84E43GjWK ++ rm /tmp/tmp.IALl3BY31x /tmp/tmp.P84E43GjWK ++ return 0 + wait_operator_pod percona-server-mongodb-operator-5b5f6fcd94-h78wh + local pod=percona-server-mongodb-operator-5b5f6fcd94-h78wh + set +o xtrace waiting for pod/percona-server-mongodb-operator-5b5f6fcd94-h78wh to be ready.OK + echo 'Print operator info from log' Print operator info from log + grep 'Manager starting up' ++ get_operator_pod ++ kubectl_bin get pods --selector=name=percona-server-mongodb-operator -o 'jsonpath={.items[].metadata.name}' -n psmdb-operator +++ mktemp ++ local LAST_OUT=/tmp/tmp.9zBNwrFlw7 +++ mktemp ++ local LAST_ERR=/tmp/tmp.sFN41Gxerf ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods --selector=name=percona-server-mongodb-operator -o 'jsonpath={.items[].metadata.name}' -n psmdb-operator ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.9zBNwrFlw7 ++ cat /tmp/tmp.sFN41Gxerf ++ rm /tmp/tmp.9zBNwrFlw7 /tmp/tmp.sFN41Gxerf ++ return 0 + kubectl_bin logs -n psmdb-operator percona-server-mongodb-operator-5b5f6fcd94-h78wh ++ mktemp + local LAST_OUT=/tmp/tmp.fBtdQ4Lo6d ++ mktemp + local LAST_ERR=/tmp/tmp.Itqh4jIyaF + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl logs -n psmdb-operator percona-server-mongodb-operator-5b5f6fcd94-h78wh + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.fBtdQ4Lo6d + cat /tmp/tmp.Itqh4jIyaF + rm /tmp/tmp.fBtdQ4Lo6d /tmp/tmp.Itqh4jIyaF + return 0 2026-03-09T11:33:53.258Z INFO setup Manager starting up {"gitCommit": "0a1aa642fab677b3a3eb9b1dee5f81fc42e34249", "gitBranch": "PR-2277-0a1aa642f", "buildTime": "", "goVersion": "go1.25.8", "os": "linux", "arch": "amd64"} + create_namespace recover-no-primary-11707 + local namespace=recover-no-primary-11707 + local skip_clean_namespace= + [[ 1 == 1 ]] + [[ -z '' ]] + destroy_chaos_mesh ++ helm list --all-namespaces --filter chaos-mesh ++ tail -n1 ++ awk '-F ' '{print $2}' ++ sed s/NAMESPACE// + local chaos_mesh_ns= + desc 'destroy chaos-mesh' + set +o xtrace ----------------------------------------------------------------------------------- destroy chaos-mesh ----------------------------------------------------------------------------------- + '[' -n '' ']' ++ kubectl get MutatingWebhookConfiguration ++ awk '{print $1}' ++ grep chaos-mesh + timeout 30 kubectl delete MutatingWebhookConfiguration error: resource(s) were provided, but no name was specified + : ++ kubectl get ValidatingWebhookConfiguration ++ grep chaos-mesh ++ awk '{print $1}' + timeout 30 kubectl delete ValidatingWebhookConfiguration error: resource(s) were provided, but no name was specified + : ++ kubectl get ValidatingWebhookConfiguration ++ grep validate-auth ++ awk '{print $1}' + timeout 30 kubectl delete ValidatingWebhookConfiguration error: resource(s) were provided, but no name was specified + : ++ kubectl api-resources ++ grep chaos-mesh ++ awk '{print $1}' ++ kubectl get crd ++ grep chaos-mesh.org ++ awk '{print $1}' + timeout 30 kubectl delete crd error: resource(s) were provided, but no name was specified + : ++ kubectl get clusterrolebinding ++ grep chaos-mesh ++ awk '{print $1}' + timeout 30 kubectl delete clusterrolebinding error: resource(s) were provided, but no name was specified + : ++ kubectl get clusterrole ++ grep chaos-mesh ++ awk '{print $1}' + timeout 30 kubectl delete clusterrole error: resource(s) were provided, but no name was specified + : + desc 'cleaned up all old namespaces' + set +o xtrace ----------------------------------------------------------------------------------- cleaned up all old namespaces ----------------------------------------------------------------------------------- + kubectl_bin get ns + grep -E -v '^kube-|^default|Terminating|psmdb-operator|openshift|^gke-|^gmp-|^NAME' + awk '{print$1}' + '[' -n '' ']' + xargs kubectl delete ns + desc 'cleaned up old namespaces recover-no-primary-11707' + set +o xtrace ----------------------------------------------------------------------------------- cleaned up old namespaces recover-no-primary-11707 ----------------------------------------------------------------------------------- + kubectl_bin delete namespace recover-no-primary-11707 --ignore-not-found ++ mktemp ++ mktemp + local LAST_OUT=/tmp/tmp.JCdks71a29 + local LAST_OUT=/tmp/tmp.5GhgRtldkf ++ mktemp ++ mktemp + local LAST_ERR=/tmp/tmp.ifBFhItLk7 + local exit_status=0 + local timeout=4 + local LAST_ERR=/tmp/tmp.q0Vf1Lv2RY + local exit_status=0 + local timeout=4 ++ seq 0 2 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl get ns + for i in $(seq 0 2) + set +e + kubectl delete namespace recover-no-primary-11707 --ignore-not-found + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.JCdks71a29 + cat /tmp/tmp.ifBFhItLk7 + rm /tmp/tmp.JCdks71a29 /tmp/tmp.ifBFhItLk7 + return 0 + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.5GhgRtldkf + cat /tmp/tmp.q0Vf1Lv2RY + rm /tmp/tmp.5GhgRtldkf /tmp/tmp.q0Vf1Lv2RY error: resource(s) were provided, but no name was specified + return 0 + kubectl_bin wait --for=delete namespace recover-no-primary-11707 ++ mktemp + local LAST_OUT=/tmp/tmp.IksRrbd6vG ++ mktemp + local LAST_ERR=/tmp/tmp.oNU7HVZlPq + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl wait --for=delete namespace recover-no-primary-11707 + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.IksRrbd6vG + cat /tmp/tmp.oNU7HVZlPq + rm /tmp/tmp.IksRrbd6vG /tmp/tmp.oNU7HVZlPq + return 0 + desc 'create namespace recover-no-primary-11707' + set +o xtrace ----------------------------------------------------------------------------------- create namespace recover-no-primary-11707 ----------------------------------------------------------------------------------- + kubectl_bin create namespace recover-no-primary-11707 ++ mktemp + local LAST_OUT=/tmp/tmp.DTWqNTJBtu ++ mktemp + local LAST_ERR=/tmp/tmp.RQLtetleWd + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl create namespace recover-no-primary-11707 + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.DTWqNTJBtu namespace/recover-no-primary-11707 created + cat /tmp/tmp.RQLtetleWd + rm /tmp/tmp.DTWqNTJBtu /tmp/tmp.RQLtetleWd + return 0 + set_kube_ctx recover-no-primary-11707 + local namespace=recover-no-primary-11707 ++ kubectl_bin config current-context +++ mktemp ++ local LAST_OUT=/tmp/tmp.QGBGZGtbmF +++ mktemp ++ local LAST_ERR=/tmp/tmp.VoRTUmmAZw ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl config current-context ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.QGBGZGtbmF ++ cat /tmp/tmp.VoRTUmmAZw ++ rm /tmp/tmp.QGBGZGtbmF /tmp/tmp.VoRTUmmAZw ++ return 0 + kubectl_bin config set-context gke_cloud-dev-112233_us-central1-a_jen-psmdb-2277-0a1aa642f-2-cluster9 --namespace=recover-no-primary-11707 ++ mktemp + local LAST_OUT=/tmp/tmp.y5HyEJb7jQ ++ mktemp + local LAST_ERR=/tmp/tmp.hBTJvMrMzW + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl config set-context gke_cloud-dev-112233_us-central1-a_jen-psmdb-2277-0a1aa642f-2-cluster9 --namespace=recover-no-primary-11707 + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.y5HyEJb7jQ Context "gke_cloud-dev-112233_us-central1-a_jen-psmdb-2277-0a1aa642f-2-cluster9" modified. + cat /tmp/tmp.hBTJvMrMzW + rm /tmp/tmp.y5HyEJb7jQ /tmp/tmp.hBTJvMrMzW + return 0 + cluster=some-name + kubectl_bin apply -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/e2e-tests/conf/secrets_with_tls.yml -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/e2e-tests/conf/client.yml ++ mktemp + local LAST_OUT=/tmp/tmp.rhdlO86xZP ++ mktemp + local LAST_ERR=/tmp/tmp.F2aswbt8WO + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl apply -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/e2e-tests/conf/secrets_with_tls.yml -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/e2e-tests/conf/client.yml + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.rhdlO86xZP secret/some-users created secret/some-name-ssl created secret/some-name-ssl-internal created deployment.apps/psmdb-client created + cat /tmp/tmp.F2aswbt8WO + rm /tmp/tmp.rhdlO86xZP /tmp/tmp.F2aswbt8WO + return 0 + desc 'testing unexposed single replset cluster' + set +o xtrace ----------------------------------------------------------------------------------- testing unexposed single replset cluster ----------------------------------------------------------------------------------- + test_single_replset + apply_cluster /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/e2e-tests/recover-no-primary/conf/some-name.yml + '[' -z '' ']' + cat_config /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/e2e-tests/recover-no-primary/conf/some-name.yml + kubectl_bin apply -f - + cat /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2277/e2e-tests/recover-no-primary/conf/some-name.yml + yq eval '(.spec | select(.image == null)).image = "docker.io/perconalab/percona-server-mongodb-operator:main-mongod8.0"' ++ mktemp + yq eval '(.spec | select(has("pmm"))).pmm.image = "docker.io/percona/pmm-client:2.44.1-1"' + yq eval '(.spec | select(has("initImage"))).initImage = "docker.io/perconalab/percona-server-mongodb-operator:PR-2277-0a1aa642f"' + yq eval '(.spec | select(has("backup"))).backup.image = "docker.io/perconalab/percona-server-mongodb-operator:main-backup"' + local LAST_OUT=/tmp/tmp.c8mcHonjfB + /usr/sbin/sed -e s/NAME_SPACE/recover-no-primary-11707/g + yq eval '.spec.upgradeOptions.apply="Never"' ++ mktemp + local LAST_ERR=/tmp/tmp.R7iBInepQx + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl apply -f - + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.c8mcHonjfB perconaservermongodb.psmdb.percona.com/some-name created + cat /tmp/tmp.R7iBInepQx + rm /tmp/tmp.c8mcHonjfB /tmp/tmp.R7iBInepQx + return 0 + wait_for_running some-name-rs0 3 + local name=some-name-rs0 + let last_pod=2 + local check_cluster_readyness=true + set_debug + [[ 1 == 1 ]] + set -o xtrace + local rs_name=rs0 + local cluster_name=some-name ++ seq 0 2 + for i in $(seq 0 $last_pod) + [[ 0 -eq 2 ]] + wait_pod some-name-rs0-0 + local pod=some-name-rs0-0 + set +o xtrace waiting for pod/some-name-rs0-0 to be ready........................................................................................................................................................................................................................................................................................................................................................................Name: some-name-rs0-0 Namespace: recover-no-primary-11707 Priority: 0 Service Account: default Node: gke-jen-psmdb-2277-0a1aa-default-pool-46f243bf-s16n/10.216.0.60 Start Time: Mon, 09 Mar 2026 11:34:36 +0000 Labels: app.kubernetes.io/component=mongod app.kubernetes.io/instance=some-name app.kubernetes.io/managed-by=percona-server-mongodb-operator app.kubernetes.io/name=percona-server-mongodb app.kubernetes.io/part-of=percona-server-mongodb app.kubernetes.io/replset=rs0 apps.kubernetes.io/pod-index=0 controller-revision-hash=some-name-rs0-5f54786d4c statefulset.kubernetes.io/pod-name=some-name-rs0-0 Annotations: percona.com/ssl-hash: 932a5c8e34b56a6575a4fe633e075820 percona.com/ssl-internal-hash: 244a8895a30c533cd36c1a9e0a927b13 Status: Pending IP: IPs: Controlled By: StatefulSet/some-name-rs0 Init Containers: mongo-init: Container ID: Image: docker.io/perconalab/percona-server-mongodb-operator:PR-2277-0a1aa642f Image ID: Port: Host Port: Command: /init-entrypoint.sh State: Waiting Reason: PodInitializing Ready: False Restart Count: 0 Limits: cpu: 500m memory: 500M Requests: cpu: 100m memory: 100M Environment: Mounts: /data/db from mongod-data (rw) /opt/percona from bin (rw) /var/run/secrets/kubernetes.io/serviceaccount from kube-api-access-jgr55 (ro) Containers: mongod: Container ID: Image: docker.io/perconalab/percona-server-mongodb-operator:main-mongod8.0 Image ID: Port: 27017/TCP (mongodb) Host Port: 0/TCP (mongodb) Command: /opt/percona/ps-entry.sh Args: --bind_ip_all --auth --dbpath=/data/db --port=27017 --replSet=rs0 --storageEngine=wiredTiger --relaxPermChecks --sslAllowInvalidCertificates --clusterAuthMode=x509 --tlsMode=preferTLS --enableEncryption --encryptionKeyFile=/etc/mongodb-encryption/encryption-key --wiredTigerCacheSizeGB=0.25 --wiredTigerIndexPrefixCompression=true --quiet State: Waiting Reason: PodInitializing Ready: False Restart Count: 0 Limits: cpu: 500m memory: 500M Requests: cpu: 100m memory: 100M Liveness: exec [/opt/percona/mongodb-healthcheck k8s liveness --ssl --sslInsecure --sslCAFile /etc/mongodb-ssl/ca.crt --sslPEMKeyFile /tmp/tls.pem --startupDelaySeconds 7200] delay=60s timeout=10s period=30s #success=1 #failure=4 Readiness: exec [/opt/percona/mongodb-healthcheck k8s readiness --component mongod --ssl --sslInsecure --sslCAFile /etc/mongodb-ssl/ca.crt --sslPEMKeyFile /tmp/tls.pem] delay=10s timeout=2s period=3s #success=1 #failure=8 Environment Variables from: internal-some-name-users Secret Optional: false Environment: SERVICE_NAME: some-name NAMESPACE: recover-no-primary-11707 MONGODB_PORT: 27017 MONGODB_REPLSET: rs0 Mounts: /.mongodb from mongosh (rw) /data/db from mongod-data (rw) /etc/mongodb-encryption from some-name-mongodb-encryption-key (ro) /etc/mongodb-secrets from some-name-mongodb-keyfile (ro) /etc/mongodb-ssl from ssl (ro) /etc/mongodb-ssl-internal from ssl-internal (ro) /etc/users-secret from users-secret-file (rw) /opt/percona from bin (rw) /var/run/secrets/kubernetes.io/serviceaccount from kube-api-access-jgr55 (ro) Conditions: Type Status PodReadyToStartContainers False Initialized False Ready False ContainersReady False PodScheduled True Volumes: mongod-data: Type: PersistentVolumeClaim (a reference to a PersistentVolumeClaim in the same namespace) ClaimName: mongod-data-some-name-rs0-0 ReadOnly: false some-name-mongodb-keyfile: Type: Secret (a volume populated by a Secret) SecretName: some-name-mongodb-keyfile Optional: false bin: Type: EmptyDir (a temporary directory that shares a pod's lifetime) Medium: SizeLimit: mongosh: Type: EmptyDir (a temporary directory that shares a pod's lifetime) Medium: SizeLimit: some-name-mongodb-encryption-key: Type: Secret (a volume populated by a Secret) SecretName: some-name-mongodb-encryption-key Optional: false ssl: Type: Secret (a volume populated by a Secret) SecretName: some-name-ssl Optional: false ssl-internal: Type: Secret (a volume populated by a Secret) SecretName: some-name-ssl-internal Optional: true users-secret-file: Type: Secret (a volume populated by a Secret) SecretName: internal-some-name-users Optional: false kube-api-access-jgr55: Type: Projected (a volume that contains injected data from multiple sources) TokenExpirationSeconds: 3607 ConfigMapName: kube-root-ca.crt Optional: false DownwardAPI: true QoS Class: Burstable Node-Selectors: Tolerations: node.kubernetes.io/not-ready:NoExecute op=Exists for 300s node.kubernetes.io/unreachable:NoExecute op=Exists for 300s Events: Type Reason Age From Message ---- ------ ---- ---- ------- Normal Scheduled 12m default-scheduler Successfully assigned recover-no-primary-11707/some-name-rs0-0 to gke-jen-psmdb-2277-0a1aa-default-pool-46f243bf-s16n Normal SuccessfulAttachVolume 12m attachdetach-controller AttachVolume.Attach succeeded for volume "pvc-aafd9ad2-49f9-4d32-b136-df0d98d5d564" Warning FailedMount 119s (x13 over 12m) kubelet MountVolume.SetUp failed for volume "kube-api-access-jgr55" : configmap "kube-root-ca.crt" not found Defaulted container "mongod" out of: mongod, mongo-init (init) Error from server (BadRequest): container "mongod" in pod "some-name-rs0-0" is waiting to start: PodInitializing Defaulted container "mongod" out of: mongod, mongo-init (init) Error from server (BadRequest): container "mongod" in pod "some-name-rs0-0" is waiting to start: PodInitializing Defaulted container "mongod" out of: mongod, mongo-init (init) Error from server (BadRequest): container "mongod" in pod "some-name-rs0-0" is waiting to start: PodInitializing Defaulted container "mongod" out of: mongod, mongo-init (init) Error from server (BadRequest): container "mongod" in pod "some-name-rs0-0" is waiting to start: PodInitializing