mongo/jstests/slow1/large_role_chain.js

49 lines
1.5 KiB
JavaScript

// Tests SERVER-11475 - Make sure server does't crash when many user defined roles are created where
// each role is a member of the next, creating a large chain.
// @tags: [
// requires_sharding,
// # We are choosing not to test on MacOS since it's too noisy.
// slow_on_macos,
// ]
import {ShardingTest} from "jstests/libs/shardingtest.js";
function runTest(conn) {
let testdb = conn.getDB("rolechain");
testdb.runCommand({dropAllRolesFromDatabase: 1});
let chainLen = 2000;
let buildInfo = conn.getDB("admin").runCommand("buildInfo");
assert.commandWorked(buildInfo);
// We reduce the number of roles linked together in the chain to avoid causing this test to take
// a long time with --dbg=on builds.
if (buildInfo.debug) {
chainLen = 200;
}
jsTestLog("Generating a chain of " + chainLen + " linked roles");
let roleNameBase = "chainRole";
for (let i = 0; i < chainLen; i++) {
let name = roleNameBase + i;
if (i == 0) {
testdb.runCommand({createRole: name, privileges: [], roles: []});
} else {
jsTestLog("Creating role " + i);
let prevRole = roleNameBase + (i - 1);
testdb.runCommand({createRole: name, privileges: [], roles: [prevRole]});
}
}
}
// run all tests standalone
let conn = MongoRunner.runMongod();
runTest(conn);
MongoRunner.stopMongod(conn);
// run all tests sharded
conn = new ShardingTest({shards: 2, mongos: 1, config: 3});
runTest(conn);
conn.stop();