summaryrefslogtreecommitdiff
path: root/jstests/replsets/reconfig_tags.js
blob: 3fa4cb71041e8a1ee640e6e36d2e726b3895e9a9 (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
// test that reconfigging only tag changes is properly reflected in isMaster

var replTest = new ReplSetTest({ nodes: 2 });
replTest.startSet({ oplogSize: 10 });
replTest.initiate();
replTest.awaitSecondaryNodes();

// Tag primary with { dc: 'ny', tag: 'one' }, secondary with { dc: 'ny', tag: 'two' }
var primary = replTest.getPrimary();
var secondary = replTest.getSecondary();
var rsConfig = primary.getDB("local").system.replset.findOne();
jsTest.log('got rsconf ' + tojson(rsConfig));
rsConfig.members.forEach(function(member) {
    if (member.host == primary.host) {
        member.tags = { dc: 'ny', tag: 'one' };
    } else {
        member.tags = { dc: 'ny', tag: 'two' };
    }
});

rsConfig.version++;

jsTest.log('new rsconf ' + tojson(rsConfig));

try {
    var res = primary.adminCommand({ replSetReconfig: rsConfig });
    jsTest.log('reconfig res: ' + tojson(res)); // Should not see this
}
catch(e) {
    jsTest.log('replSetReconfig error: ' + e);
}

replTest.awaitSecondaryNodes();

var testDB = primary.getDB('test');

var newConn = new Mongo(primary.host);
var isMaster = newConn.adminCommand({ isMaster: 1 });
assert(isMaster.tags != null, 'isMaster: ' + tojson(isMaster));

print('success: ' + tojson(isMaster));
replTest.stopSet();