Files
mongo/jstests/multiVersion/genericSetFCVUsage/2_test_launching_cluster.js

56 lines
1.6 KiB
JavaScript

//
// Tests launching multi-version ShardingTest clusters.
//
load('./jstests/multiVersion/libs/verify_versions.js');
(function() {
"use strict";
// Sharded cluster upgrade order: config servers -> shards -> mongos.
const mixedVersionsToCheck = [
{config: ["latest"], shard: ["last-lts", "latest"], mongos: ["last-lts"]},
{config: ["latest"], shard: ["last-continuous", "latest"], mongos: ["last-continuous"]},
];
for (let versions of mixedVersionsToCheck) {
jsTest.log("Testing mixed versions: " + tojson(versions));
// Set up a multi-version cluster
var st = new ShardingTest({
shards: 2,
mongos: 2,
other: {
mongosOptions: {binVersion: versions.mongos},
configOptions: {binVersion: versions.config},
shardOptions: {binVersion: versions.shard},
enableBalancer: true
}
});
var shards = [st.shard0, st.shard1];
var mongoses = [st.s0, st.s1];
var configs = [st.config0, st.config1, st.config2];
// Make sure we have hosts of all the different versions
var versionsFound = [];
for (var j = 0; j < shards.length; j++)
versionsFound.push(shards[j].getBinVersion());
assert.allBinVersions(versions.shard, versionsFound);
versionsFound = [];
for (var j = 0; j < mongoses.length; j++)
versionsFound.push(mongoses[j].getBinVersion());
assert.allBinVersions(versions.mongos, versionsFound);
versionsFound = [];
for (var j = 0; j < configs.length; j++)
versionsFound.push(configs[j].getBinVersion());
assert.allBinVersions(versions.config, versionsFound);
st.stop();
}
})();