1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
|
var baseName = "jstests_sharding_sharding_options";
load('jstests/libs/command_line/test_parsed_options.js');
// Move Paranoia
jsTest.log("Testing \"moveParanoia\" command line option");
var expectedResult = {
"parsed": {"sharding": {"archiveMovedChunks": true}}
};
testGetCmdLineOptsMongod({moveParanoia: ""}, expectedResult);
jsTest.log("Testing \"noMoveParanoia\" command line option");
expectedResult = {
"parsed": {"sharding": {"archiveMovedChunks": false}}
};
testGetCmdLineOptsMongod({noMoveParanoia: ""}, expectedResult);
jsTest.log("Testing \"sharding.archiveMovedChunks\" config file option");
expectedResult = {
"parsed": {
"config": "jstests/libs/config_files/enable_paranoia.json",
"sharding": {"archiveMovedChunks": true}
}
};
testGetCmdLineOptsMongod({config: "jstests/libs/config_files/enable_paranoia.json"},
expectedResult);
// Sharding Role
jsTest.log("Testing \"configsvr\" command line option");
var expectedResult = {
"parsed":
{"sharding": {"clusterRole": "configsvr"}, "storage": {"journal": {"enabled": true}}}
};
testGetCmdLineOptsMongod({configsvr: "", journal: ""}, expectedResult);
jsTest.log("Testing \"shardsvr\" command line option");
expectedResult = {
"parsed": {"sharding": {"clusterRole": "shardsvr"}}
};
testGetCmdLineOptsMongod({shardsvr: ""}, expectedResult);
jsTest.log("Testing \"sharding.clusterRole\" config file option");
expectedResult = {
"parsed": {
"config": "jstests/libs/config_files/set_shardingrole.json",
"sharding": {"clusterRole": "configsvr"}
}
};
testGetCmdLineOptsMongod({config: "jstests/libs/config_files/set_shardingrole.json"},
expectedResult);
// Auto Splitting
jsTest.log("Testing \"noAutoSplit\" command line option");
var expectedResult = {
"parsed": {"sharding": {"autoSplit": false}}
};
testGetCmdLineOptsMongos({noAutoSplit: ""}, expectedResult);
jsTest.log("Testing \"sharding.autoSplit\" config file option");
expectedResult = {
"parsed": {
"config": "jstests/libs/config_files/enable_autosplit.json",
"sharding": {"autoSplit": true}
}
};
testGetCmdLineOptsMongos({config: "jstests/libs/config_files/enable_autosplit.json"},
expectedResult);
// Test that we preserve switches explicitly set to false in config files. See SERVER-13439.
jsTest.log("Testing explicitly disabled \"moveParanoia\" config file option");
expectedResult = {
"parsed": {
"config": "jstests/libs/config_files/disable_moveparanoia.ini",
"sharding": {"archiveMovedChunks": false}
}
};
testGetCmdLineOptsMongod({config: "jstests/libs/config_files/disable_moveparanoia.ini"},
expectedResult);
jsTest.log("Testing explicitly disabled \"noMoveParanoia\" config file option");
expectedResult = {
"parsed": {
"config": "jstests/libs/config_files/disable_nomoveparanoia.ini",
"sharding": {"archiveMovedChunks": true}
}
};
testGetCmdLineOptsMongod({config: "jstests/libs/config_files/disable_nomoveparanoia.ini"},
expectedResult);
jsTest.log("Testing explicitly disabled \"noAutoSplit\" config file option");
expectedResult = {
"parsed": {
"config": "jstests/libs/config_files/disable_noautosplit.ini",
"sharding": {"autoSplit": true}
}
};
testGetCmdLineOptsMongos({config: "jstests/libs/config_files/disable_noautosplit.ini"},
expectedResult);
print(baseName + " succeeded.");
|