Log: /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/logs/upgrade.log Warning: version difference between client (1.36) and server (1.33) exceeds the supported minor version skew of +/-1 Warning: version difference between client (1.36) and server (1.33) exceeds the supported minor version skew of +/-1 Warning: version difference between client (1.36) and server (1.33) exceeds the supported minor version skew of +/-1 + cluster=upgrade + CLUSTER_SIZE=3 + TARGET_OPERATOR_VER=1.23.0 + TARGET_IMAGE=docker.io/perconalab/percona-server-mongodb-operator:PR-2058-fb8cc7187 + TARGET_IMAGE_MONGOD=docker.io/perconalab/percona-server-mongodb-operator:main-mongod8.0 + TARGET_IMAGE_PMM_CLIENT=docker.io/percona/pmm-client:2.44.1-1 + TARGET_IMAGE_BACKUP=docker.io/perconalab/percona-server-mongodb-operator:main-backup ++ get_mongod_ver_from_image docker.io/perconalab/percona-server-mongodb-operator:main-mongod8.0 ++ local image=docker.io/perconalab/percona-server-mongodb-operator:main-mongod8.0 +++ run_simple_cli_inside_image docker.io/perconalab/percona-server-mongodb-operator:main-mongod8.0 'mongod --version' +++ local image=docker.io/perconalab/percona-server-mongodb-operator:main-mongod8.0 +++ local 'cli=mongod --version' +++ local pod_name=746 +++ kubectl_bin -n default run 746 --image=docker.io/perconalab/percona-server-mongodb-operator:main-mongod8.0 --restart=Never --command -- sleep infinity +++ /usr/sbin/sed -r 's/^.*db version v(([0-9]+\.){2}[0-9]+-[0-9]+).*$/\1/g' ++++ mktemp +++ local LAST_OUT=/tmp/tmp.FBv4HUSkNU ++++ mktemp +++ local LAST_ERR=/tmp/tmp.YHDueZdhGT +++ local exit_status=0 +++ local timeout=4 ++++ seq 0 2 +++ for i in $(seq 0 2) +++ set +e +++ kubectl -n default run 746 --image=docker.io/perconalab/percona-server-mongodb-operator:main-mongod8.0 --restart=Never --command -- sleep infinity +++ exit_status=0 +++ set -e +++ '[' 0 '!=' 0 -a -n 1 ']' +++ break +++ cat /tmp/tmp.FBv4HUSkNU +++ cat /tmp/tmp.YHDueZdhGT +++ rm /tmp/tmp.FBv4HUSkNU /tmp/tmp.YHDueZdhGT +++ return 0 +++ kubectl_bin -n default wait --for=condition=Ready pod/746 ++++ mktemp +++ local LAST_OUT=/tmp/tmp.Vv9lYcuEzs ++++ mktemp +++ local LAST_ERR=/tmp/tmp.5kGXOl5xmY +++ local exit_status=0 +++ local timeout=4 ++++ seq 0 2 +++ for i in $(seq 0 2) +++ set +e +++ kubectl -n default wait --for=condition=Ready pod/746 +++ exit_status=0 +++ set -e +++ '[' 0 '!=' 0 -a -n 1 ']' +++ break +++ cat /tmp/tmp.Vv9lYcuEzs +++ cat /tmp/tmp.5kGXOl5xmY +++ rm /tmp/tmp.Vv9lYcuEzs /tmp/tmp.5kGXOl5xmY +++ return 0 ++++ kubectl_bin -n default exec 746 -- bash -c 'mongod --version 2>&1' +++++ mktemp ++++ local LAST_OUT=/tmp/tmp.nja78QmsAh +++++ mktemp ++++ local LAST_ERR=/tmp/tmp.uPXqdt55Et ++++ local exit_status=0 ++++ local timeout=4 +++++ seq 0 2 ++++ for i in $(seq 0 2) ++++ set +e ++++ kubectl -n default exec 746 -- bash -c 'mongod --version 2>&1' ++++ exit_status=0 ++++ set -e ++++ '[' 0 '!=' 0 -a -n 1 ']' ++++ break ++++ cat /tmp/tmp.nja78QmsAh ++++ cat /tmp/tmp.uPXqdt55Et ++++ rm /tmp/tmp.nja78QmsAh /tmp/tmp.uPXqdt55Et ++++ return 0 +++ local $'output=db version v8.0.23-10\nBuild Info: {\n "version": "8.0.23-10",\n "gitVersion": "10286e6c2a0ccd5d65c0b324c6fe29e5412db449",\n "openSSLVersion": "OpenSSL 3.5.5 27 Jan 2026",\n "modules": [],\n "perconaFeatures": [\n "MemoryEngine",\n "HotBackup",\n "BackupCursorAggregationStage",\n "BackupCursorExtendAggregationStage",\n "AWSIAM",\n "Kerberos",\n "LDAP",\n "OIDC",\n "TDE",\n "FIPSMode",\n "FCBIS",\n "Auditing",\n "ProfilingRateLimit",\n "LogRedaction",\n "ngram"\n ],\n "allocator": "tcmalloc-google",\n "environment": {\n "distarch": "x86_64",\n "target_arch": "x86_64"\n }\n}' +++ kubectl_bin -n default delete pod/746 --grace-period=0 --force ++++ mktemp +++ local LAST_OUT=/tmp/tmp.PNKlpxTZ9p ++++ mktemp +++ local LAST_ERR=/tmp/tmp.k8MidxdPic +++ local exit_status=0 +++ local timeout=4 ++++ seq 0 2 +++ for i in $(seq 0 2) +++ set +e +++ kubectl -n default delete pod/746 --grace-period=0 --force +++ exit_status=0 +++ set -e +++ '[' 0 '!=' 0 -a -n 1 ']' +++ break +++ cat /tmp/tmp.PNKlpxTZ9p +++ cat /tmp/tmp.k8MidxdPic Warning: Immediate deletion does not wait for confirmation that the running resource has been terminated. The resource may continue to run on the cluster indefinitely. +++ rm /tmp/tmp.PNKlpxTZ9p /tmp/tmp.k8MidxdPic +++ return 0 +++ echo db version v8.0.23-10 Build Info: '{' '"version":' '"8.0.23-10",' '"gitVersion":' '"10286e6c2a0ccd5d65c0b324c6fe29e5412db449",' '"openSSLVersion":' '"OpenSSL' 3.5.5 27 Jan '2026",' '"modules":' '[],' '"perconaFeatures":' '[' '"MemoryEngine",' '"HotBackup",' '"BackupCursorAggregationStage",' '"BackupCursorExtendAggregationStage",' '"AWSIAM",' '"Kerberos",' '"LDAP",' '"OIDC",' '"TDE",' '"FIPSMode",' '"FCBIS",' '"Auditing",' '"ProfilingRateLimit",' '"LogRedaction",' '"ngram"' '],' '"allocator":' '"tcmalloc-google",' '"environment":' '{' '"distarch":' '"x86_64",' '"target_arch":' '"x86_64"' '}' '}' ++ version_info=8.0.23-10 ++ [[ ! 8.0.23-10 =~ ^([0-9]+\.){2}[0-9]+-[0-9]+$ ]] ++ echo 8.0.23-10 + FULL_VER=8.0.23-10 + MONGO_VER=8.0 ++ curl -s https://check.percona.com/versions/v1/psmdb-operator ++ jq -r '.versions[].operator' ++ sort -V ++ tail -n1 + INIT_OPERATOR_VER=1.22.0 + [[ 1.22.0 == 1\.23\.0 ]] + GIT_TAG=v1.22.0 + case $(curl -s -o /dev/null -w "%{http_code}" 'https://check.percona.com/versions/v1/psmdb-operator/'${INIT_OPERATOR_VER}'/latest?databaseVersion='${MONGO_VER}'') in ++ curl -s -o /dev/null -w '%{http_code}' 'https://check.percona.com/versions/v1/psmdb-operator/1.22.0/latest?databaseVersion=8.0' ++ curl -s 'https://check.percona.com/versions/v1/psmdb-operator/1.22.0/latest?databaseVersion=8.0' + INIT_OPERATOR_IMAGES='{"versions":[{"product":"psmdb-operator", "operator":"1.22.0", "matrix":{"mongod":{"8.0.19-7":{"imagePath":"percona/percona-server-mongodb:8.0.19-7", "imageHash":"779378a9f52cd9e617d0c356053b4b9c97209b0b759aa819300427836f6f2c66", "imageHashArm64":"531793543992d2e502d3187b778f8468462dd9cdb16a58fa157fe86626594ede", "status":"recommended", "critical":false}}, "pxc":{}, "pmm":{"2.44.1-1":{"imagePath":"percona/pmm-client:2.44.1-1", "imageHash":"52a8fb5e8f912eef1ff8a117ea323c401e278908ce29928dafc23fac1db4f1e3", "imageHashArm64":"390bfd12f981e8b3890550c4927a3ece071377065e001894458047602c744e3b", "status":"recommended", "critical":false}, "3.6.0":{"imagePath":"percona/pmm-client:3.6.0", "imageHash":"174fa4675d3ea4d95fd7b45d11f2bcc98b98b703662e6b2614dfe886a7187b23", "imageHashArm64":"435a9af2083adb68ddab6a97e6d02bd6d31c54562e919ebc09618e886d58d1ae", "status":"recommended", "critical":false}}, "proxysql":{}, "haproxy":{}, "backup":{"2.12.0":{"imagePath":"percona/percona-backup-mongodb:2.12.0", "imageHash":"6d56b787c2dc532c9c19cc607a2bc1855a722cdaa52024ea38d4de4aae777f8a", "imageHashArm64":"e2177fa6fef0e47ee8392ca7044a6781150ccf7297383239f813558323aa0a8e", "status":"recommended", "critical":false}}, "operator":{"1.22.0":{"imagePath":"percona/percona-server-mongodb-operator:1.22.0", "imageHash":"d4384b3853dc5026cc33de1dfd68ac11aaf5d54f4e84b115e05d7d473f4c6188", "imageHashArm64":"be97aad4c0642bc4e2e5c7c31b4d123d9f6135070682b8fbd6024c7620315e72", "status":"recommended", "critical":false}}, "logCollector":{"4.0.1-2":{"imagePath":"percona/fluentbit:4.0.1-2", "imageHash":"d732be16b7f3d0eea8d9c0a50f72136db83c2aed74262300d97abd2cfaefbc26", "imageHashArm64":"805c102d3646b8499b74ea9864d4c29137f94e4603470c23da1c032276193a36", "status":"recommended", "critical":false}}, "postgresql":{}, "pgbackrest":{}, "pgbackrestRepo":{}, "pgbadger":{}, "pgbouncer":{}, "pxcOperator":{}, "psmdbOperator":{}, "pgOperatorApiserver":{}, "pgOperatorEvent":{}, "pgOperatorRmdata":{}, "pgOperatorScheduler":{}, "pgOperator":{}, "pgOperatorDeployer":{}, "psOperator":{}, "mysql":{}, "router":{}, "orchestrator":{}, "toolkit":{}, "postgis":{}, "binlogServer":{}, "pgupgrade":{}}}]}' + OPERATOR_NAME=percona-server-mongodb-operator ++ echo '{"versions":[{"product":"psmdb-operator", "operator":"1.22.0", "matrix":{"mongod":{"8.0.19-7":{"imagePath":"percona/percona-server-mongodb:8.0.19-7", "imageHash":"779378a9f52cd9e617d0c356053b4b9c97209b0b759aa819300427836f6f2c66", "imageHashArm64":"531793543992d2e502d3187b778f8468462dd9cdb16a58fa157fe86626594ede", "status":"recommended", "critical":false}}, "pxc":{}, "pmm":{"2.44.1-1":{"imagePath":"percona/pmm-client:2.44.1-1", "imageHash":"52a8fb5e8f912eef1ff8a117ea323c401e278908ce29928dafc23fac1db4f1e3", "imageHashArm64":"390bfd12f981e8b3890550c4927a3ece071377065e001894458047602c744e3b", "status":"recommended", "critical":false}, "3.6.0":{"imagePath":"percona/pmm-client:3.6.0", "imageHash":"174fa4675d3ea4d95fd7b45d11f2bcc98b98b703662e6b2614dfe886a7187b23", "imageHashArm64":"435a9af2083adb68ddab6a97e6d02bd6d31c54562e919ebc09618e886d58d1ae", "status":"recommended", "critical":false}}, "proxysql":{}, "haproxy":{}, "backup":{"2.12.0":{"imagePath":"percona/percona-backup-mongodb:2.12.0", "imageHash":"6d56b787c2dc532c9c19cc607a2bc1855a722cdaa52024ea38d4de4aae777f8a", "imageHashArm64":"e2177fa6fef0e47ee8392ca7044a6781150ccf7297383239f813558323aa0a8e", "status":"recommended", "critical":false}}, "operator":{"1.22.0":{"imagePath":"percona/percona-server-mongodb-operator:1.22.0", "imageHash":"d4384b3853dc5026cc33de1dfd68ac11aaf5d54f4e84b115e05d7d473f4c6188", "imageHashArm64":"be97aad4c0642bc4e2e5c7c31b4d123d9f6135070682b8fbd6024c7620315e72", "status":"recommended", "critical":false}}, "logCollector":{"4.0.1-2":{"imagePath":"percona/fluentbit:4.0.1-2", "imageHash":"d732be16b7f3d0eea8d9c0a50f72136db83c2aed74262300d97abd2cfaefbc26", "imageHashArm64":"805c102d3646b8499b74ea9864d4c29137f94e4603470c23da1c032276193a36", "status":"recommended", "critical":false}}, "postgresql":{}, "pgbackrest":{}, "pgbackrestRepo":{}, "pgbadger":{}, "pgbouncer":{}, "pxcOperator":{}, "psmdbOperator":{}, "pgOperatorApiserver":{}, "pgOperatorEvent":{}, "pgOperatorRmdata":{}, "pgOperatorScheduler":{}, "pgOperator":{}, "pgOperatorDeployer":{}, "psOperator":{}, "mysql":{}, "router":{}, "orchestrator":{}, "toolkit":{}, "postgis":{}, "binlogServer":{}, "pgupgrade":{}}}]}' ++ jq -r '.versions[].matrix.operator[].imagePath' + IMAGE=percona/percona-server-mongodb-operator:1.22.0 + [[ docker.io/perconalab/percona-server-mongodb-operator:PR-2058-fb8cc7187 == perconalab/* ]] + [[ docker.io/perconalab/percona-server-mongodb-operator:PR-2058-fb8cc7187 == */perconalab/* ]] + IMAGE=perconalab/percona-server-mongodb-operator:1.22.0 ++ echo '{"versions":[{"product":"psmdb-operator", "operator":"1.22.0", "matrix":{"mongod":{"8.0.19-7":{"imagePath":"percona/percona-server-mongodb:8.0.19-7", "imageHash":"779378a9f52cd9e617d0c356053b4b9c97209b0b759aa819300427836f6f2c66", "imageHashArm64":"531793543992d2e502d3187b778f8468462dd9cdb16a58fa157fe86626594ede", "status":"recommended", "critical":false}}, "pxc":{}, "pmm":{"2.44.1-1":{"imagePath":"percona/pmm-client:2.44.1-1", "imageHash":"52a8fb5e8f912eef1ff8a117ea323c401e278908ce29928dafc23fac1db4f1e3", "imageHashArm64":"390bfd12f981e8b3890550c4927a3ece071377065e001894458047602c744e3b", "status":"recommended", "critical":false}, "3.6.0":{"imagePath":"percona/pmm-client:3.6.0", "imageHash":"174fa4675d3ea4d95fd7b45d11f2bcc98b98b703662e6b2614dfe886a7187b23", "imageHashArm64":"435a9af2083adb68ddab6a97e6d02bd6d31c54562e919ebc09618e886d58d1ae", "status":"recommended", "critical":false}}, "proxysql":{}, "haproxy":{}, "backup":{"2.12.0":{"imagePath":"percona/percona-backup-mongodb:2.12.0", "imageHash":"6d56b787c2dc532c9c19cc607a2bc1855a722cdaa52024ea38d4de4aae777f8a", "imageHashArm64":"e2177fa6fef0e47ee8392ca7044a6781150ccf7297383239f813558323aa0a8e", "status":"recommended", "critical":false}}, "operator":{"1.22.0":{"imagePath":"percona/percona-server-mongodb-operator:1.22.0", "imageHash":"d4384b3853dc5026cc33de1dfd68ac11aaf5d54f4e84b115e05d7d473f4c6188", "imageHashArm64":"be97aad4c0642bc4e2e5c7c31b4d123d9f6135070682b8fbd6024c7620315e72", "status":"recommended", "critical":false}}, "logCollector":{"4.0.1-2":{"imagePath":"percona/fluentbit:4.0.1-2", "imageHash":"d732be16b7f3d0eea8d9c0a50f72136db83c2aed74262300d97abd2cfaefbc26", "imageHashArm64":"805c102d3646b8499b74ea9864d4c29137f94e4603470c23da1c032276193a36", "status":"recommended", "critical":false}}, "postgresql":{}, "pgbackrest":{}, "pgbackrestRepo":{}, "pgbadger":{}, "pgbouncer":{}, "pxcOperator":{}, "psmdbOperator":{}, "pgOperatorApiserver":{}, "pgOperatorEvent":{}, "pgOperatorRmdata":{}, "pgOperatorScheduler":{}, "pgOperator":{}, "pgOperatorDeployer":{}, "psOperator":{}, "mysql":{}, "router":{}, "orchestrator":{}, "toolkit":{}, "postgis":{}, "binlogServer":{}, "pgupgrade":{}}}]}' ++ jq -r '.versions[].matrix.mongod[].imagePath' + IMAGE_MONGOD=percona/percona-server-mongodb:8.0.19-7 ++ echo '{"versions":[{"product":"psmdb-operator", "operator":"1.22.0", "matrix":{"mongod":{"8.0.19-7":{"imagePath":"percona/percona-server-mongodb:8.0.19-7", "imageHash":"779378a9f52cd9e617d0c356053b4b9c97209b0b759aa819300427836f6f2c66", "imageHashArm64":"531793543992d2e502d3187b778f8468462dd9cdb16a58fa157fe86626594ede", "status":"recommended", "critical":false}}, "pxc":{}, "pmm":{"2.44.1-1":{"imagePath":"percona/pmm-client:2.44.1-1", "imageHash":"52a8fb5e8f912eef1ff8a117ea323c401e278908ce29928dafc23fac1db4f1e3", "imageHashArm64":"390bfd12f981e8b3890550c4927a3ece071377065e001894458047602c744e3b", "status":"recommended", "critical":false}, "3.6.0":{"imagePath":"percona/pmm-client:3.6.0", "imageHash":"174fa4675d3ea4d95fd7b45d11f2bcc98b98b703662e6b2614dfe886a7187b23", "imageHashArm64":"435a9af2083adb68ddab6a97e6d02bd6d31c54562e919ebc09618e886d58d1ae", "status":"recommended", "critical":false}}, "proxysql":{}, "haproxy":{}, "backup":{"2.12.0":{"imagePath":"percona/percona-backup-mongodb:2.12.0", "imageHash":"6d56b787c2dc532c9c19cc607a2bc1855a722cdaa52024ea38d4de4aae777f8a", "imageHashArm64":"e2177fa6fef0e47ee8392ca7044a6781150ccf7297383239f813558323aa0a8e", "status":"recommended", "critical":false}}, "operator":{"1.22.0":{"imagePath":"percona/percona-server-mongodb-operator:1.22.0", "imageHash":"d4384b3853dc5026cc33de1dfd68ac11aaf5d54f4e84b115e05d7d473f4c6188", "imageHashArm64":"be97aad4c0642bc4e2e5c7c31b4d123d9f6135070682b8fbd6024c7620315e72", "status":"recommended", "critical":false}}, "logCollector":{"4.0.1-2":{"imagePath":"percona/fluentbit:4.0.1-2", "imageHash":"d732be16b7f3d0eea8d9c0a50f72136db83c2aed74262300d97abd2cfaefbc26", "imageHashArm64":"805c102d3646b8499b74ea9864d4c29137f94e4603470c23da1c032276193a36", "status":"recommended", "critical":false}}, "postgresql":{}, "pgbackrest":{}, "pgbackrestRepo":{}, "pgbadger":{}, "pgbouncer":{}, "pxcOperator":{}, "psmdbOperator":{}, "pgOperatorApiserver":{}, "pgOperatorEvent":{}, "pgOperatorRmdata":{}, "pgOperatorScheduler":{}, "pgOperator":{}, "pgOperatorDeployer":{}, "psOperator":{}, "mysql":{}, "router":{}, "orchestrator":{}, "toolkit":{}, "postgis":{}, "binlogServer":{}, "pgupgrade":{}}}]}' ++ jq -r '.versions[].matrix.pmm[].imagePath' + IMAGE_PMM_CLIENT=$'percona/pmm-client:2.44.1-1\npercona/pmm-client:3.6.0' ++ echo '{"versions":[{"product":"psmdb-operator", "operator":"1.22.0", "matrix":{"mongod":{"8.0.19-7":{"imagePath":"percona/percona-server-mongodb:8.0.19-7", "imageHash":"779378a9f52cd9e617d0c356053b4b9c97209b0b759aa819300427836f6f2c66", "imageHashArm64":"531793543992d2e502d3187b778f8468462dd9cdb16a58fa157fe86626594ede", "status":"recommended", "critical":false}}, "pxc":{}, "pmm":{"2.44.1-1":{"imagePath":"percona/pmm-client:2.44.1-1", "imageHash":"52a8fb5e8f912eef1ff8a117ea323c401e278908ce29928dafc23fac1db4f1e3", "imageHashArm64":"390bfd12f981e8b3890550c4927a3ece071377065e001894458047602c744e3b", "status":"recommended", "critical":false}, "3.6.0":{"imagePath":"percona/pmm-client:3.6.0", "imageHash":"174fa4675d3ea4d95fd7b45d11f2bcc98b98b703662e6b2614dfe886a7187b23", "imageHashArm64":"435a9af2083adb68ddab6a97e6d02bd6d31c54562e919ebc09618e886d58d1ae", "status":"recommended", "critical":false}}, "proxysql":{}, "haproxy":{}, "backup":{"2.12.0":{"imagePath":"percona/percona-backup-mongodb:2.12.0", "imageHash":"6d56b787c2dc532c9c19cc607a2bc1855a722cdaa52024ea38d4de4aae777f8a", "imageHashArm64":"e2177fa6fef0e47ee8392ca7044a6781150ccf7297383239f813558323aa0a8e", "status":"recommended", "critical":false}}, "operator":{"1.22.0":{"imagePath":"percona/percona-server-mongodb-operator:1.22.0", "imageHash":"d4384b3853dc5026cc33de1dfd68ac11aaf5d54f4e84b115e05d7d473f4c6188", "imageHashArm64":"be97aad4c0642bc4e2e5c7c31b4d123d9f6135070682b8fbd6024c7620315e72", "status":"recommended", "critical":false}}, "logCollector":{"4.0.1-2":{"imagePath":"percona/fluentbit:4.0.1-2", "imageHash":"d732be16b7f3d0eea8d9c0a50f72136db83c2aed74262300d97abd2cfaefbc26", "imageHashArm64":"805c102d3646b8499b74ea9864d4c29137f94e4603470c23da1c032276193a36", "status":"recommended", "critical":false}}, "postgresql":{}, "pgbackrest":{}, "pgbackrestRepo":{}, "pgbadger":{}, "pgbouncer":{}, "pxcOperator":{}, "psmdbOperator":{}, "pgOperatorApiserver":{}, "pgOperatorEvent":{}, "pgOperatorRmdata":{}, "pgOperatorScheduler":{}, "pgOperator":{}, "pgOperatorDeployer":{}, "psOperator":{}, "mysql":{}, "router":{}, "orchestrator":{}, "toolkit":{}, "postgis":{}, "binlogServer":{}, "pgupgrade":{}}}]}' ++ jq -r '.versions[].matrix.backup[].imagePath' + IMAGE_BACKUP=percona/percona-backup-mongodb:2.12.0 + qualify_image_var IMAGE + local var=IMAGE + local val=perconalab/percona-server-mongodb-operator:1.22.0 + local out= + local ref + [[ -z perconalab/percona-server-mongodb-operator:1.22.0 ]] + [[ perconalab/percona-server-mongodb-operator:1.22.0 == * * ]] ++ qualify_image_ref perconalab/percona-server-mongodb-operator:1.22.0 ++ local ref=perconalab/percona-server-mongodb-operator:1.22.0 ++ local first=perconalab ++ [[ perconalab == *.* ]] ++ [[ perconalab == *:* ]] ++ [[ perconalab == localhost ]] ++ [[ perconalab/percona-server-mongodb-operator:1.22.0 == percona/* ]] ++ [[ perconalab/percona-server-mongodb-operator:1.22.0 == perconalab/* ]] ++ printf %s%s docker.io/ perconalab/percona-server-mongodb-operator:1.22.0 ++ return 0 + printf -v IMAGE %s docker.io/perconalab/percona-server-mongodb-operator:1.22.0 + qualify_image_var IMAGE_MONGOD + local var=IMAGE_MONGOD + local val=percona/percona-server-mongodb:8.0.19-7 + local out= + local ref + [[ -z percona/percona-server-mongodb:8.0.19-7 ]] + [[ percona/percona-server-mongodb:8.0.19-7 == * * ]] ++ qualify_image_ref percona/percona-server-mongodb:8.0.19-7 ++ local ref=percona/percona-server-mongodb:8.0.19-7 ++ local first=percona ++ [[ percona == *.* ]] ++ [[ percona == *:* ]] ++ [[ percona == localhost ]] ++ [[ percona/percona-server-mongodb:8.0.19-7 == percona/* ]] ++ printf %s%s docker.io/ percona/percona-server-mongodb:8.0.19-7 ++ return 0 + printf -v IMAGE_MONGOD %s docker.io/percona/percona-server-mongodb:8.0.19-7 + qualify_image_var IMAGE_PMM_CLIENT + local var=IMAGE_PMM_CLIENT + local $'val=percona/pmm-client:2.44.1-1\npercona/pmm-client:3.6.0' + local out= + local ref + [[ -z percona/pmm-client:2.44.1-1 percona/pmm-client:3.6.0 ]] + [[ percona/pmm-client:2.44.1-1 percona/pmm-client:3.6.0 == * * ]] + IFS= + read -r ref + [[ -z percona/pmm-client:2.44.1-1 ]] ++ qualify_image_ref percona/pmm-client:2.44.1-1 ++ local ref=percona/pmm-client:2.44.1-1 ++ local first=percona ++ [[ percona == *.* ]] ++ [[ percona == *:* ]] ++ [[ percona == localhost ]] ++ [[ percona/pmm-client:2.44.1-1 == percona/* ]] ++ printf %s%s docker.io/ percona/pmm-client:2.44.1-1 ++ return 0 + out+=docker.io/percona/pmm-client:2.44.1-1 + out+=$'\n' + IFS= + read -r ref + [[ -z percona/pmm-client:3.6.0 ]] ++ qualify_image_ref percona/pmm-client:3.6.0 ++ local ref=percona/pmm-client:3.6.0 ++ local first=percona ++ [[ percona == *.* ]] ++ [[ percona == *:* ]] ++ [[ percona == localhost ]] ++ [[ percona/pmm-client:3.6.0 == percona/* ]] ++ printf %s%s docker.io/ percona/pmm-client:3.6.0 ++ return 0 + out+=docker.io/percona/pmm-client:3.6.0 + out+=$'\n' + IFS= + read -r ref + out=$'docker.io/percona/pmm-client:2.44.1-1\ndocker.io/percona/pmm-client:3.6.0' + printf -v IMAGE_PMM_CLIENT %s $'docker.io/percona/pmm-client:2.44.1-1\ndocker.io/percona/pmm-client:3.6.0' + return 0 + qualify_image_var IMAGE_BACKUP + local var=IMAGE_BACKUP + local val=percona/percona-backup-mongodb:2.12.0 + local out= + local ref + [[ -z percona/percona-backup-mongodb:2.12.0 ]] + [[ percona/percona-backup-mongodb:2.12.0 == * * ]] ++ qualify_image_ref percona/percona-backup-mongodb:2.12.0 ++ local ref=percona/percona-backup-mongodb:2.12.0 ++ local first=percona ++ [[ percona == *.* ]] ++ [[ percona == *:* ]] ++ [[ percona == localhost ]] ++ [[ percona/percona-backup-mongodb:2.12.0 == percona/* ]] ++ printf %s%s docker.io/ percona/percona-backup-mongodb:2.12.0 ++ return 0 + printf -v IMAGE_BACKUP %s docker.io/percona/percona-backup-mongodb:2.12.0 + [[ 1.23.0 == 1\.22\.0 ]] + main + rbac=rbac + '[' -n psmdb-operator ']' + rbac=cw-rbac + create_infra_gh upgrade-30317 v1.22.0 + local ns=upgrade-30317 + local git_tag=v1.22.0 + check_crd_for_deletion v1.22.0 + local git_tag=v1.22.0 ++ curl -s https://raw.githubusercontent.com/percona/percona-server-mongodb-operator/v1.22.0/deploy/crd.yaml ++ yq eval .metadata.name ++ /usr/sbin/sed s/---//g ++ /usr/sbin/sed ':a;N;$!ba;s/\n/ /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/perconaservermongodbbackups.psmdb.percona.com -o 'jsonpath={.status.conditions[-1].type}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.69rbrULhoA +++ mktemp ++ local LAST_ERR=/tmp/tmp.Nmw2vIgXRm ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get crd/perconaservermongodbbackups.psmdb.percona.com -o 'jsonpath={.status.conditions[-1].type}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.69rbrULhoA ++ cat /tmp/tmp.Nmw2vIgXRm ++ rm /tmp/tmp.69rbrULhoA /tmp/tmp.Nmw2vIgXRm ++ return 0 + [[ Established == Terminating ]] + 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/perconaservermongodbrestores.psmdb.percona.com -o 'jsonpath={.status.conditions[-1].type}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.VEQpvZfg0p +++ mktemp ++ local LAST_ERR=/tmp/tmp.UIqbpc7wTV ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get crd/perconaservermongodbrestores.psmdb.percona.com -o 'jsonpath={.status.conditions[-1].type}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.VEQpvZfg0p ++ cat /tmp/tmp.UIqbpc7wTV ++ rm /tmp/tmp.VEQpvZfg0p /tmp/tmp.UIqbpc7wTV ++ return 0 + [[ Established == Terminating ]] + 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/perconaservermongodbs.psmdb.percona.com -o 'jsonpath={.status.conditions[-1].type}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.dYBay0rBmJ +++ mktemp ++ local LAST_ERR=/tmp/tmp.HWA9tng6uj ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get crd/perconaservermongodbs.psmdb.percona.com -o 'jsonpath={.status.conditions[-1].type}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.dYBay0rBmJ ++ cat /tmp/tmp.HWA9tng6uj ++ rm /tmp/tmp.dYBay0rBmJ /tmp/tmp.HWA9tng6uj ++ return 0 + [[ Established == Terminating ]] + '[' -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 + '[' -n '' ']' + desc 'cleaned up old namespaces psmdb-operator' + set +o xtrace + grep -E -v '^kube-|^default|Terminating|psmdb-operator|openshift|^gke-|^gmp-|^NAME' ----------------------------------------------------------------------------------- cleaned up old namespaces psmdb-operator ----------------------------------------------------------------------------------- + kubectl_bin delete namespace psmdb-operator --ignore-not-found + awk '{print$1}' + xargs kubectl delete ns ++ mktemp ++ mktemp + local LAST_OUT=/tmp/tmp.J2NFz9lXjX ++ mktemp + local LAST_OUT=/tmp/tmp.vhjCdW3qGu + local LAST_ERR=/tmp/tmp.T88dC8oiF8 + local exit_status=0 + local timeout=4 ++ seq 0 2 ++ mktemp + for i in $(seq 0 2) + set +e + kubectl get ns + local LAST_ERR=/tmp/tmp.kkYYjTGxwK + local exit_status=0 + local timeout=4 ++ seq 0 2 + 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.J2NFz9lXjX + cat /tmp/tmp.T88dC8oiF8 + rm /tmp/tmp.J2NFz9lXjX /tmp/tmp.T88dC8oiF8 + return 0 namespace "split-horizon-manual-tls-24334" deleted + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.vhjCdW3qGu namespace "psmdb-operator" deleted + cat /tmp/tmp.kkYYjTGxwK + rm /tmp/tmp.vhjCdW3qGu /tmp/tmp.kkYYjTGxwK + return 0 + kubectl_bin wait --for=delete namespace psmdb-operator ++ mktemp + local LAST_OUT=/tmp/tmp.mFGapvSyXb ++ mktemp + local LAST_ERR=/tmp/tmp.eqzplr1eBA + 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.mFGapvSyXb + cat /tmp/tmp.eqzplr1eBA + rm /tmp/tmp.mFGapvSyXb /tmp/tmp.eqzplr1eBA + 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.H7skMdXVJb ++ mktemp + local LAST_ERR=/tmp/tmp.8clByU6qr5 + 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.H7skMdXVJb namespace/psmdb-operator created + cat /tmp/tmp.8clByU6qr5 + rm /tmp/tmp.H7skMdXVJb /tmp/tmp.8clByU6qr5 + return 0 + set_kube_ctx psmdb-operator + local namespace=psmdb-operator ++ kubectl_bin config current-context +++ mktemp ++ local LAST_OUT=/tmp/tmp.VhGFpPkSGZ +++ mktemp ++ local LAST_ERR=/tmp/tmp.vwvFOj8H5i ++ 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.VhGFpPkSGZ ++ cat /tmp/tmp.vwvFOj8H5i ++ rm /tmp/tmp.VhGFpPkSGZ /tmp/tmp.vwvFOj8H5i ++ return 0 + kubectl_bin config set-context gke_cloud-dev-112233_us-central1-a_jen-psmdb-2058-fb8cc7187-17-cluster14 --namespace=psmdb-operator ++ mktemp + local LAST_OUT=/tmp/tmp.yQQcXluN5K ++ mktemp + local LAST_ERR=/tmp/tmp.dWW9ZVbyO9 + 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-2058-fb8cc7187-17-cluster14 --namespace=psmdb-operator + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.yQQcXluN5K Context "gke_cloud-dev-112233_us-central1-a_jen-psmdb-2058-fb8cc7187-17-cluster14" modified. + cat /tmp/tmp.dWW9ZVbyO9 + rm /tmp/tmp.yQQcXluN5K /tmp/tmp.dWW9ZVbyO9 + return 0 + deploy_operator_gh v1.22.0 + local git_tag=v1.22.0 + desc 'start operator' + set +o xtrace ----------------------------------------------------------------------------------- start operator ----------------------------------------------------------------------------------- + kubectl_bin apply -f https://raw.githubusercontent.com/percona/percona-server-mongodb-operator/v1.22.0/deploy/crd.yaml --server-side ++ mktemp + local LAST_OUT=/tmp/tmp.n9EW03CTAT ++ mktemp + local LAST_ERR=/tmp/tmp.3Omv4KM9OR + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl apply -f https://raw.githubusercontent.com/percona/percona-server-mongodb-operator/v1.22.0/deploy/crd.yaml --server-side + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.n9EW03CTAT 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.3Omv4KM9OR + rm /tmp/tmp.n9EW03CTAT /tmp/tmp.3Omv4KM9OR + return 0 + local rbac_yaml=rbac + local operator_yaml=operator + '[' -n psmdb-operator ']' + rbac_yaml=cw-rbac + operator_yaml=cw-operator + kubectl_bin apply -f https://raw.githubusercontent.com/percona/percona-server-mongodb-operator/v1.22.0/deploy/cw-rbac.yaml ++ mktemp + local LAST_OUT=/tmp/tmp.7pNed5dAkq ++ mktemp + local LAST_ERR=/tmp/tmp.TihPn1fZr6 + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl apply -f https://raw.githubusercontent.com/percona/percona-server-mongodb-operator/v1.22.0/deploy/cw-rbac.yaml + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.7pNed5dAkq clusterrole.rbac.authorization.k8s.io/percona-server-mongodb-operator configured serviceaccount/percona-server-mongodb-operator created clusterrolebinding.rbac.authorization.k8s.io/service-account-percona-server-mongodb-operator unchanged + cat /tmp/tmp.TihPn1fZr6 + rm /tmp/tmp.7pNed5dAkq /tmp/tmp.TihPn1fZr6 + return 0 + curl -s https://raw.githubusercontent.com/percona/percona-server-mongodb-operator/v1.22.0/deploy/cw-operator.yaml + yq eval $'\n\t\t(.spec.template.spec.containers[].image = "docker.io/perconalab/percona-server-mongodb-operator:1.22.0") |\n\t\t((.. | select(.[] == "DISABLE_TELEMETRY")) |= .value="true") |\n\t\t((.. | select(.[] == "LOG_LEVEL")) |= .value="DEBUG")' /tmp/tmp.uTQpXpxW6A/cw-operator_v1.22.0.yaml + kubectl_bin apply -n psmdb-operator -f - ++ mktemp + local LAST_OUT=/tmp/tmp.s1digG0xnt ++ mktemp + local LAST_ERR=/tmp/tmp.U3YO0AbVB4 + 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.s1digG0xnt deployment.apps/percona-server-mongodb-operator created + cat /tmp/tmp.U3YO0AbVB4 + rm /tmp/tmp.s1digG0xnt /tmp/tmp.U3YO0AbVB4 + return 0 + sleep 2 ++ 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.cNRA1cCSho +++ mktemp ++ local LAST_ERR=/tmp/tmp.SQjaE9xUYP ++ 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.cNRA1cCSho ++ cat /tmp/tmp.SQjaE9xUYP ++ rm /tmp/tmp.cNRA1cCSho /tmp/tmp.SQjaE9xUYP ++ return 0 + wait_operator_pod percona-server-mongodb-operator-5c87b8f5df-jkvwb + local pod=percona-server-mongodb-operator-5c87b8f5df-jkvwb + set +o xtrace waiting for pod/percona-server-mongodb-operator-5c87b8f5df-jkvwb 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.F7r1wlu2bl +++ mktemp ++ local LAST_ERR=/tmp/tmp.TFSeBBlI9i ++ 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.F7r1wlu2bl ++ cat /tmp/tmp.TFSeBBlI9i ++ rm /tmp/tmp.F7r1wlu2bl /tmp/tmp.TFSeBBlI9i ++ return 0 + kubectl_bin logs -n psmdb-operator percona-server-mongodb-operator-5c87b8f5df-jkvwb ++ mktemp + local LAST_OUT=/tmp/tmp.rpBIJgJ5GZ ++ mktemp + local LAST_ERR=/tmp/tmp.sHEhSX4drE + 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-5c87b8f5df-jkvwb + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.rpBIJgJ5GZ + cat /tmp/tmp.sHEhSX4drE + rm /tmp/tmp.rpBIJgJ5GZ /tmp/tmp.sHEhSX4drE + return 0 2026-06-09T10:57:45.343Z INFO setup Manager starting up {"gitCommit": "1fc1e8b4e5640f83f0b5b71e0f25d8bbec82caf6", "gitBranch": "release-1-22-0", "buildTime": "", "goVersion": "go1.25.7", "os": "linux", "arch": "amd64"} + create_namespace upgrade-30317 + local namespace=upgrade-30317 + 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' + xargs kubectl delete ns + awk '{print$1}' ++ mktemp + '[' -n '' ']' + desc 'cleaned up old namespaces upgrade-30317' + set +o xtrace ----------------------------------------------------------------------------------- cleaned up old namespaces upgrade-30317 ----------------------------------------------------------------------------------- + kubectl_bin delete namespace upgrade-30317 --ignore-not-found + local LAST_OUT=/tmp/tmp.gbILdvmKNO ++ mktemp ++ mktemp + local LAST_ERR=/tmp/tmp.ZBsJvhTsTt + local exit_status=0 + local timeout=4 ++ seq 0 2 + local LAST_OUT=/tmp/tmp.6C8Ru0vHbR + for i in $(seq 0 2) + set +e + kubectl get ns ++ mktemp + local LAST_ERR=/tmp/tmp.6VSxE06JEJ + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl delete namespace upgrade-30317 --ignore-not-found + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.gbILdvmKNO + cat /tmp/tmp.ZBsJvhTsTt + rm /tmp/tmp.gbILdvmKNO /tmp/tmp.ZBsJvhTsTt + return 0 + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.6C8Ru0vHbR + cat /tmp/tmp.6VSxE06JEJ + rm /tmp/tmp.6C8Ru0vHbR /tmp/tmp.6VSxE06JEJ + return 0 + kubectl_bin wait --for=delete namespace upgrade-30317 ++ mktemp + local LAST_OUT=/tmp/tmp.kqtyZXPDCu ++ mktemp + local LAST_ERR=/tmp/tmp.l0zdlT5zCI + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl wait --for=delete namespace upgrade-30317 error: resource(s) were provided, but no name was specified + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.kqtyZXPDCu + cat /tmp/tmp.l0zdlT5zCI + rm /tmp/tmp.kqtyZXPDCu /tmp/tmp.l0zdlT5zCI + return 0 + desc 'create namespace upgrade-30317' + set +o xtrace ----------------------------------------------------------------------------------- create namespace upgrade-30317 ----------------------------------------------------------------------------------- + kubectl_bin create namespace upgrade-30317 ++ mktemp + local LAST_OUT=/tmp/tmp.Ffp4U72ENZ ++ mktemp + local LAST_ERR=/tmp/tmp.ad4cpy7Luc + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl create namespace upgrade-30317 + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.Ffp4U72ENZ namespace/upgrade-30317 created + cat /tmp/tmp.ad4cpy7Luc + rm /tmp/tmp.Ffp4U72ENZ /tmp/tmp.ad4cpy7Luc + return 0 + set_kube_ctx upgrade-30317 + local namespace=upgrade-30317 ++ kubectl_bin config current-context +++ mktemp ++ local LAST_OUT=/tmp/tmp.fiiYVZHCPb +++ mktemp ++ local LAST_ERR=/tmp/tmp.j7yBWydNau ++ 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.fiiYVZHCPb ++ cat /tmp/tmp.j7yBWydNau ++ rm /tmp/tmp.fiiYVZHCPb /tmp/tmp.j7yBWydNau ++ return 0 + kubectl_bin config set-context gke_cloud-dev-112233_us-central1-a_jen-psmdb-2058-fb8cc7187-17-cluster14 --namespace=upgrade-30317 ++ mktemp + local LAST_OUT=/tmp/tmp.fSO4ew9QgE ++ mktemp + local LAST_ERR=/tmp/tmp.f7zIAkUsj2 + 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-2058-fb8cc7187-17-cluster14 --namespace=upgrade-30317 + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.fSO4ew9QgE Context "gke_cloud-dev-112233_us-central1-a_jen-psmdb-2058-fb8cc7187-17-cluster14" modified. + cat /tmp/tmp.f7zIAkUsj2 + rm /tmp/tmp.fSO4ew9QgE /tmp/tmp.f7zIAkUsj2 + return 0 + apply_s3_storage_secrets + desc 'create secrets for cloud storages' + set +o xtrace ----------------------------------------------------------------------------------- create secrets for cloud storages ----------------------------------------------------------------------------------- + '[' -z '' ']' + kubectl_bin apply -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/conf/minio-secret.yml -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/conf/cloud-secret.yml ++ mktemp + local LAST_OUT=/tmp/tmp.qt4hY0F6nV ++ mktemp + local LAST_ERR=/tmp/tmp.03uHomNlTD + 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-2058/e2e-tests/conf/minio-secret.yml -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/conf/cloud-secret.yml + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.qt4hY0F6nV secret/minio-secret created secret/aws-s3-secret created secret/alibaba-cloud-secret created secret/gcp-cs-secret created secret/azure-secret created secret/gcp-cs-sa-key-secret created + cat /tmp/tmp.03uHomNlTD + rm /tmp/tmp.qt4hY0F6nV /tmp/tmp.03uHomNlTD + return 0 + deploy_minio + local cert_secret= + local service_name=minio-service + desc 'install MinIO: minio-service' + set +o xtrace ----------------------------------------------------------------------------------- install MinIO: minio-service ----------------------------------------------------------------------------------- + helm uninstall minio-service + : + helm repo remove minio "minio" has been removed from your repositories + helm repo add minio https://charts.min.io/ "minio" has been added to your repositories + local endpoint=http://minio-service:9000 + minio_args=('--version' '5.4.0' '--set' 'replicas=1' '--set' 'mode=standalone' '--set' 'resources.requests.memory=256Mi' '--set' 'rootUser=rootuser' '--set' 'rootPassword=rootpass123' '--set' 'users[0].accessKey=some-access-key' '--set' 'users[0].secretKey=some-secret-key' '--set' 'users[0].policy=consoleAdmin' '--set' 'service.type=ClusterIP' '--set' 'configPathmc=/tmp/' '--set' 'securityContext.enabled=false' '--set' 'persistence.size=2G' '--set' 'fullnameOverride=minio-service' '--set' 'serviceAccount.create=true' '--set' 'serviceAccount.name=minio-service-sa') + local minio_args + [[ -n '' ]] + retry 10 60 helm install minio-service --version 5.4.0 --set replicas=1 --set mode=standalone --set resources.requests.memory=256Mi --set rootUser=rootuser --set rootPassword=rootpass123 --set 'users[0].accessKey=some-access-key' --set 'users[0].secretKey=some-secret-key' --set 'users[0].policy=consoleAdmin' --set service.type=ClusterIP --set configPathmc=/tmp/ --set securityContext.enabled=false --set persistence.size=2G --set fullnameOverride=minio-service --set serviceAccount.create=true --set serviceAccount.name=minio-service-sa minio/minio + local max=10 + local delay=60 + shift 2 + local n=1 + helm install minio-service --version 5.4.0 --set replicas=1 --set mode=standalone --set resources.requests.memory=256Mi --set rootUser=rootuser --set rootPassword=rootpass123 --set 'users[0].accessKey=some-access-key' --set 'users[0].secretKey=some-secret-key' --set 'users[0].policy=consoleAdmin' --set service.type=ClusterIP --set configPathmc=/tmp/ --set securityContext.enabled=false --set persistence.size=2G --set fullnameOverride=minio-service --set serviceAccount.create=true --set serviceAccount.name=minio-service-sa minio/minio NAME: minio-service LAST DEPLOYED: Tue Jun 9 10:58:08 2026 NAMESPACE: upgrade-30317 STATUS: deployed REVISION: 1 TEST SUITE: None NOTES: MinIO can be accessed via port 9000 on the following DNS name from within your cluster: minio-service.upgrade-30317.cluster.local To access MinIO from localhost, run the below commands: 1. export POD_NAME=$(kubectl get pods --namespace upgrade-30317 -l "release=minio-service" -o jsonpath="{.items[0].metadata.name}") 2. kubectl port-forward $POD_NAME 9000 --namespace upgrade-30317 Read more about port forwarding here: http://kubernetes.io/docs/user-guide/kubectl/kubectl_port-forward/ You can now access MinIO server on http://localhost:9000. Follow the below steps to connect to MinIO server with mc client: 1. Download the MinIO mc client - https://min.io/docs/minio/linux/reference/minio-mc.html#quickstart 2. export MC_HOST_minio-service-local=http://$(kubectl get secret --namespace upgrade-30317 minio-service -o jsonpath="{.data.rootUser}" | base64 --decode):$(kubectl get secret --namespace upgrade-30317 minio-service -o jsonpath="{.data.rootPassword}" | base64 --decode)@localhost:9000 3. mc ls minio-service-local ++ kubectl_bin get pods --selector=release=minio-service -o 'jsonpath={.items[].metadata.name}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.f1W5HyUwSG +++ mktemp ++ local LAST_ERR=/tmp/tmp.ZJPwRwTcke ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods --selector=release=minio-service -o 'jsonpath={.items[].metadata.name}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.f1W5HyUwSG ++ cat /tmp/tmp.ZJPwRwTcke ++ rm /tmp/tmp.f1W5HyUwSG /tmp/tmp.ZJPwRwTcke ++ return 0 + local MINIO_POD=minio-service-6d5f646cdc-256sv + wait_pod minio-service-6d5f646cdc-256sv + local pod=minio-service-6d5f646cdc-256sv + set +o xtrace waiting for pod/minio-service-6d5f646cdc-256sv to be ready.OK + '[' -n psmdb-operator ']' + kubectl_bin create svc -n psmdb-operator externalname minio-service --external-name=minio-service.upgrade-30317.svc.cluster.local --tcp=9000 service/minio-service created + create_minio_bucket operator-testing http://minio-service:9000 + local bucket=operator-testing + local endpoint=http://minio-service:9000 + kubectl_bin run -i --rm aws-cli --image=docker.io/perconalab/awscli --restart=Never -- bash -c $'AWS_ACCESS_KEY_ID=some-access-key \t\tAWS_SECRET_ACCESS_KEY=some-secret-key \t\tAWS_DEFAULT_REGION=us-east-1 /usr/bin/aws --no-verify-ssl --endpoint-url http://minio-service:9000 s3 mb s3://operator-testing' ++ mktemp + local LAST_OUT=/tmp/tmp.h29xsW2Ovc ++ mktemp + local LAST_ERR=/tmp/tmp.FCPHi14W2r + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl run -i --rm aws-cli --image=docker.io/perconalab/awscli --restart=Never -- bash -c $'AWS_ACCESS_KEY_ID=some-access-key \t\tAWS_SECRET_ACCESS_KEY=some-secret-key \t\tAWS_DEFAULT_REGION=us-east-1 /usr/bin/aws --no-verify-ssl --endpoint-url http://minio-service:9000 s3 mb s3://operator-testing' + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.h29xsW2Ovc make_bucket: operator-testing make_bucket: operator-testing pod "aws-cli" deleted from upgrade-30317 namespace + cat /tmp/tmp.FCPHi14W2r All commands and output from this session will be recorded in container logs, including credentials and sensitive information passed through the command prompt. If you don't see a command prompt, try pressing enter. warning: couldn't attach to pod/aws-cli, falling back to streaming logs: Internal error occurred: unable to upgrade connection: container aws-cli not found in pod aws-cli_upgrade-30317 + rm /tmp/tmp.h29xsW2Ovc /tmp/tmp.FCPHi14W2r + return 0 + desc 'create secrets and start client' + set +o xtrace ----------------------------------------------------------------------------------- create secrets and start client ----------------------------------------------------------------------------------- + curl -s https://raw.githubusercontent.com/percona/percona-server-mongodb-operator/v1.22.0/deploy/secrets.yaml + kubectl_bin apply -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/conf/client.yml -f /tmp/tmp.uTQpXpxW6A/secrets.yaml ++ mktemp + local LAST_OUT=/tmp/tmp.h7q4nVGYfm ++ mktemp + local LAST_ERR=/tmp/tmp.W4A40cyfEw + 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-2058/e2e-tests/conf/client.yml -f /tmp/tmp.uTQpXpxW6A/secrets.yaml + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.h7q4nVGYfm deployment.apps/psmdb-client created secret/my-cluster-name-secrets created + cat /tmp/tmp.W4A40cyfEw + rm /tmp/tmp.h7q4nVGYfm /tmp/tmp.W4A40cyfEw + return 0 + local cr_yaml=/tmp/tmp.uTQpXpxW6A/cr_v1.22.0.yaml + prepare_cr_yaml /tmp/tmp.uTQpXpxW6A/cr_v1.22.0.yaml + local cr_yaml=/tmp/tmp.uTQpXpxW6A/cr_v1.22.0.yaml + curl -s https://raw.githubusercontent.com/percona/percona-server-mongodb-operator/v1.22.0/deploy/cr.yaml + yq eval $'\n\t\t\t.metadata.name = "upgrade" |\n\t\t\t.spec.upgradeOptions.apply = "disabled" |\n\t\t\t.spec.replsets[].size = 3 |\n\t\t\t.spec.replsets[].arbiter.enabled = false |\n\t\t\t.spec.backup.enabled = true |\n\t\t\t.spec.backup.pitr.enabled = false |\n\t\t\t.spec.backup.storages.minio.type = "s3" |\n\t\t\t.spec.backup.storages.minio.s3.credentialsSecret = "minio-secret" |\n\t\t\t.spec.backup.storages.minio.s3.region = "us-east-1" |\n\t\t\t.spec.backup.storages.minio.s3.bucket = "operator-testing" |\n\t\t\t.spec.backup.storages.minio.s3.endpointUrl = "http://minio-service:9000/" |\n\t\t\t.spec.sharding.enabled = false |\n\t\t\t.spec.image="" | .spec.image tag="!!null" |\n\t\t\t.spec.backup.image = "-backup" |\n\t\t\t.spec.pmm.image = "-pmm"' + desc 'create first PSMDB cluster' + set +o xtrace ----------------------------------------------------------------------------------- create first PSMDB cluster ----------------------------------------------------------------------------------- + apply_cluster /tmp/tmp.uTQpXpxW6A/cr_v1.22.0.yaml + '[' -z '' ']' + cat_config /tmp/tmp.uTQpXpxW6A/cr_v1.22.0.yaml + kubectl_bin apply -f - + cat /tmp/tmp.uTQpXpxW6A/cr_v1.22.0.yaml ++ mktemp + yq eval '(.spec | select(.image == null)).image = "docker.io/percona/percona-server-mongodb:8.0.19-7"' + yq eval $'(.spec | select(has("pmm"))).pmm.image = "docker.io/percona/pmm-client:2.44.1-1\ndocker.io/percona/pmm-client:3.6.0"' + yq eval '(.spec | select(has("initImage"))).initImage = "docker.io/perconalab/percona-server-mongodb-operator:1.22.0"' + yq eval '(.spec | select(has("backup"))).backup.image = "docker.io/percona/percona-backup-mongodb:2.12.0"' + local LAST_OUT=/tmp/tmp.b69vmOutQk + /usr/sbin/sed -e s/NAME_SPACE/upgrade-30317/g + yq eval '.spec.upgradeOptions.apply="Never"' ++ mktemp + local LAST_ERR=/tmp/tmp.JZmu7jcwsN + 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.b69vmOutQk perconaservermongodb.psmdb.percona.com/upgrade created + cat /tmp/tmp.JZmu7jcwsN + rm /tmp/tmp.b69vmOutQk /tmp/tmp.JZmu7jcwsN + return 0 + desc 'check if Pod is started' + set +o xtrace ----------------------------------------------------------------------------------- check if Pod is started ----------------------------------------------------------------------------------- + wait_for_running upgrade-rs0 3 + local name=upgrade-rs0 + let last_pod=2 + local check_cluster_readyness=true + set_debug + [[ 1 == 1 ]] + set -o xtrace + local rs_name=rs0 + local cluster_name=upgrade ++ seq 0 2 + for i in $(seq 0 $last_pod) + [[ 0 -eq 2 ]] + wait_pod upgrade-rs0-0 + local pod=upgrade-rs0-0 + set +o xtrace waiting for pod/upgrade-rs0-0 to be ready......................OK + for i in $(seq 0 $last_pod) + [[ 1 -eq 2 ]] + wait_pod upgrade-rs0-1 + local pod=upgrade-rs0-1 + set +o xtrace waiting for pod/upgrade-rs0-1 to be ready......................OK + for i in $(seq 0 $last_pod) + [[ 2 -eq 2 ]] ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].arbiter.enabled}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.YKomAnvrt7 +++ mktemp ++ local LAST_ERR=/tmp/tmp.qlS4V9tKSL ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].arbiter.enabled}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.YKomAnvrt7 ++ cat /tmp/tmp.qlS4V9tKSL ++ rm /tmp/tmp.YKomAnvrt7 /tmp/tmp.qlS4V9tKSL ++ return 0 + [[ false == true ]] + wait_pod upgrade-rs0-2 + local pod=upgrade-rs0-2 + set +o xtrace waiting for pod/upgrade-rs0-2 to be ready.......................OK ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].nonvoting.enabled}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.3P1sqKsqqw +++ mktemp ++ local LAST_ERR=/tmp/tmp.ZMXe77N6pK ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].nonvoting.enabled}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.3P1sqKsqqw ++ cat /tmp/tmp.ZMXe77N6pK ++ rm /tmp/tmp.3P1sqKsqqw /tmp/tmp.ZMXe77N6pK ++ return 0 + [[ false == true ]] ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].hidden.enabled}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.eNBmomCLuJ +++ mktemp ++ local LAST_ERR=/tmp/tmp.RadcGVmOMP ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].hidden.enabled}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.eNBmomCLuJ ++ cat /tmp/tmp.RadcGVmOMP ++ rm /tmp/tmp.eNBmomCLuJ /tmp/tmp.RadcGVmOMP ++ return 0 + [[ false == true ]] + sleep 10 + [[ true == true ]] + set +x Waiting for cluster readyness + sleep 20 + desc 'create user myApp' + set +o xtrace ----------------------------------------------------------------------------------- create user myApp ----------------------------------------------------------------------------------- + run_mongo 'db.createUser({user: "myApp", pwd: "myPass", roles: [{ db: "myApp", role: "readWrite" }]})' userAdmin:userAdmin123456@upgrade-rs0.upgrade-30317 + local 'command=db.createUser({user: "myApp", pwd: "myPass", roles: [{ db: "myApp", role: "readWrite" }]})' + local uri=userAdmin:userAdmin123456@upgrade-rs0.upgrade-30317 + local driver=mongodb+srv + local suffix=.svc.cluster.local + local mongo_flag= + local replica_set=rs0 + [[ userAdmin:userAdmin123456@upgrade-rs0.upgrade-30317 == *cfg* ]] ++ kubectl_bin get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.23ouFz9gwY +++ mktemp ++ local LAST_ERR=/tmp/tmp.n9WbHyR1B0 ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.23ouFz9gwY ++ cat /tmp/tmp.n9WbHyR1B0 ++ rm /tmp/tmp.23ouFz9gwY /tmp/tmp.n9WbHyR1B0 ++ return 0 + local client_container=psmdb-client-bb8b97679-p4ppf + kubectl_bin exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''db.createUser({user: "myApp", pwd: "myPass", roles: [{ db: "myApp", role: "readWrite" }]})\n'\'' | mongo mongodb+srv://userAdmin:userAdmin123456@upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' ++ mktemp + local LAST_OUT=/tmp/tmp.3qbuGn3vUJ ++ mktemp + local LAST_ERR=/tmp/tmp.rCNA2OV7Yo + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''db.createUser({user: "myApp", pwd: "myPass", roles: [{ db: "myApp", role: "readWrite" }]})\n'\'' | mongo mongodb+srv://userAdmin:userAdmin123456@upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.3qbuGn3vUJ Percona Server for MongoDB shell version v4.4.29-28 connecting to: mongodb://upgrade-rs0-2.upgrade-rs0.upgrade-30317.svc.cluster.local:27017,upgrade-rs0-0.upgrade-rs0.upgrade-30317.svc.cluster.local:27017,upgrade-rs0-1.upgrade-rs0.upgrade-30317.svc.cluster.local:27017/admin?compressors=disabled&gssapiServiceName=mongodb&replicaSet=rs0&ssl=false Implicit session: session { "id" : UUID("4541648e-ea72-41d7-8e1e-2091892877c2") } Percona Server for MongoDB server version: v8.0.19-7 WARNING: shell and server versions do not match Successfully added user: { "user" : "myApp", "roles" : [ { "db" : "myApp", "role" : "readWrite" } ] } bye + cat /tmp/tmp.rCNA2OV7Yo + rm /tmp/tmp.3qbuGn3vUJ /tmp/tmp.rCNA2OV7Yo + return 0 + desc 'write data' + set +o xtrace ----------------------------------------------------------------------------------- write data ----------------------------------------------------------------------------------- + run_mongo 'use myApp\n db.test.insert({ x: 100500 })' myApp:myPass@upgrade-rs0.upgrade-30317 + local 'command=use myApp\n db.test.insert({ x: 100500 })' + local uri=myApp:myPass@upgrade-rs0.upgrade-30317 + local driver=mongodb+srv + local suffix=.svc.cluster.local + local mongo_flag= + local replica_set=rs0 + [[ myApp:myPass@upgrade-rs0.upgrade-30317 == *cfg* ]] ++ kubectl_bin get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.ohrQals7gG +++ mktemp ++ local LAST_ERR=/tmp/tmp.0dONgHTahH ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.ohrQals7gG ++ cat /tmp/tmp.0dONgHTahH ++ rm /tmp/tmp.ohrQals7gG /tmp/tmp.0dONgHTahH ++ return 0 + local client_container=psmdb-client-bb8b97679-p4ppf + kubectl_bin exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.insert({ x: 100500 })\n'\'' | mongo mongodb+srv://myApp:myPass@upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' ++ mktemp + local LAST_OUT=/tmp/tmp.te1xpKFft8 ++ mktemp + local LAST_ERR=/tmp/tmp.mrYQqyRgg0 + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.insert({ x: 100500 })\n'\'' | mongo mongodb+srv://myApp:myPass@upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.te1xpKFft8 Percona Server for MongoDB shell version v4.4.29-28 connecting to: mongodb://upgrade-rs0-1.upgrade-rs0.upgrade-30317.svc.cluster.local:27017,upgrade-rs0-2.upgrade-rs0.upgrade-30317.svc.cluster.local:27017,upgrade-rs0-0.upgrade-rs0.upgrade-30317.svc.cluster.local:27017/admin?compressors=disabled&gssapiServiceName=mongodb&replicaSet=rs0&ssl=false Implicit session: session { "id" : UUID("7f984101-99d0-4847-adc9-2f5a827ef01d") } Percona Server for MongoDB server version: v8.0.19-7 WARNING: shell and server versions do not match switched to db myApp WriteResult({ "nInserted" : 1 }) bye + cat /tmp/tmp.mrYQqyRgg0 + rm /tmp/tmp.te1xpKFft8 /tmp/tmp.mrYQqyRgg0 + return 0 + desc 'check if cr and statefulset created with expected config' + set +o xtrace ----------------------------------------------------------------------------------- check if cr and statefulset created with expected config ----------------------------------------------------------------------------------- + compare_generation 1 statefulset upgrade-rs0 + local generation=1 + local resource=statefulset + local name=upgrade-rs0 + local current_generation ++ kubectl_bin get statefulset upgrade-rs0 -o 'jsonpath={.metadata.generation}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.fEegAzJDKw +++ mktemp ++ local LAST_ERR=/tmp/tmp.3yj9yZDhkg ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get statefulset upgrade-rs0 -o 'jsonpath={.metadata.generation}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.fEegAzJDKw ++ cat /tmp/tmp.3yj9yZDhkg ++ rm /tmp/tmp.fEegAzJDKw /tmp/tmp.3yj9yZDhkg ++ return 0 + current_generation=1 + [[ 1 != 1 ]] + compare_generation 1 psmdb upgrade + local generation=1 + local resource=psmdb + local name=upgrade + local current_generation ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.metadata.generation}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.JuFFCGl4Xh +++ mktemp ++ local LAST_ERR=/tmp/tmp.Gh9pQVT7n5 ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.metadata.generation}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.JuFFCGl4Xh ++ cat /tmp/tmp.Gh9pQVT7n5 ++ rm /tmp/tmp.JuFFCGl4Xh /tmp/tmp.Gh9pQVT7n5 ++ return 0 + current_generation=1 + [[ 1 != 1 ]] + desc 'create backup ' + set +o xtrace ----------------------------------------------------------------------------------- create backup ----------------------------------------------------------------------------------- + backup_name_minio=backup-minio + run_backup minio + local storage=minio + local backup_name=backup-minio + local type=logical + log 'running backup backup-minio' + set +o xtrace [2026-06-09T11:01:59+0000] running backup backup-minio + yq eval $'.metadata.name = "backup-minio"\n\t\t\t| .spec.storageName = "minio"\n\t\t\t| .spec.type = "logical"' /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/upgrade/conf/backup-minio.yml + kubectl_bin apply -f - ++ mktemp + local LAST_OUT=/tmp/tmp.a77Za8ErGw ++ mktemp + local LAST_ERR=/tmp/tmp.utgqXBIpfW + 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.a77Za8ErGw perconaservermongodbbackup.psmdb.percona.com/backup-minio created + cat /tmp/tmp.utgqXBIpfW + rm /tmp/tmp.a77Za8ErGw /tmp/tmp.utgqXBIpfW + return 0 + wait_backup backup-minio + local backup_name=backup-minio + local target_state=ready + set +o xtrace waiting for backup-minio to reach ready state....OK + desc 'upgrade operator' + set +o xtrace ----------------------------------------------------------------------------------- upgrade operator ----------------------------------------------------------------------------------- + kubectl_bin apply --server-side --force-conflicts -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/deploy/crd.yaml ++ mktemp + local LAST_OUT=/tmp/tmp.6nzaejf5P2 ++ mktemp + local LAST_ERR=/tmp/tmp.PeR9DYyLMq + 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-2058/deploy/crd.yaml + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.6nzaejf5P2 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.PeR9DYyLMq + rm /tmp/tmp.6nzaejf5P2 /tmp/tmp.PeR9DYyLMq + return 0 + kubectl_bin apply -f /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/deploy/cw-rbac.yaml -n psmdb-operator ++ mktemp + local LAST_OUT=/tmp/tmp.XlWA7chMcE ++ mktemp + local LAST_ERR=/tmp/tmp.MYkhNO528A + 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-2058/deploy/cw-rbac.yaml -n psmdb-operator + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.XlWA7chMcE clusterrole.rbac.authorization.k8s.io/percona-server-mongodb-operator configured serviceaccount/percona-server-mongodb-operator unchanged clusterrolebinding.rbac.authorization.k8s.io/service-account-percona-server-mongodb-operator unchanged + cat /tmp/tmp.MYkhNO528A + rm /tmp/tmp.XlWA7chMcE /tmp/tmp.MYkhNO528A + return 0 + kubectl_bin patch deployment percona-server-mongodb-operator '-p{"spec":{"template":{"spec":{"containers":[{"name":"percona-server-mongodb-operator","image":"docker.io/perconalab/percona-server-mongodb-operator:PR-2058-fb8cc7187"}]}}}}' -n psmdb-operator ++ mktemp + local LAST_OUT=/tmp/tmp.MKLtdGUINn ++ mktemp + local LAST_ERR=/tmp/tmp.Livb8ovgD4 + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl patch deployment percona-server-mongodb-operator '-p{"spec":{"template":{"spec":{"containers":[{"name":"percona-server-mongodb-operator","image":"docker.io/perconalab/percona-server-mongodb-operator:PR-2058-fb8cc7187"}]}}}}' -n psmdb-operator + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.MKLtdGUINn deployment.apps/percona-server-mongodb-operator patched + cat /tmp/tmp.Livb8ovgD4 + rm /tmp/tmp.MKLtdGUINn /tmp/tmp.Livb8ovgD4 + return 0 + kubectl_bin rollout status deployment/percona-server-mongodb-operator -n psmdb-operator ++ mktemp + local LAST_OUT=/tmp/tmp.6mokt33KkH ++ mktemp + local LAST_ERR=/tmp/tmp.ipJkCUmjXn + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl rollout status deployment/percona-server-mongodb-operator -n psmdb-operator + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.6mokt33KkH Waiting for deployment "percona-server-mongodb-operator" rollout to finish: 1 old replicas are pending termination... Waiting for deployment "percona-server-mongodb-operator" rollout to finish: 1 old replicas are pending termination... deployment "percona-server-mongodb-operator" successfully rolled out + cat /tmp/tmp.ipJkCUmjXn + rm /tmp/tmp.6mokt33KkH /tmp/tmp.ipJkCUmjXn + return 0 + desc 'wait for operator upgrade' + set +o xtrace ----------------------------------------------------------------------------------- wait for operator upgrade ----------------------------------------------------------------------------------- ++ kubectl_bin get pods -n psmdb-operator --selector=name=percona-server-mongodb-operator -o 'custom-columns=NAME:.metadata.name,IMAGE:.spec.containers[0].image' ++ grep -vc NAME ++ awk '{print $1}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.vD4Xpb0oZ0 +++ mktemp ++ local LAST_ERR=/tmp/tmp.7CYCP8iXQf ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods -n psmdb-operator --selector=name=percona-server-mongodb-operator -o 'custom-columns=NAME:.metadata.name,IMAGE:.spec.containers[0].image' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.vD4Xpb0oZ0 ++ cat /tmp/tmp.7CYCP8iXQf ++ rm /tmp/tmp.vD4Xpb0oZ0 /tmp/tmp.7CYCP8iXQf ++ return 0 + [[ 1 -eq 1 ]] + sleep 10 + desc 'check images and generation after operator upgrade' + set +o xtrace ----------------------------------------------------------------------------------- check images and generation after operator upgrade ----------------------------------------------------------------------------------- + wait_for_running upgrade-rs0 3 + local name=upgrade-rs0 + let last_pod=2 + local check_cluster_readyness=true + set_debug + [[ 1 == 1 ]] + set -o xtrace + local rs_name=rs0 + local cluster_name=upgrade ++ seq 0 2 + for i in $(seq 0 $last_pod) + [[ 0 -eq 2 ]] + wait_pod upgrade-rs0-0 + local pod=upgrade-rs0-0 + set +o xtrace waiting for pod/upgrade-rs0-0 to be ready.OK + for i in $(seq 0 $last_pod) + [[ 1 -eq 2 ]] + wait_pod upgrade-rs0-1 + local pod=upgrade-rs0-1 + set +o xtrace waiting for pod/upgrade-rs0-1 to be ready.OK + for i in $(seq 0 $last_pod) + [[ 2 -eq 2 ]] ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].arbiter.enabled}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.VSpSdUDJqq +++ mktemp ++ local LAST_ERR=/tmp/tmp.jV5WUYAkcV ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].arbiter.enabled}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.VSpSdUDJqq ++ cat /tmp/tmp.jV5WUYAkcV ++ rm /tmp/tmp.VSpSdUDJqq /tmp/tmp.jV5WUYAkcV ++ return 0 + [[ false == true ]] + wait_pod upgrade-rs0-2 + local pod=upgrade-rs0-2 + set +o xtrace waiting for pod/upgrade-rs0-2 to be ready.OK ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].nonvoting.enabled}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.9ek2Zr87yS +++ mktemp ++ local LAST_ERR=/tmp/tmp.e2aZNebZZ9 ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].nonvoting.enabled}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.9ek2Zr87yS ++ cat /tmp/tmp.e2aZNebZZ9 ++ rm /tmp/tmp.9ek2Zr87yS /tmp/tmp.e2aZNebZZ9 ++ return 0 + [[ false == true ]] ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].hidden.enabled}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.TWH9EXudjl +++ mktemp ++ local LAST_ERR=/tmp/tmp.calAOjvqjw ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].hidden.enabled}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.TWH9EXudjl ++ cat /tmp/tmp.calAOjvqjw ++ rm /tmp/tmp.TWH9EXudjl /tmp/tmp.calAOjvqjw ++ return 0 + [[ false == true ]] + sleep 10 + [[ true == true ]] + set +x Waiting for cluster readyness + check_applied_images operator + local updated_image=operator + case "${updated_image}" in ++ kubectl_bin get pod -n psmdb-operator --selector=name=percona-server-mongodb-operator -o 'jsonpath={.items[*].spec.containers[?(@.name == "percona-server-mongodb-operator")].image}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.qeoOd1v2hl +++ mktemp ++ local LAST_ERR=/tmp/tmp.nvbaPF0XPf ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pod -n psmdb-operator --selector=name=percona-server-mongodb-operator -o 'jsonpath={.items[*].spec.containers[?(@.name == "percona-server-mongodb-operator")].image}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.qeoOd1v2hl ++ cat /tmp/tmp.nvbaPF0XPf ++ rm /tmp/tmp.qeoOd1v2hl /tmp/tmp.nvbaPF0XPf ++ return 0 + [[ docker.io/perconalab/percona-server-mongodb-operator:PR-2058-fb8cc7187 == docker.io/perconalab/percona-server-mongodb-operator:PR-2058-fb8cc7187 ]] ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.backup.image}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.UHywZd7tib +++ mktemp ++ local LAST_ERR=/tmp/tmp.v7vBv1UGat ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.backup.image}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.UHywZd7tib ++ cat /tmp/tmp.v7vBv1UGat ++ rm /tmp/tmp.UHywZd7tib /tmp/tmp.v7vBv1UGat ++ return 0 + [[ docker.io/percona/percona-backup-mongodb:2.12.0 == docker.io/percona/percona-backup-mongodb:2.12.0 ]] ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.pmm.image}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.zDleFSmoWq +++ mktemp ++ local LAST_ERR=/tmp/tmp.zs77t1Dji3 ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.pmm.image}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.zDleFSmoWq ++ cat /tmp/tmp.zs77t1Dji3 ++ rm /tmp/tmp.zDleFSmoWq /tmp/tmp.zs77t1Dji3 ++ return 0 + [[ docker.io/percona/pmm-client:2.44.1-1 docker.io/percona/pmm-client:3.6.0 == docker.io/percona/pmm-client:2.44.1-1 docker.io/percona/pmm-client:3.6.0 ]] ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.image}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.a6sagmaSdh +++ mktemp ++ local LAST_ERR=/tmp/tmp.Xm7yi0T9x3 ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.image}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.a6sagmaSdh ++ cat /tmp/tmp.Xm7yi0T9x3 ++ rm /tmp/tmp.a6sagmaSdh /tmp/tmp.Xm7yi0T9x3 ++ return 0 + [[ docker.io/percona/percona-server-mongodb:8.0.19-7 == docker.io/percona/percona-server-mongodb:8.0.19-7 ]] + : Operator image has been updated correctly + compare_generation 1 statefulset upgrade-rs0 + local generation=1 + local resource=statefulset + local name=upgrade-rs0 + local current_generation ++ kubectl_bin get statefulset upgrade-rs0 -o 'jsonpath={.metadata.generation}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.o6Cls0Eb5Q +++ mktemp ++ local LAST_ERR=/tmp/tmp.QiQzkBjjTL ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get statefulset upgrade-rs0 -o 'jsonpath={.metadata.generation}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.o6Cls0Eb5Q ++ cat /tmp/tmp.QiQzkBjjTL ++ rm /tmp/tmp.o6Cls0Eb5Q /tmp/tmp.QiQzkBjjTL ++ return 0 + current_generation=1 + [[ 1 != 1 ]] + compare_generation 1 psmdb upgrade + local generation=1 + local resource=psmdb + local name=upgrade + local current_generation ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.metadata.generation}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.lvIfwpFTPq +++ mktemp ++ local LAST_ERR=/tmp/tmp.ZeZWKiIA2S ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.metadata.generation}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.lvIfwpFTPq ++ cat /tmp/tmp.ZeZWKiIA2S ++ rm /tmp/tmp.lvIfwpFTPq /tmp/tmp.ZeZWKiIA2S ++ return 0 + current_generation=1 + [[ 1 != 1 ]] + desc 'patch psmdb images and upgrade' + set +o xtrace ----------------------------------------------------------------------------------- patch psmdb images and upgrade ----------------------------------------------------------------------------------- + kubectl_bin patch psmdb upgrade --type=merge --patch $'{\n "spec": {\n "crVersion": "1.23.0",\n "image": "docker.io/perconalab/percona-server-mongodb-operator:main-mongod8.0",\n "pmm": { "image": "docker.io/percona/pmm-client:2.44.1-1" },\n "backup": { "image": "docker.io/perconalab/percona-server-mongodb-operator:main-backup" }\n }}' ++ mktemp + local LAST_OUT=/tmp/tmp.NtoX2Xpw0x ++ mktemp + local LAST_ERR=/tmp/tmp.kPVdYzKDTY + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl patch psmdb upgrade --type=merge --patch $'{\n "spec": {\n "crVersion": "1.23.0",\n "image": "docker.io/perconalab/percona-server-mongodb-operator:main-mongod8.0",\n "pmm": { "image": "docker.io/percona/pmm-client:2.44.1-1" },\n "backup": { "image": "docker.io/perconalab/percona-server-mongodb-operator:main-backup" }\n }}' + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.NtoX2Xpw0x perconaservermongodb.psmdb.percona.com/upgrade patched + cat /tmp/tmp.kPVdYzKDTY + rm /tmp/tmp.NtoX2Xpw0x /tmp/tmp.kPVdYzKDTY + return 0 + sleep 10 + desc 'check cluster after full upgrade' + set +o xtrace ----------------------------------------------------------------------------------- check cluster after full upgrade ----------------------------------------------------------------------------------- + wait_for_running upgrade-rs0 3 + local name=upgrade-rs0 + let last_pod=2 + local check_cluster_readyness=true + set_debug + [[ 1 == 1 ]] + set -o xtrace + local rs_name=rs0 + local cluster_name=upgrade ++ seq 0 2 + for i in $(seq 0 $last_pod) + [[ 0 -eq 2 ]] + wait_pod upgrade-rs0-0 + local pod=upgrade-rs0-0 + set +o xtrace waiting for pod/upgrade-rs0-0 to be ready.OK + for i in $(seq 0 $last_pod) + [[ 1 -eq 2 ]] + wait_pod upgrade-rs0-1 + local pod=upgrade-rs0-1 + set +o xtrace waiting for pod/upgrade-rs0-1 to be ready.OK + for i in $(seq 0 $last_pod) + [[ 2 -eq 2 ]] ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].arbiter.enabled}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.jOTxt0IvWN +++ mktemp ++ local LAST_ERR=/tmp/tmp.Usw3jPdUL2 ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].arbiter.enabled}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.jOTxt0IvWN ++ cat /tmp/tmp.Usw3jPdUL2 ++ rm /tmp/tmp.jOTxt0IvWN /tmp/tmp.Usw3jPdUL2 ++ return 0 + [[ false == true ]] + wait_pod upgrade-rs0-2 + local pod=upgrade-rs0-2 + set +o xtrace waiting for pod/upgrade-rs0-2 to be ready.OK ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].nonvoting.enabled}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.IpbsROKuxB +++ mktemp ++ local LAST_ERR=/tmp/tmp.v6TlQiafBc ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].nonvoting.enabled}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.IpbsROKuxB ++ cat /tmp/tmp.v6TlQiafBc ++ rm /tmp/tmp.IpbsROKuxB /tmp/tmp.v6TlQiafBc ++ return 0 + [[ false == true ]] ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].hidden.enabled}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.tfF1NJIJoA +++ mktemp ++ local LAST_ERR=/tmp/tmp.YSiWapPuQ9 ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.replsets[?(@.name=="rs0")].hidden.enabled}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.tfF1NJIJoA ++ cat /tmp/tmp.YSiWapPuQ9 ++ rm /tmp/tmp.tfF1NJIJoA /tmp/tmp.YSiWapPuQ9 ++ return 0 + [[ false == true ]] + sleep 10 + [[ true == true ]] + set +x Waiting for cluster readyness........................................... + wait_cluster_consistency upgrade + local retry=0 ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.status.state}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.AY5qHuCjAT +++ mktemp ++ local LAST_ERR=/tmp/tmp.oKcpQu2tVx ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.status.state}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.AY5qHuCjAT ++ cat /tmp/tmp.oKcpQu2tVx ++ rm /tmp/tmp.AY5qHuCjAT /tmp/tmp.oKcpQu2tVx ++ return 0 + [[ ready == ready ]] ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.status.replsets.rs0.ready}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.qcndYoxKnu +++ mktemp ++ local LAST_ERR=/tmp/tmp.bvQ6Rv8R4F ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.status.replsets.rs0.ready}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.qcndYoxKnu ++ cat /tmp/tmp.bvQ6Rv8R4F ++ rm /tmp/tmp.qcndYoxKnu /tmp/tmp.bvQ6Rv8R4F ++ return 0 + [[ 3 == 3 ]] + simple_data_check upgrade-rs0 3 + local cluster_name=upgrade-rs0 + let last_pod=3-1 + local isSharded=0 + local cluster_pfx= + '[' 0 -eq 1 ']' ++ seq 0 2 + for i in $(seq 0 $last_pod) + compare_mongo_cmd find myApp:myPass@upgrade-rs0-0.upgrade-rs0.upgrade-30317 + local command=find + local uri=myApp:myPass@upgrade-rs0-0.upgrade-rs0.upgrade-30317 + local postfix= + local suffix= + local database=myApp + local collection=test + local sort= + local tls=false + local replicaset= + local 'full_command=db.test.find()' + [[ -n '' ]] + log 'running db.test.find() in myApp' + set +o xtrace [2026-06-09T11:04:55+0000] running db.test.find() in myApp + [[ false == true ]] + mongo_command=run_mongo + run_mongo 'use myApp\n db.test.find()' myApp:myPass@upgrade-rs0-0.upgrade-rs0.upgrade-30317 mongodb '' '' + local 'command=use myApp\n db.test.find()' + local uri=myApp:myPass@upgrade-rs0-0.upgrade-rs0.upgrade-30317 + local driver=mongodb + local suffix=.svc.cluster.local + local mongo_flag= + local replica_set=rs0 + [[ myApp:myPass@upgrade-rs0-0.upgrade-rs0.upgrade-30317 == *cfg* ]] + grep -E -v 'I NETWORK|W NETWORK|F NETWORK|"c":"NETWORK"|Error saving history file|Percona Server for MongoDB|connecting to:|Unable to reach primary for set|Implicit session:|versions do not match|Error saving history file:|Started a new thread for the timer service' + /usr/sbin/sed -re 's/ObjectId\("[0-9a-f]+"\)//; s/-[0-9]+.svc/-xxx.svc/' ++ kubectl_bin get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.Gb0SIZsvvg +++ mktemp ++ local LAST_ERR=/tmp/tmp.2WFCVOUNy4 ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.Gb0SIZsvvg ++ cat /tmp/tmp.2WFCVOUNy4 ++ rm /tmp/tmp.Gb0SIZsvvg /tmp/tmp.2WFCVOUNy4 ++ return 0 + local client_container=psmdb-client-bb8b97679-p4ppf + kubectl_bin exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.find()\n'\'' | mongo mongodb://myApp:myPass@upgrade-rs0-0.upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' ++ mktemp + local LAST_OUT=/tmp/tmp.0DWxRERd7T ++ mktemp + local LAST_ERR=/tmp/tmp.WsCz2pMg6R + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.find()\n'\'' | mongo mongodb://myApp:myPass@upgrade-rs0-0.upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.0DWxRERd7T + cat /tmp/tmp.WsCz2pMg6R + rm /tmp/tmp.0DWxRERd7T /tmp/tmp.WsCz2pMg6R + return 0 + [[ 0 -eq 0 ]] + diff -u /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/upgrade/compare/find.json /tmp/tmp.uTQpXpxW6A/find + for i in $(seq 0 $last_pod) + compare_mongo_cmd find myApp:myPass@upgrade-rs0-1.upgrade-rs0.upgrade-30317 + local command=find + local uri=myApp:myPass@upgrade-rs0-1.upgrade-rs0.upgrade-30317 + local postfix= + local suffix= + local database=myApp + local collection=test + local sort= + local tls=false + local replicaset= + local 'full_command=db.test.find()' + [[ -n '' ]] + log 'running db.test.find() in myApp' + set +o xtrace [2026-06-09T11:04:58+0000] running db.test.find() in myApp + [[ false == true ]] + mongo_command=run_mongo + run_mongo 'use myApp\n db.test.find()' myApp:myPass@upgrade-rs0-1.upgrade-rs0.upgrade-30317 mongodb '' '' + local 'command=use myApp\n db.test.find()' + local uri=myApp:myPass@upgrade-rs0-1.upgrade-rs0.upgrade-30317 + local driver=mongodb + local suffix=.svc.cluster.local + local mongo_flag= + local replica_set=rs0 + [[ myApp:myPass@upgrade-rs0-1.upgrade-rs0.upgrade-30317 == *cfg* ]] + grep -E -v 'I NETWORK|W NETWORK|F NETWORK|"c":"NETWORK"|Error saving history file|Percona Server for MongoDB|connecting to:|Unable to reach primary for set|Implicit session:|versions do not match|Error saving history file:|Started a new thread for the timer service' ++ kubectl_bin get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' + /usr/sbin/sed -re 's/ObjectId\("[0-9a-f]+"\)//; s/-[0-9]+.svc/-xxx.svc/' +++ mktemp ++ local LAST_OUT=/tmp/tmp.8FFh6dftIJ +++ mktemp ++ local LAST_ERR=/tmp/tmp.ayFw9YhKZ6 ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.8FFh6dftIJ ++ cat /tmp/tmp.ayFw9YhKZ6 ++ rm /tmp/tmp.8FFh6dftIJ /tmp/tmp.ayFw9YhKZ6 ++ return 0 + local client_container=psmdb-client-bb8b97679-p4ppf + kubectl_bin exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.find()\n'\'' | mongo mongodb://myApp:myPass@upgrade-rs0-1.upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' ++ mktemp + local LAST_OUT=/tmp/tmp.kQE7WO8vIw ++ mktemp + local LAST_ERR=/tmp/tmp.8HC91zVQtq + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.find()\n'\'' | mongo mongodb://myApp:myPass@upgrade-rs0-1.upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.kQE7WO8vIw + cat /tmp/tmp.8HC91zVQtq + rm /tmp/tmp.kQE7WO8vIw /tmp/tmp.8HC91zVQtq + return 0 + [[ 0 -eq 0 ]] + diff -u /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/upgrade/compare/find.json /tmp/tmp.uTQpXpxW6A/find + for i in $(seq 0 $last_pod) + compare_mongo_cmd find myApp:myPass@upgrade-rs0-2.upgrade-rs0.upgrade-30317 + local command=find + local uri=myApp:myPass@upgrade-rs0-2.upgrade-rs0.upgrade-30317 + local postfix= + local suffix= + local database=myApp + local collection=test + local sort= + local tls=false + local replicaset= + local 'full_command=db.test.find()' + [[ -n '' ]] + log 'running db.test.find() in myApp' + set +o xtrace [2026-06-09T11:05:01+0000] running db.test.find() in myApp + [[ false == true ]] + mongo_command=run_mongo + run_mongo 'use myApp\n db.test.find()' myApp:myPass@upgrade-rs0-2.upgrade-rs0.upgrade-30317 mongodb '' '' + local 'command=use myApp\n db.test.find()' + local uri=myApp:myPass@upgrade-rs0-2.upgrade-rs0.upgrade-30317 + local driver=mongodb + local suffix=.svc.cluster.local + local mongo_flag= + local replica_set=rs0 + grep -E -v 'I NETWORK|W NETWORK|F NETWORK|"c":"NETWORK"|Error saving history file|Percona Server for MongoDB|connecting to:|Unable to reach primary for set|Implicit session:|versions do not match|Error saving history file:|Started a new thread for the timer service' + [[ myApp:myPass@upgrade-rs0-2.upgrade-rs0.upgrade-30317 == *cfg* ]] + /usr/sbin/sed -re 's/ObjectId\("[0-9a-f]+"\)//; s/-[0-9]+.svc/-xxx.svc/' ++ kubectl_bin get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.9Snan1EQAE +++ mktemp ++ local LAST_ERR=/tmp/tmp.Jhub8lNMWX ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.9Snan1EQAE ++ cat /tmp/tmp.Jhub8lNMWX ++ rm /tmp/tmp.9Snan1EQAE /tmp/tmp.Jhub8lNMWX ++ return 0 + local client_container=psmdb-client-bb8b97679-p4ppf + kubectl_bin exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.find()\n'\'' | mongo mongodb://myApp:myPass@upgrade-rs0-2.upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' ++ mktemp + local LAST_OUT=/tmp/tmp.JLsVsVkYtt ++ mktemp + local LAST_ERR=/tmp/tmp.xRqJTqq5DL + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.find()\n'\'' | mongo mongodb://myApp:myPass@upgrade-rs0-2.upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.JLsVsVkYtt + cat /tmp/tmp.xRqJTqq5DL + rm /tmp/tmp.JLsVsVkYtt /tmp/tmp.xRqJTqq5DL + return 0 + [[ 0 -eq 0 ]] + diff -u /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/upgrade/compare/find.json /tmp/tmp.uTQpXpxW6A/find + check_applied_images all + local updated_image=all + case "${updated_image}" in ++ kubectl_bin get pod -n psmdb-operator --selector=name=percona-server-mongodb-operator -o 'jsonpath={.items[*].spec.containers[?(@.name == "percona-server-mongodb-operator")].image}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.nUYoqB2lXW +++ mktemp ++ local LAST_ERR=/tmp/tmp.bTLxJe6CC7 ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pod -n psmdb-operator --selector=name=percona-server-mongodb-operator -o 'jsonpath={.items[*].spec.containers[?(@.name == "percona-server-mongodb-operator")].image}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.nUYoqB2lXW ++ cat /tmp/tmp.bTLxJe6CC7 ++ rm /tmp/tmp.nUYoqB2lXW /tmp/tmp.bTLxJe6CC7 ++ return 0 + [[ docker.io/perconalab/percona-server-mongodb-operator:PR-2058-fb8cc7187 == docker.io/perconalab/percona-server-mongodb-operator:PR-2058-fb8cc7187 ]] ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.backup.image}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.4GZeCF6RRA +++ mktemp ++ local LAST_ERR=/tmp/tmp.Xk2ohssgrg ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.backup.image}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.4GZeCF6RRA ++ cat /tmp/tmp.Xk2ohssgrg ++ rm /tmp/tmp.4GZeCF6RRA /tmp/tmp.Xk2ohssgrg ++ return 0 + [[ docker.io/perconalab/percona-server-mongodb-operator:main-backup == docker.io/perconalab/percona-server-mongodb-operator:main-backup ]] ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.pmm.image}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.TQuG3CBmBA +++ mktemp ++ local LAST_ERR=/tmp/tmp.dw7okj21bq ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.pmm.image}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.TQuG3CBmBA ++ cat /tmp/tmp.dw7okj21bq ++ rm /tmp/tmp.TQuG3CBmBA /tmp/tmp.dw7okj21bq ++ return 0 + [[ docker.io/percona/pmm-client:2.44.1-1 == docker.io/percona/pmm-client:2.44.1-1 ]] ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.spec.image}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.n4pbqVRu0T +++ mktemp ++ local LAST_ERR=/tmp/tmp.jBPJQ3Vx4R ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.spec.image}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.n4pbqVRu0T ++ cat /tmp/tmp.jBPJQ3Vx4R ++ rm /tmp/tmp.n4pbqVRu0T /tmp/tmp.jBPJQ3Vx4R ++ return 0 + [[ docker.io/perconalab/percona-server-mongodb-operator:main-mongod8.0 == docker.io/perconalab/percona-server-mongodb-operator:main-mongod8.0 ]] + : Cluster images have been updated correctly + compare_generation 2 statefulset upgrade-rs0 + local generation=2 + local resource=statefulset + local name=upgrade-rs0 + local current_generation ++ kubectl_bin get statefulset upgrade-rs0 -o 'jsonpath={.metadata.generation}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.RMj8U34eqx +++ mktemp ++ local LAST_ERR=/tmp/tmp.RwLp0GTOb0 ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get statefulset upgrade-rs0 -o 'jsonpath={.metadata.generation}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.RMj8U34eqx ++ cat /tmp/tmp.RwLp0GTOb0 ++ rm /tmp/tmp.RMj8U34eqx /tmp/tmp.RwLp0GTOb0 ++ return 0 + current_generation=2 + [[ 2 != 2 ]] + compare_generation 2 psmdb upgrade + local generation=2 + local resource=psmdb + local name=upgrade + local current_generation ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.metadata.generation}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.luEBdtPPuH +++ mktemp ++ local LAST_ERR=/tmp/tmp.KfXjZWuwzj ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.metadata.generation}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.luEBdtPPuH ++ cat /tmp/tmp.KfXjZWuwzj ++ rm /tmp/tmp.luEBdtPPuH /tmp/tmp.KfXjZWuwzj ++ return 0 + current_generation=2 + [[ 2 != 2 ]] + desc 'drop collection and do restore with new version' + set +o xtrace ----------------------------------------------------------------------------------- drop collection and do restore with new version ----------------------------------------------------------------------------------- + run_mongo 'use myApp\n db.test.drop()' myApp:myPass@upgrade-rs0.upgrade-30317 + local 'command=use myApp\n db.test.drop()' + local uri=myApp:myPass@upgrade-rs0.upgrade-30317 + local driver=mongodb+srv + local suffix=.svc.cluster.local + local mongo_flag= + local replica_set=rs0 + [[ myApp:myPass@upgrade-rs0.upgrade-30317 == *cfg* ]] ++ kubectl_bin get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.anqmPrmaSb +++ mktemp ++ local LAST_ERR=/tmp/tmp.ZcwuAhZqo0 ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.anqmPrmaSb ++ cat /tmp/tmp.ZcwuAhZqo0 ++ rm /tmp/tmp.anqmPrmaSb /tmp/tmp.ZcwuAhZqo0 ++ return 0 + local client_container=psmdb-client-bb8b97679-p4ppf + kubectl_bin exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.drop()\n'\'' | mongo mongodb+srv://myApp:myPass@upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' ++ mktemp + local LAST_OUT=/tmp/tmp.7tC3XGnOTp ++ mktemp + local LAST_ERR=/tmp/tmp.ZwDwaRqSLv + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.drop()\n'\'' | mongo mongodb+srv://myApp:myPass@upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.7tC3XGnOTp Percona Server for MongoDB shell version v4.4.29-28 connecting to: mongodb://upgrade-rs0-2.upgrade-rs0.upgrade-30317.svc.cluster.local:27017,upgrade-rs0-0.upgrade-rs0.upgrade-30317.svc.cluster.local:27017,upgrade-rs0-1.upgrade-rs0.upgrade-30317.svc.cluster.local:27017/admin?compressors=disabled&gssapiServiceName=mongodb&replicaSet=rs0&ssl=false Implicit session: session { "id" : UUID("d28015fa-8c77-4919-a056-384e08f4c531") } Percona Server for MongoDB server version: v8.0.23-10 WARNING: shell and server versions do not match switched to db myApp true bye + cat /tmp/tmp.ZwDwaRqSLv + rm /tmp/tmp.7tC3XGnOTp /tmp/tmp.ZwDwaRqSLv + return 0 + check_backup_in_storage backup-minio minio rs0 myApp.test.gz + local backup=backup-minio + local storage_type=minio + local replset=rs0 + local file=myApp.test.gz + local protocol=http + local endpoint ++ get_backup_dest backup-minio ++ local backup_name=backup-minio ++ /usr/sbin/sed 's|https://engk8soperators.blob.core.windows.net/||' ++ sed 's|azure://||' ++ sed -e 's/.json$//' ++ kubectl_bin get psmdb-backup backup-minio -o 'jsonpath={.status.destination}' ++ sed 's|s3://||' +++ mktemp ++ sed 's|gs://||' ++ local LAST_OUT=/tmp/tmp.aHzt6LqreC +++ mktemp ++ local LAST_ERR=/tmp/tmp.IbVK16h0dD ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb-backup backup-minio -o 'jsonpath={.status.destination}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.aHzt6LqreC ++ cat /tmp/tmp.IbVK16h0dD ++ rm /tmp/tmp.aHzt6LqreC /tmp/tmp.IbVK16h0dD ++ return 0 + backup_dest=operator-testing/2026-06-09T11:02:02Z + case ${storage_type} in + endpoint=minio-service + grep myApp.test.gz + kubectl_bin run -i --rm aws-cli --image=docker.io/perconalab/awscli --restart=Never -- /usr/bin/env AWS_ACCESS_KEY_ID=some-access-key AWS_SECRET_ACCESS_KEY=some-secret-key AWS_DEFAULT_REGION=us-east-1 /usr/bin/aws --no-verify-ssl --endpoint-url http://minio-service:9000 s3 ls s3://operator-testing/2026-06-09T11:02:02Z/rs0/myApp.test.gz ++ mktemp + local LAST_OUT=/tmp/tmp.eDVsRs2Baz ++ mktemp + local LAST_ERR=/tmp/tmp.zCaXdYWkMX + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl run -i --rm aws-cli --image=docker.io/perconalab/awscli --restart=Never -- /usr/bin/env AWS_ACCESS_KEY_ID=some-access-key AWS_SECRET_ACCESS_KEY=some-secret-key AWS_DEFAULT_REGION=us-east-1 /usr/bin/aws --no-verify-ssl --endpoint-url http://minio-service:9000 s3 ls s3://operator-testing/2026-06-09T11:02:02Z/rs0/myApp.test.gz + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.eDVsRs2Baz + cat /tmp/tmp.zCaXdYWkMX All commands and output from this session will be recorded in container logs, including credentials and sensitive information passed through the command prompt. If you don't see a command prompt, try pressing enter. + rm /tmp/tmp.eDVsRs2Baz /tmp/tmp.zCaXdYWkMX + return 0 2026-06-09 11:02:05 55 myApp.test.gz + run_mongo 'use myApp\n db.test.insert({ x: 100501 })' myApp:myPass@upgrade-rs0.upgrade-30317 + local 'command=use myApp\n db.test.insert({ x: 100501 })' + local uri=myApp:myPass@upgrade-rs0.upgrade-30317 + local driver=mongodb+srv + local suffix=.svc.cluster.local + local mongo_flag= + local replica_set=rs0 + [[ myApp:myPass@upgrade-rs0.upgrade-30317 == *cfg* ]] ++ kubectl_bin get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.BDz2u0J5af +++ mktemp ++ local LAST_ERR=/tmp/tmp.n8bCwyCP7O ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.BDz2u0J5af ++ cat /tmp/tmp.n8bCwyCP7O ++ rm /tmp/tmp.BDz2u0J5af /tmp/tmp.n8bCwyCP7O ++ return 0 + local client_container=psmdb-client-bb8b97679-p4ppf + kubectl_bin exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.insert({ x: 100501 })\n'\'' | mongo mongodb+srv://myApp:myPass@upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' ++ mktemp + local LAST_OUT=/tmp/tmp.Jh2IKjBHem ++ mktemp + local LAST_ERR=/tmp/tmp.A1V1LmH2ru + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.insert({ x: 100501 })\n'\'' | mongo mongodb+srv://myApp:myPass@upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.Jh2IKjBHem Percona Server for MongoDB shell version v4.4.29-28 connecting to: mongodb://upgrade-rs0-2.upgrade-rs0.upgrade-30317.svc.cluster.local:27017,upgrade-rs0-0.upgrade-rs0.upgrade-30317.svc.cluster.local:27017,upgrade-rs0-1.upgrade-rs0.upgrade-30317.svc.cluster.local:27017/admin?compressors=disabled&gssapiServiceName=mongodb&replicaSet=rs0&ssl=false Implicit session: session { "id" : UUID("59043a61-2c67-428e-9a2b-5a5b966cd877") } Percona Server for MongoDB server version: v8.0.23-10 WARNING: shell and server versions do not match switched to db myApp WriteResult({ "nInserted" : 1 }) bye + cat /tmp/tmp.A1V1LmH2ru + rm /tmp/tmp.Jh2IKjBHem /tmp/tmp.A1V1LmH2ru + return 0 + compare_mongo_cmd find myApp:myPass@upgrade-rs0.upgrade-30317 -2nd .svc.cluster.local myApp test + local command=find + local uri=myApp:myPass@upgrade-rs0.upgrade-30317 + local postfix=-2nd + local suffix=.svc.cluster.local + local database=myApp + local collection=test + local sort= + local tls=false + local replicaset= + local 'full_command=db.test.find()' + [[ -n '' ]] + log 'running db.test.find() in myApp' + set +o xtrace [2026-06-09T11:05:21+0000] running db.test.find() in myApp + [[ false == true ]] + mongo_command=run_mongo + run_mongo 'use myApp\n db.test.find()' myApp:myPass@upgrade-rs0.upgrade-30317 mongodb .svc.cluster.local '' + local 'command=use myApp\n db.test.find()' + local uri=myApp:myPass@upgrade-rs0.upgrade-30317 + local driver=mongodb + local suffix=.svc.cluster.local + local mongo_flag= + local replica_set=rs0 + [[ myApp:myPass@upgrade-rs0.upgrade-30317 == *cfg* ]] + grep -E -v 'I NETWORK|W NETWORK|F NETWORK|"c":"NETWORK"|Error saving history file|Percona Server for MongoDB|connecting to:|Unable to reach primary for set|Implicit session:|versions do not match|Error saving history file:|Started a new thread for the timer service' + /usr/sbin/sed -re 's/ObjectId\("[0-9a-f]+"\)//; s/-[0-9]+.svc/-xxx.svc/' ++ kubectl_bin get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.KPLwkcyvih +++ mktemp ++ local LAST_ERR=/tmp/tmp.raCMGyGizt ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.KPLwkcyvih ++ cat /tmp/tmp.raCMGyGizt ++ rm /tmp/tmp.KPLwkcyvih /tmp/tmp.raCMGyGizt ++ return 0 + local client_container=psmdb-client-bb8b97679-p4ppf + kubectl_bin exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.find()\n'\'' | mongo mongodb://myApp:myPass@upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' ++ mktemp + local LAST_OUT=/tmp/tmp.KLfeMZjYnq ++ mktemp + local LAST_ERR=/tmp/tmp.CBFNZHZ1fB + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.find()\n'\'' | mongo mongodb://myApp:myPass@upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.KLfeMZjYnq + cat /tmp/tmp.CBFNZHZ1fB + rm /tmp/tmp.KLfeMZjYnq /tmp/tmp.CBFNZHZ1fB + return 0 + [[ 0 -eq 0 ]] + diff -u /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/upgrade/compare/find-2nd.json /tmp/tmp.uTQpXpxW6A/find-2nd + run_restore backup-minio + local backup_name=backup-minio + local restore_file=/mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/upgrade/conf/restore.yml + log 'running restore restore-backup-minio' + set +o xtrace [2026-06-09T11:05:23+0000] running restore restore-backup-minio + cat /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/upgrade/conf/restore.yml + /usr/sbin/sed -e 's/name:/name: restore-backup-minio/' + /usr/sbin/sed -e 's/backupName:/backupName: backup-minio/' + kubectl_bin apply -f - ++ mktemp + local LAST_OUT=/tmp/tmp.IZntmzUtbc ++ mktemp + local LAST_ERR=/tmp/tmp.xN0OCVRHYc + 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.IZntmzUtbc perconaservermongodbrestore.psmdb.percona.com/restore-backup-minio created + cat /tmp/tmp.xN0OCVRHYc + rm /tmp/tmp.IZntmzUtbc /tmp/tmp.xN0OCVRHYc + return 0 + wait_restore backup-minio upgrade + local backup_name=backup-minio + local cluster_name=upgrade + local target_state=ready + local wait_cluster_consistency=1 + local wait_time=1780 + local ok_if_ready=0 + set +o xtrace Waiting for the psmdb-restore/restore-backup-minio object to be created.OK Waiting psmdb-restore/restore-backup-minio to reach state "ready" .OK after 0 minutes + [[ 1 -eq 1 ]] + wait_cluster_consistency upgrade + local retry=0 ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.status.state}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.Q6pxzgzjfA +++ mktemp ++ local LAST_ERR=/tmp/tmp.wt3bQnNaxn ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.status.state}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.Q6pxzgzjfA ++ cat /tmp/tmp.wt3bQnNaxn ++ rm /tmp/tmp.Q6pxzgzjfA /tmp/tmp.wt3bQnNaxn ++ return 0 + [[ ready == ready ]] ++ kubectl_bin get psmdb upgrade -o 'jsonpath={.status.replsets.rs0.ready}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.iPOZ1yv1H1 +++ mktemp ++ local LAST_ERR=/tmp/tmp.SMr7io0Y20 ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get psmdb upgrade -o 'jsonpath={.status.replsets.rs0.ready}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.iPOZ1yv1H1 ++ cat /tmp/tmp.SMr7io0Y20 ++ rm /tmp/tmp.iPOZ1yv1H1 /tmp/tmp.SMr7io0Y20 ++ return 0 + [[ 3 == 3 ]] + simple_data_check upgrade-rs0 3 + local cluster_name=upgrade-rs0 + let last_pod=3-1 + local isSharded=0 + local cluster_pfx= + '[' 0 -eq 1 ']' ++ seq 0 2 + for i in $(seq 0 $last_pod) + compare_mongo_cmd find myApp:myPass@upgrade-rs0-0.upgrade-rs0.upgrade-30317 + local command=find + local uri=myApp:myPass@upgrade-rs0-0.upgrade-rs0.upgrade-30317 + local postfix= + local suffix= + local database=myApp + local collection=test + local sort= + local tls=false + local replicaset= + local 'full_command=db.test.find()' + [[ -n '' ]] + log 'running db.test.find() in myApp' + set +o xtrace [2026-06-09T11:05:44+0000] running db.test.find() in myApp + [[ false == true ]] + mongo_command=run_mongo + run_mongo 'use myApp\n db.test.find()' myApp:myPass@upgrade-rs0-0.upgrade-rs0.upgrade-30317 mongodb '' '' + local 'command=use myApp\n db.test.find()' + local uri=myApp:myPass@upgrade-rs0-0.upgrade-rs0.upgrade-30317 + local driver=mongodb + local suffix=.svc.cluster.local + local mongo_flag= + local replica_set=rs0 + [[ myApp:myPass@upgrade-rs0-0.upgrade-rs0.upgrade-30317 == *cfg* ]] + grep -E -v 'I NETWORK|W NETWORK|F NETWORK|"c":"NETWORK"|Error saving history file|Percona Server for MongoDB|connecting to:|Unable to reach primary for set|Implicit session:|versions do not match|Error saving history file:|Started a new thread for the timer service' + /usr/sbin/sed -re 's/ObjectId\("[0-9a-f]+"\)//; s/-[0-9]+.svc/-xxx.svc/' ++ kubectl_bin get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.KDGUbSyrD4 +++ mktemp ++ local LAST_ERR=/tmp/tmp.1UvqCjlPOj ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.KDGUbSyrD4 ++ cat /tmp/tmp.1UvqCjlPOj ++ rm /tmp/tmp.KDGUbSyrD4 /tmp/tmp.1UvqCjlPOj ++ return 0 + local client_container=psmdb-client-bb8b97679-p4ppf + kubectl_bin exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.find()\n'\'' | mongo mongodb://myApp:myPass@upgrade-rs0-0.upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' ++ mktemp + local LAST_OUT=/tmp/tmp.mo0SDLaMA6 ++ mktemp + local LAST_ERR=/tmp/tmp.s2KPy3KDHN + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.find()\n'\'' | mongo mongodb://myApp:myPass@upgrade-rs0-0.upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.mo0SDLaMA6 + cat /tmp/tmp.s2KPy3KDHN + rm /tmp/tmp.mo0SDLaMA6 /tmp/tmp.s2KPy3KDHN + return 0 + [[ 0 -eq 0 ]] + diff -u /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/upgrade/compare/find.json /tmp/tmp.uTQpXpxW6A/find + for i in $(seq 0 $last_pod) + compare_mongo_cmd find myApp:myPass@upgrade-rs0-1.upgrade-rs0.upgrade-30317 + local command=find + local uri=myApp:myPass@upgrade-rs0-1.upgrade-rs0.upgrade-30317 + local postfix= + local suffix= + local database=myApp + local collection=test + local sort= + local tls=false + local replicaset= + local 'full_command=db.test.find()' + [[ -n '' ]] + log 'running db.test.find() in myApp' + set +o xtrace [2026-06-09T11:05:46+0000] running db.test.find() in myApp + [[ false == true ]] + mongo_command=run_mongo + run_mongo 'use myApp\n db.test.find()' myApp:myPass@upgrade-rs0-1.upgrade-rs0.upgrade-30317 mongodb '' '' + local 'command=use myApp\n db.test.find()' + local uri=myApp:myPass@upgrade-rs0-1.upgrade-rs0.upgrade-30317 + local driver=mongodb + local suffix=.svc.cluster.local + local mongo_flag= + local replica_set=rs0 + [[ myApp:myPass@upgrade-rs0-1.upgrade-rs0.upgrade-30317 == *cfg* ]] + grep -E -v 'I NETWORK|W NETWORK|F NETWORK|"c":"NETWORK"|Error saving history file|Percona Server for MongoDB|connecting to:|Unable to reach primary for set|Implicit session:|versions do not match|Error saving history file:|Started a new thread for the timer service' + /usr/sbin/sed -re 's/ObjectId\("[0-9a-f]+"\)//; s/-[0-9]+.svc/-xxx.svc/' ++ kubectl_bin get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.3D99kkqH5I +++ mktemp ++ local LAST_ERR=/tmp/tmp.92YG5E6Eoi ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.3D99kkqH5I ++ cat /tmp/tmp.92YG5E6Eoi ++ rm /tmp/tmp.3D99kkqH5I /tmp/tmp.92YG5E6Eoi ++ return 0 + local client_container=psmdb-client-bb8b97679-p4ppf + kubectl_bin exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.find()\n'\'' | mongo mongodb://myApp:myPass@upgrade-rs0-1.upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' ++ mktemp + local LAST_OUT=/tmp/tmp.E8skP1GK0E ++ mktemp + local LAST_ERR=/tmp/tmp.PUR4hBMOsh + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.find()\n'\'' | mongo mongodb://myApp:myPass@upgrade-rs0-1.upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.E8skP1GK0E + cat /tmp/tmp.PUR4hBMOsh + rm /tmp/tmp.E8skP1GK0E /tmp/tmp.PUR4hBMOsh + return 0 + [[ 0 -eq 0 ]] + diff -u /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/upgrade/compare/find.json /tmp/tmp.uTQpXpxW6A/find + for i in $(seq 0 $last_pod) + compare_mongo_cmd find myApp:myPass@upgrade-rs0-2.upgrade-rs0.upgrade-30317 + local command=find + local uri=myApp:myPass@upgrade-rs0-2.upgrade-rs0.upgrade-30317 + local postfix= + local suffix= + local database=myApp + local collection=test + local sort= + local tls=false + local replicaset= + local 'full_command=db.test.find()' + [[ -n '' ]] + log 'running db.test.find() in myApp' + set +o xtrace [2026-06-09T11:05:49+0000] running db.test.find() in myApp + [[ false == true ]] + mongo_command=run_mongo + run_mongo 'use myApp\n db.test.find()' myApp:myPass@upgrade-rs0-2.upgrade-rs0.upgrade-30317 mongodb '' '' + local 'command=use myApp\n db.test.find()' + grep -E -v 'I NETWORK|W NETWORK|F NETWORK|"c":"NETWORK"|Error saving history file|Percona Server for MongoDB|connecting to:|Unable to reach primary for set|Implicit session:|versions do not match|Error saving history file:|Started a new thread for the timer service' + local uri=myApp:myPass@upgrade-rs0-2.upgrade-rs0.upgrade-30317 + local driver=mongodb + /usr/sbin/sed -re 's/ObjectId\("[0-9a-f]+"\)//; s/-[0-9]+.svc/-xxx.svc/' + local suffix=.svc.cluster.local + local mongo_flag= + local replica_set=rs0 + [[ myApp:myPass@upgrade-rs0-2.upgrade-rs0.upgrade-30317 == *cfg* ]] ++ kubectl_bin get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' +++ mktemp ++ local LAST_OUT=/tmp/tmp.cm4bSB6SAv +++ mktemp ++ local LAST_ERR=/tmp/tmp.LK1LZMlrSG ++ local exit_status=0 ++ local timeout=4 +++ seq 0 2 ++ for i in $(seq 0 2) ++ set +e ++ kubectl get pods --selector=name=psmdb-client -o 'jsonpath={.items[].metadata.name}' ++ exit_status=0 ++ set -e ++ '[' 0 '!=' 0 -a -n 1 ']' ++ break ++ cat /tmp/tmp.cm4bSB6SAv ++ cat /tmp/tmp.LK1LZMlrSG ++ rm /tmp/tmp.cm4bSB6SAv /tmp/tmp.LK1LZMlrSG ++ return 0 + local client_container=psmdb-client-bb8b97679-p4ppf + kubectl_bin exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.find()\n'\'' | mongo mongodb://myApp:myPass@upgrade-rs0-2.upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' ++ mktemp + local LAST_OUT=/tmp/tmp.IrMWJshvIq ++ mktemp + local LAST_ERR=/tmp/tmp.jRG2by5qPr + local exit_status=0 + local timeout=4 ++ seq 0 2 + for i in $(seq 0 2) + set +e + kubectl exec psmdb-client-bb8b97679-p4ppf -- bash -c 'printf '\''use myApp\n db.test.find()\n'\'' | mongo mongodb://myApp:myPass@upgrade-rs0-2.upgrade-rs0.upgrade-30317.svc.cluster.local/admin?ssl=false\&replicaSet=rs0 ' + exit_status=0 + set -e + '[' 0 '!=' 0 -a -n 1 ']' + break + cat /tmp/tmp.IrMWJshvIq + cat /tmp/tmp.jRG2by5qPr + rm /tmp/tmp.IrMWJshvIq /tmp/tmp.jRG2by5qPr + return 0 + [[ 0 -eq 0 ]] + diff -u /mnt/jenkins/workspace/cloud-psmdb-operator_PR-2058/e2e-tests/upgrade/compare/find.json /tmp/tmp.uTQpXpxW6A/find + desc cleanup + set +o xtrace ----------------------------------------------------------------------------------- cleanup ----------------------------------------------------------------------------------- + destroy upgrade-30317 + local namespace=upgrade-30317 + local ignore_logs=true + [[ 1 == 1 ]] + echo 'SKIP_DELETE=1, not destroying upgrade-30317' SKIP_DELETE=1, not destroying upgrade-30317 + return + desc 'test passed' + set +o xtrace ----------------------------------------------------------------------------------- test passed -----------------------------------------------------------------------------------