Files
mongo/jstests/replsets/replsetarb2.js

47 lines
1.5 KiB
JavaScript
Raw Normal View History

2010-07-30 14:02:27 -04:00
// Election when master fails and remaining nodes are an arbiter and a slave.
(function() {
"use strict";
2010-07-30 14:02:27 -04:00
var replTest = new ReplSetTest( {name: 'unicomplex', nodes: 3} );
var nodes = replTest.nodeList();
var conns = replTest.startSet();
var r = replTest.initiate({"_id" : "unicomplex",
"members" : [
{"_id" : 0, "host" : nodes[0]},
{"_id" : 1, "host" : nodes[1], "arbiterOnly" : true, "votes": 1},
{"_id" : 2, "host" : nodes[2]}
]});
2010-07-30 14:02:27 -04:00
// Make sure we have a master
var master = replTest.getPrimary();
2010-07-30 14:02:27 -04:00
// Make sure we have an arbiter
assert.soon(function() {
var res = conns[1].getDB("admin").runCommand({replSetGetStatus: 1});
2010-07-30 14:02:27 -04:00
printjson(res);
return res.myState === 7;
2010-07-30 14:02:27 -04:00
}, "Aribiter failed to initialize.");
var result = conns[1].getDB("admin").runCommand({isMaster : 1});
assert(result.arbiterOnly);
assert(!result.passive);
2010-07-30 14:02:27 -04:00
// Wait for initial replication
master.getDB("foo").foo.insert({a: "foo"});
replTest.awaitReplication();
// Now kill the original master
var mId = replTest.getNodeId(master);
replTest.stop(mId);
2010-07-30 14:02:27 -04:00
// And make sure that the slave is promoted
var new_master = replTest.getPrimary();
2010-07-30 14:02:27 -04:00
var newMasterId = replTest.getNodeId(new_master);
assert.neq(newMasterId, mId, "Secondary wasn't promoted to new primary");
2010-07-30 14:02:27 -04:00
replTest.stopSet(15);
}());