0
0
mirror of https://github.com/mongodb/mongo.git synced 2024-11-27 23:27:11 +01:00
mongodb/jstests/hooks/run_initial_sync_node_validation.js
2024-09-10 18:07:06 +00:00

59 lines
1.9 KiB
JavaScript

// Runner that runs full validation on all collections of the initial sync node and checks the
// dbhashes of all of the nodes including the initial sync node.
import {ReplSetTest} from "jstests/libs/replsettest.js";
var startTime = Date.now();
var primaryInfo = null;
assert.soonRetryOnNetworkErrors(
() => {
primaryInfo = db.isMaster();
return primaryInfo.hasOwnProperty("ismaster") && primaryInfo.ismaster;
},
() => {
return `shell is not connected to the primary node: ${tojson(primaryInfo)}`;
});
// The initial sync hooks only work for replica sets.
var rst = new ReplSetTest(db.getMongo().host);
// Call getPrimary to populate rst with information about the nodes.
var primary = rst.getPrimary();
assert(primary, 'calling getPrimary() failed');
// Find the hidden node.
var hiddenNode;
for (var secondary of rst.getSecondaries()) {
var isMasterRes = secondary.getDB('admin').isMaster();
if (isMasterRes.hidden) {
hiddenNode = secondary;
break;
}
}
assert(hiddenNode, 'No hidden initial sync node was found in the replica set');
// Confirm that the hidden node is in SECONDARY state.
var res;
assert.soonRetryOnNetworkErrors(
() => {
res = assert.commandWorked(hiddenNode.adminCommand({replSetGetStatus: 1}));
return res.myState === ReplSetTest.State.SECONDARY;
},
() => {
return `res: ${tojson(res)}`;
});
/* The checkReplicatedDataHashes call waits until all operations have replicated to and
have been applied on the secondaries, so we run the validation script after it
to ensure we're validating the entire contents of the collection */
// For checkDBHashes
const excludedDBs = jsTest.options().excludedDBsFromDBHash;
rst.checkReplicatedDataHashes(undefined, excludedDBs);
await import("jstests/hooks/run_validate_collections.js");
var totalTime = Date.now() - startTime;
print('Finished consistency checks of initial sync node in ' + totalTime + ' ms.');