Files
mongo/jstests/replsets/remove1.js

123 lines
2.7 KiB
JavaScript
Raw Normal View History

/* test removing a node from a replica set
*
* Start set with three nodes
* Initial sync
* Remove slave1
* Remove slave2
* Bring slave1 back up
* Bring slave2 back up
* Add them back as slave
* Make sure everyone's secondary
*/
load("jstests/replsets/rslib.js");
var name = "removeNodes";
var host = getHostName();
print("Start set with three nodes");
2011-05-31 10:33:33 -04:00
var replTest = new ReplSetTest( {name: name, nodes: 2} );
var nodes = replTest.startSet();
replTest.initiate();
var master = replTest.getMaster();
print("Initial sync");
master.getDB("foo").bar.baz.insert({x:1});
replTest.awaitReplication();
2011-05-10 17:32:20 -04:00
print("Remove slaves");
var config = replTest.getReplSetConfig();
config.members.pop();
config.version = 2;
assert.soon(function() {
try {
master.getDB("admin").runCommand({replSetReconfig:config});
}
catch(e) {
print(e);
}
reconnect(master);
2011-05-10 17:32:20 -04:00
reconnect(replTest.nodes[1]);
var c = master.getDB("local").system.replset.findOne();
return c.version == 2;
});
2011-05-31 10:33:33 -04:00
print("Add it back as a slave");
2010-11-18 13:05:02 -05:00
config.members.push({_id:1, host : host+":"+replTest.getPort(1)});
2011-05-10 17:32:20 -04:00
config.version = 3;
2011-04-06 17:58:47 -04:00
printjson(config);
2010-11-18 09:56:21 -05:00
wait(function() {
try {
2011-06-14 16:22:51 -04:00
master.getDB("admin").runCommand({replSetReconfig:config});
2010-11-18 09:56:21 -05:00
}
catch(e) {
2011-06-14 16:22:51 -04:00
print(e);
2010-11-18 09:56:21 -05:00
}
reconnect(master);
2011-04-07 12:08:09 -04:00
printjson(master.getDB("admin").runCommand({replSetGetStatus:1}));
2010-11-18 09:56:21 -05:00
master.setSlaveOk();
var newConfig = master.getDB("local").system.replset.findOne();
2011-04-27 00:09:07 -04:00
print( "newConfig: " + tojson(newConfig) );
2011-05-10 17:32:20 -04:00
return newConfig.version == 3;
2011-04-27 00:09:07 -04:00
} , "wait1" );
print("Make sure everyone's secondary");
wait(function() {
var status = master.getDB("admin").runCommand({replSetGetStatus:1});
occasionally(function() {
printjson(status);
});
2011-05-31 10:33:33 -04:00
if (!status.members || status.members.length != 2) {
2010-11-18 09:56:21 -05:00
return false;
}
2011-05-31 10:33:33 -04:00
for (var i = 0; i<2; i++) {
2010-11-18 09:56:21 -05:00
if (status.members[i].state != 1 && status.members[i].state != 2) {
return false;
}
}
return true;
2011-04-27 00:09:07 -04:00
} , "wait2" );
2011-06-14 16:22:51 -04:00
print("reconfig with minority");
replTest.stop(1);
assert.soon(function() {
2011-07-25 19:03:56 -04:00
try {
return master.getDB("admin").runCommand({isMaster : 1}).secondary;
}
catch(e) {
print("trying to get master: "+e);
}
2011-06-14 16:22:51 -04:00
});
config.version = 4;
config.members.pop();
try {
master.getDB("admin").runCommand({replSetReconfig : config, force : true});
}
catch(e) {
print(e);
}
reconnect(master);
assert.soon(function() {
return master.getDB("admin").runCommand({isMaster : 1}).ismaster;
});
config = master.getDB("local").system.replset.findOne();
printjson(config);
assert(config.version > 4);
replTest.stopSet();