// // 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(); } })();