0
0
mirror of https://github.com/mongodb/mongo.git synced 2024-11-30 17:10:48 +01:00
mongodb/jstests/replsets/reconfig.js

51 lines
1.2 KiB
JavaScript
Raw Normal View History

// try reconfiguring with servers down
2011-05-09 21:43:25 +02:00
load("jstests/replsets/rslib.js");
var replTest = new ReplSetTest({ name: 'testSet', nodes: 5 });
var nodes = replTest.startSet();
replTest.initiate();
var master = replTest.getMaster();
print("initial sync");
master.getDB("foo").bar.insert({X:1});
replTest.awaitReplication();
print("stopping 3 & 4");
replTest.stop(3);
replTest.stop(4);
print("reconfiguring");
var config = master.getDB("local").system.replset.findOne();
var oldVersion = config.version++;
config.members[0].votes = 2;
config.members[3].votes = 2;
try {
master.getDB("admin").runCommand({replSetReconfig : config});
}
catch(e) {
print(e);
}
var config = master.getDB("local").system.replset.findOne();
assert.eq(oldVersion+1, config.version);
print("0 & 3 up; 1, 2, 4 down");
replTest.restart(3);
replTest.stop(1);
replTest.stop(2);
print("try to reconfigure with a 'majority' down");
oldVersion = config.version++;
2011-05-09 21:43:25 +02:00
reconnect(master);
var result = master.getDB("admin").runCommand({replSetReconfig : config});
assert.eq(13144, result.assertionCode);
var config = master.getDB("local").system.replset.findOne();
assert.eq(oldVersion, config.version);
replTest.stopSet();