summaryrefslogtreecommitdiff
path: root/jstests/replsets/replsetarb2.js
blob: 0e4c79111bc26a960390da56b5a7c63879c3b37d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
// Election when master fails and remaining nodes are an arbiter and a slave.
// Note that in this scenario, the arbiter needs two votes.

doTest = function( signal ) {

    var replTest = new ReplSetTest( {name: 'unicomplex', nodes: 3} );
    var nodes = replTest.nodeList();

    print(tojson(nodes));

    var conns = replTest.startSet();
    var r = replTest.initiate({"_id" : "unicomplex", 
                "members" : [
                             {"_id" : 0, "host" : nodes[0] },
                             {"_id" : 1, "host" : nodes[1], "arbiterOnly" : true, "votes": 2},
                             {"_id" : 2, "host" : nodes[2] }]});

    // Make sure we have a master
    var master = replTest.getMaster();

    // Make sure we have an arbiter
    assert.soon(function() {
        res = conns[1].getDB("admin").runCommand({replSetGetStatus: 1});
        printjson(res);
        return res.myState == 7;
    }, "Aribiter failed to initialize.");

    // Wait for initial replication
    master.getDB("foo").foo.insert({a: "foo"});
    replTest.awaitReplication();

    assert( ! conns[1].getDB( "admin" ).runCommand( "ismaster" ).secondary , "arbiter shouldn't be secondary" )

    // Now kill the original master
    mId = replTest.getNodeId( master );
    replTest.stop( mId );

    // And make sure that the slave is promoted
    new_master = replTest.getMaster();

    newMasterId = replTest.getNodeId( new_master );
    assert( newMasterId == 2, "Slave wasn't promoted to new master");

    replTest.stopSet( signal );
}

doTest( 15 );