summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSara Golemon <sara.golemon@mongodb.com>2021-05-26 20:46:27 +0000
committerEvergreen Agent <no-reply@evergreen.mongodb.com>2021-06-22 15:38:29 +0000
commitc68f2da49a906f37dc4c81370f87a9e036ac6378 (patch)
tree49abc99bc0266d787f4d879693093be4e499f5f9
parent0752572374c79198dc9fce439a18e89ea3c7c328 (diff)
downloadmongo-c68f2da49a906f37dc4c81370f87a9e036ac6378.tar.gz
SERVER-57328 Make ReplSetTest.upgradeSet() tolerant of reelections
(cherry picked from commit 5ef956df508b16cbc15cd4360f74cdea0cab34d3)
-rw-r--r--jstests/multiVersion/libs/multi_rs.js9
1 files changed, 6 insertions, 3 deletions
diff --git a/jstests/multiVersion/libs/multi_rs.js b/jstests/multiVersion/libs/multi_rs.js
index 4fbb3ec82c3..ecdfb4e4687 100644
--- a/jstests/multiVersion/libs/multi_rs.js
+++ b/jstests/multiVersion/libs/multi_rs.js
@@ -31,9 +31,12 @@ ReplSetTest.prototype.upgradeSet = function(options, user, pwd) {
}
}
- assert.eq(
- this.getPrimary(), primary, "Primary changed unexpectedly after upgrading secondaries");
- this.upgradePrimary(primary, Object.assign({}, options), user, pwd);
+ if (this.getPrimary() == primary) {
+ this.upgradePrimary(primary, Object.assign({}, options), user, pwd);
+ } else {
+ // An election occured during upgrade, old primary is now a secondary.
+ this.upgradeMembers([primary], Object.assign({}, options), user, pwd);
+ }
};
function mergeNodeOptions(nodeOptions, options) {