2016-03-09 12:17:50 -05:00
|
|
|
doTest = function(signal) {
|
2012-06-27 08:02:01 -04:00
|
|
|
|
|
|
|
|
// Test orphaned master steps down
|
2016-03-09 12:17:50 -05:00
|
|
|
var replTest = new ReplSetTest({name: 'testSet', nodes: 3});
|
2012-06-27 08:02:01 -04:00
|
|
|
|
|
|
|
|
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");
|
|
|
|
|
|
2016-03-09 12:17:50 -05:00
|
|
|
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.");
|
2012-06-27 08:02:01 -04:00
|
|
|
|
|
|
|
|
print("replset4.js worked, stopping");
|
|
|
|
|
replTest.stopSet(signal);
|
2016-02-04 12:30:42 -05:00
|
|
|
};
|
2012-06-27 08:02:01 -04:00
|
|
|
|
2010-08-31 04:23:10 -04:00
|
|
|
print("replset4.js");
|
2016-03-09 12:17:50 -05:00
|
|
|
doTest(15);
|
2010-08-26 13:50:34 -04:00
|
|
|
print("replset4.js SUCCESS");
|