2012-06-27 08:02:01 -04:00
|
|
|
doTest = function (signal) {
|
|
|
|
|
|
|
|
|
|
// Test orphaned master steps down
|
|
|
|
|
var replTest = new ReplSetTest({ name: 'testSet', nodes: 3 });
|
|
|
|
|
|
|
|
|
|
replTest.startSet();
|
|
|
|
|
replTest.initiate();
|
|
|
|
|
|
2015-11-25 11:20:43 -05:00
|
|
|
var master = replTest.getPrimary();
|
2012-06-27 08:02:01 -04:00
|
|
|
|
|
|
|
|
// Kill both slaves, simulating a network partition
|
|
|
|
|
var slaves = replTest.liveNodes.slaves;
|
|
|
|
|
for (var i = 0; i < slaves.length; i++) {
|
|
|
|
|
var slave_id = replTest.getNodeId(slaves[i]);
|
|
|
|
|
replTest.stop(slave_id);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
print("replset4.js 1");
|
|
|
|
|
|
|
|
|
|
assert.soon(
|
|
|
|
|
function () {
|
|
|
|
|
try {
|
|
|
|
|
var result = master.getDB("admin").runCommand({ ismaster: 1 });
|
|
|
|
|
return (result['ok'] == 1 && result['ismaster'] == false);
|
|
|
|
|
} catch (e) {
|
|
|
|
|
print("replset4.js caught " + e);
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
"Master fails to step down when orphaned."
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
print("replset4.js worked, stopping");
|
|
|
|
|
replTest.stopSet(signal);
|
|
|
|
|
}
|
|
|
|
|
|
2010-08-31 04:23:10 -04:00
|
|
|
print("replset4.js");
|
2010-07-29 14:00:25 -04:00
|
|
|
doTest( 15 );
|
2010-08-26 13:50:34 -04:00
|
|
|
print("replset4.js SUCCESS");
|