2010-11-09 17:28:32 -05:00
|
|
|
/**
|
|
|
|
|
* Test killing the primary during initial sync
|
|
|
|
|
* and don't allow the other secondary to become primary
|
|
|
|
|
*
|
|
|
|
|
* 1. Bring up set
|
|
|
|
|
* 2. Insert some data
|
|
|
|
|
* 4. Make sure synced
|
|
|
|
|
* 5. Freeze #2
|
|
|
|
|
* 6. Bring up #3
|
|
|
|
|
* 7. Kill #1 in the middle of syncing
|
2010-12-27 18:53:06 -05:00
|
|
|
* 8. Check that #3 makes it into secondary state
|
2010-11-09 17:28:32 -05:00
|
|
|
* 9. Bring #1 back up
|
|
|
|
|
* 10. Initial sync should succeed
|
|
|
|
|
* 11. Insert some stuff
|
|
|
|
|
* 12. Everyone happy eventually
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
load("jstests/replsets/rslib.js");
|
|
|
|
|
var basename = "jstests_initsync2";
|
|
|
|
|
|
2010-11-12 09:11:48 -05:00
|
|
|
var doTest = function() {
|
2010-11-09 17:28:32 -05:00
|
|
|
|
|
|
|
|
print("1. Bring up set");
|
|
|
|
|
var replTest = new ReplSetTest( {name: basename, nodes: 2} );
|
|
|
|
|
var conns = replTest.startSet();
|
|
|
|
|
replTest.initiate();
|
|
|
|
|
|
2015-11-25 11:20:43 -05:00
|
|
|
var master = replTest.getPrimary();
|
2010-11-11 12:44:20 -05:00
|
|
|
var origMaster = master;
|
2010-11-09 17:28:32 -05:00
|
|
|
var foo = master.getDB("foo");
|
|
|
|
|
var admin = master.getDB("admin");
|
|
|
|
|
|
|
|
|
|
var slave1 = replTest.liveNodes.slaves[0];
|
|
|
|
|
var admin_s1 = slave1.getDB("admin");
|
|
|
|
|
var local_s1 = slave1.getDB("local");
|
|
|
|
|
|
|
|
|
|
print("2. Insert some data");
|
|
|
|
|
for (var i=0; i<10000; i++) {
|
|
|
|
|
foo.bar.insert({date : new Date(), x : i, str : "all the talk on the market"});
|
|
|
|
|
}
|
|
|
|
|
print("total in foo: "+foo.bar.count());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
print("4. Make sure synced");
|
|
|
|
|
replTest.awaitReplication();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
print("5. Freeze #2");
|
|
|
|
|
admin_s1.runCommand({replSetFreeze:999999});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
print("6. Bring up #3");
|
|
|
|
|
var hostname = getHostName();
|
|
|
|
|
|
2015-03-22 12:08:21 -04:00
|
|
|
var slave2 = MongoRunner.runMongod({replSet: basename, oplogSize: 2});
|
2011-11-10 23:21:05 -05:00
|
|
|
|
2010-11-09 17:28:32 -05:00
|
|
|
var local_s2 = slave2.getDB("local");
|
|
|
|
|
var admin_s2 = slave2.getDB("admin");
|
|
|
|
|
|
|
|
|
|
var config = replTest.getReplSetConfig();
|
|
|
|
|
config.version = 2;
|
|
|
|
|
|
2014-06-18 12:23:20 -04:00
|
|
|
// Add #3 using rs.add() configuration document.
|
|
|
|
|
// Since 'db' currently points to slave2, reset 'db' to admin db on master before running rs.add().
|
|
|
|
|
db = admin;
|
2014-06-18 22:55:55 -04:00
|
|
|
|
|
|
|
|
// If _id is not provided, rs.add() will generate _id for #3 based on existing members' _ids.
|
2015-03-22 12:08:21 -04:00
|
|
|
assert.commandWorked(rs.add({host:hostname+":"+slave2.port}), "failed to add #3 to replica set");
|
2014-06-18 12:23:20 -04:00
|
|
|
|
2010-11-09 17:28:32 -05:00
|
|
|
reconnect(slave1);
|
|
|
|
|
reconnect(slave2);
|
|
|
|
|
|
|
|
|
|
wait(function() {
|
|
|
|
|
var config2 = local_s1.system.replset.findOne();
|
|
|
|
|
var config3 = local_s2.system.replset.findOne();
|
|
|
|
|
|
|
|
|
|
printjson(config2);
|
|
|
|
|
printjson(config3);
|
|
|
|
|
|
|
|
|
|
return config2.version == config.version &&
|
|
|
|
|
(config3 && config3.version == config.version);
|
|
|
|
|
});
|
2010-11-10 12:09:16 -05:00
|
|
|
admin_s2.runCommand({replSetFreeze:999999});
|
|
|
|
|
|
2010-11-09 17:28:32 -05:00
|
|
|
|
|
|
|
|
wait(function() {
|
|
|
|
|
var status = admin_s2.runCommand({replSetGetStatus:1});
|
|
|
|
|
printjson(status);
|
2010-11-10 20:39:18 -05:00
|
|
|
return status.members &&
|
2010-11-10 21:44:07 -05:00
|
|
|
(status.members[2].state == 3 || status.members[2].state == 2);
|
2010-11-09 17:28:32 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
print("7. Kill #1 in the middle of syncing");
|
|
|
|
|
replTest.stop(0);
|
|
|
|
|
|
|
|
|
|
|
2010-12-27 18:53:06 -05:00
|
|
|
print("8. Check that #3 makes it into secondary state");
|
|
|
|
|
wait(function() {
|
|
|
|
|
var status = admin_s2.runCommand({replSetGetStatus:1});
|
|
|
|
|
occasionally(function() { printjson(status);}, 10);
|
|
|
|
|
if (status.members[2].state == 2 || status.members[2].state == 1) {
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
});
|
2010-11-09 17:28:32 -05:00
|
|
|
|
|
|
|
|
|
2010-11-11 12:44:20 -05:00
|
|
|
print("9. Bring #1 back up");
|
2010-11-09 17:28:32 -05:00
|
|
|
replTest.start(0, {}, true);
|
|
|
|
|
reconnect(master);
|
|
|
|
|
wait(function() {
|
|
|
|
|
var status = admin.runCommand({replSetGetStatus:1});
|
|
|
|
|
printjson(status);
|
2010-11-11 12:44:20 -05:00
|
|
|
return status.members &&
|
|
|
|
|
(status.members[0].state == 1 || status.members[0].state == 2);
|
2010-11-09 17:28:32 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
print("10. Initial sync should succeed");
|
|
|
|
|
wait(function() {
|
|
|
|
|
var status = admin_s2.runCommand({replSetGetStatus:1});
|
|
|
|
|
printjson(status);
|
2010-11-13 16:16:12 -05:00
|
|
|
return status.members &&
|
|
|
|
|
status.members[2].state == 2 || status.members[2].state == 1;
|
2010-11-09 17:28:32 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
print("11. Insert some stuff");
|
2010-11-11 12:44:20 -05:00
|
|
|
// ReplSetTest doesn't find master correctly unless all nodes are defined by
|
|
|
|
|
// ReplSetTest
|
|
|
|
|
for (var i = 0; i<30; i++) {
|
|
|
|
|
var result = admin.runCommand({isMaster : 1});
|
|
|
|
|
if (result.ismaster) {
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
else if (result.primary) {
|
2010-12-28 10:57:01 -05:00
|
|
|
master = connect(result.primary+"/admin").getMongo();
|
2010-11-11 12:44:20 -05:00
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
sleep(1000);
|
|
|
|
|
}
|
|
|
|
|
|
2010-11-09 17:28:32 -05:00
|
|
|
for (var i=0; i<10000; i++) {
|
|
|
|
|
foo.bar.insert({date : new Date(), x : i, str : "all the talk on the market"});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
print("12. Everyone happy eventually");
|
2015-09-28 05:47:57 -04:00
|
|
|
replTest.awaitReplication(2 * 60 * 1000);
|
2010-11-10 12:09:16 -05:00
|
|
|
|
2010-11-12 09:11:48 -05:00
|
|
|
replTest.stopSet();
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
doTest();
|