Files
mongo/jstests/multiVersion/genericSetFCVUsage/upgrade_downgrade_sharded_cluster.js

158 lines
4.9 KiB
JavaScript

/**
* Verify that some metadata is properly changed after the upgrade and downgrade of a sharded
* cluster. More specifically:
*
* 1. Create a sharded cluster in replica set running an old binary version
* 2. Setup some data on cluster
* 3. Upgrade binaries and FCV of the cluster to the latest version
* 4. Verify the data consistency after the upgrade procedure
* 5. Downgrade binaries and FCV of the cluster to an old version
* 6. Verify the data consistency after the downgrade procedure
*/
(function() {
'use strict';
load('jstests/multiVersion/libs/multi_cluster.js'); // For upgradeCluster
load("jstests/libs/feature_flag_util.js");
const dbName = jsTestName();
function setupClusterAndDatabase(binVersion) {
const st = new ShardingTest({
mongos: 1,
config: 1,
shards: 2,
other: {
mongosOptions: {binVersion: binVersion},
configOptions: {binVersion: binVersion},
rsOptions: {
binVersion: binVersion,
},
rs: {nodes: 2},
}
});
st.configRS.awaitReplication();
assert.commandWorked(
st.s.adminCommand({enableSharding: dbName, primaryShard: st.shard0.shardName}));
return st;
}
function getNodeName(node) {
const info = node.adminCommand({hello: 1});
return info.setName + '_' + (info.secondary ? 'secondary' : 'primary');
}
function checkConfigVersionDoc() {
// TODO: SERVER-68889 remove this function once 7.0 becomes last LTS
const versionDoc = st.s.getCollection('config.version').findOne();
if (FeatureFlagUtil.isEnabled(st.s, "StopUsingConfigVersion")) {
// Check that the version doc doesn't contain any of the deprecatedFields
const deprecatedFields = [
"excluding",
"upgradeId",
"upgradeState",
"currentVersion",
"minCompatibleVersion",
];
deprecatedFields.forEach(deprecatedField => {
assert(!versionDoc.hasOwnProperty(deprecatedField),
`Found deprecated field '${deprecatedField}' in version document ${
tojson(versionDoc)}`);
});
} else {
assert.eq(versionDoc.minCompatibleVersion,
5,
"Version doc does not contain expected value for minCompatibleVersion field");
assert.eq(versionDoc.currentVersion,
6,
"Version doc does not contain expected value for currentVersion field");
}
}
function checkConfigAndShardsFCV(expectedFCV) {
const configPrimary = st.configRS.getPrimary();
const shard0Primary = st.rs0.getPrimary();
const shard0Secondary = st.rs0.getSecondary();
shard0Secondary.setSecondaryOk();
const shard1Primary = st.rs1.getPrimary();
const shard1Secondary = st.rs1.getSecondary();
shard1Secondary.setSecondaryOk();
for (const node
of [configPrimary, shard0Primary, shard0Secondary, shard1Primary, shard1Secondary]) {
jsTest.log('Verify that the FCV is properly set on node ' + getNodeName(node));
const fcvDoc = node.adminCommand({getParameter: 1, featureCompatibilityVersion: 1});
assert.eq(expectedFCV, fcvDoc.featureCompatibilityVersion.version);
}
}
function checkClusterBeforeUpgrade(fcv) {
checkConfigAndShardsFCV(fcv);
checkConfigVersionDoc();
}
function checkClusterAfterBinaryUpgrade() {
checkConfigVersionDoc();
}
function checkClusterAfterFCVUpgrade(fcv) {
checkConfigAndShardsFCV(fcv);
checkConfigVersionDoc();
}
function checkClusterAfterFCVDowngrade() {
checkConfigVersionDoc();
}
function checkClusterAfterBinaryDowngrade(fcv) {
checkConfigAndShardsFCV(fcv);
checkConfigVersionDoc();
}
for (const oldVersion of [lastLTSFCV, lastContinuousFCV]) {
//////////////////////////////
// Setting and testing cluster using old binaries in default FCV mode
jsTest.log('Deploying cluster version ' + oldVersion);
var st = setupClusterAndDatabase(oldVersion);
checkClusterBeforeUpgrade(oldVersion);
//////////////////////////////
// Setting and testing cluster using latest binaries in latest FCV mode
jsTest.log('Upgrading binaries to latest version');
st.upgradeCluster('latest');
checkClusterAfterBinaryUpgrade();
jsTest.log('Upgrading FCV to ' + latestFCV);
assert.commandWorked(st.s.adminCommand({setFeatureCompatibilityVersion: latestFCV}));
checkClusterAfterFCVUpgrade(latestFCV);
//////////////////////////////
// Setting and testing cluster using old binaries in old FCV mode
jsTest.log('Downgrading FCV to ' + oldVersion);
assert.commandWorked(st.s.adminCommand({setFeatureCompatibilityVersion: oldVersion}));
checkClusterAfterFCVDowngrade();
jsTest.log('Downgrading binaries to version ' + oldVersion);
st.downgradeCluster(oldVersion);
checkClusterAfterBinaryDowngrade(oldVersion);
st.stop();
}
})();