Files
mongo/jstests/replsets/dbhash_system_collections.js
Matt Broadstone 771dabd098 SERVER-81339 Convert ReplSetTest and ShardingTest to modules (#26332)
GitOrigin-RevId: 744aa110a53786b23c62ff53f87a1418b5991e8d
2024-08-20 22:00:49 +00:00

52 lines
1.5 KiB
JavaScript

import {ReplSetTest} from "jstests/libs/replsettest.js";
var rst = new ReplSetTest({name: 'dbhash_system_collections', nodes: 2});
rst.startSet();
rst.initiate();
var primary = rst.getPrimary();
var secondary = rst.getSecondary();
var testDB = primary.getDB('test');
assert.commandWorked(testDB.system.users.insert({users: 1}));
assert.commandWorked(testDB.system.js.insert({js: 1}));
var adminDB = primary.getDB('admin');
assert.commandWorked(adminDB.system.roles.insert({roles: 1}));
assert.commandWorked(adminDB.system.version.insert({version: 1}));
assert.commandWorked(adminDB.system.backup_users.insert({backup_users: 1}));
rst.awaitReplication();
function checkDbHash(mongo) {
var testDB = mongo.getDB('test');
var adminDB = mongo.getDB('admin');
var replicatedSystemCollections = [
'system.js',
'system.users',
];
var replicatedAdminSystemCollections = [
'system.backup_users',
'system.keys',
'system.roles',
'system.version',
];
var res = testDB.runCommand('dbhash');
assert.commandWorked(res);
assert.docEq(replicatedSystemCollections, Object.keys(res.collections), tojson(res));
res = adminDB.runCommand('dbhash');
assert.commandWorked(res);
assert.docEq(replicatedAdminSystemCollections, Object.keys(res.collections), tojson(res));
return res.md5;
}
var primaryMd5 = checkDbHash(primary);
var secondaryMd5 = checkDbHash(secondary);
assert.eq(primaryMd5, secondaryMd5, 'dbhash is different on the primary and the secondary');
rst.stopSet();