diff options
author | Sara Golemon <sara.golemon@mongodb.com> | 2021-05-26 20:46:27 +0000 |
---|---|---|
committer | Evergreen Agent <no-reply@evergreen.mongodb.com> | 2021-06-22 15:38:29 +0000 |
commit | c68f2da49a906f37dc4c81370f87a9e036ac6378 (patch) | |
tree | 49abc99bc0266d787f4d879693093be4e499f5f9 | |
parent | 0752572374c79198dc9fce439a18e89ea3c7c328 (diff) | |
download | mongo-c68f2da49a906f37dc4c81370f87a9e036ac6378.tar.gz |
SERVER-57328 Make ReplSetTest.upgradeSet() tolerant of reelections
(cherry picked from commit 5ef956df508b16cbc15cd4360f74cdea0cab34d3)
-rw-r--r-- | jstests/multiVersion/libs/multi_rs.js | 9 |
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) { |