File: mongos_no_replica_set_refresh.js

package info (click to toggle)
mongodb 1%3A2.4.10-5
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 82,464 kB
  • sloc: cpp: 740,225; ansic: 152,098; sh: 13,820; python: 11,864; makefile: 1,012; perl: 922; pascal: 617; java: 452; lisp: 222; asm: 174
file content (78 lines) | stat: -rw-r--r-- 2,431 bytes parent folder | download | duplicates (3)
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
// Tests whether new sharding is detected on insert by mongos

var st = new ShardingTest( name = "test", shards = 1, verbose = 2, mongos = 2, other = { rs : true } )

var mongos = st.s
var config = mongos.getDB("config")

config.settings.update({ _id : "balancer" }, { $set : { stopped : true } }, true )

printjson( mongos.getCollection("foo.bar").findOne() )

var rsObj = st._rs[0].test
var primary = rsObj.getPrimary()
var secondaries = rsObj.getSecondaries()

printjson( primary.getDB("local").system.replset.findOne() )

jsTestLog( "Reconfiguring replica set..." )

var reconfig = { _id : rsObj.name, version : 2, members : [ { _id : 0, host : primary.host }, { _id : 1, host : secondaries[0].host } ] }
try{
    // Results in a stepdown, which results in an exception
    printjson( primary.getDB("admin").runCommand({ replSetReconfig : reconfig }) )
}
catch( e ){
    printjson( e )
}

var numRSHosts = function(){
    var result = primary.getDB("admin").runCommand({ ismaster : 1 })
    printjson( result )
    return result.hosts.length
}

assert.soon( function(){ return numRSHosts() < 3 } )

var numMongosHosts = function(){
    var result = mongos.getDB("admin").runCommand("connPoolStats")["replicaSets"][ rsObj.name ]
    printjson( result )
    return result.hosts.length
}

assert.soon( function(){ return numMongosHosts() < 3 } )

jsTestLog( "Mongos successfully detected change..." )

var configServerURL = function(){
    var result = config.shards.find().toArray()[0]
    printjson( result )
    return result.host
}

assert.soon( function(){ return configServerURL().indexOf( secondaries[1].host ) < 0 } )

jsTestLog( "Now test adding new replica set servers..." )

config.shards.update({ _id : rsObj.name }, { $set : { host : rsObj.name + "/" + primary.host } })
printjson( config.shards.find().toArray() )

var reconfig = { _id : rsObj.name, version : 3, members : [ { _id : 0, host : primary.host }, { _id : 1, host : secondaries[0].host }, { _id : 2, host : secondaries[1].host } ] }

try {
    // Results in a stepdown, which results in an exception
    printjson( primary.getDB("admin").runCommand({ replSetReconfig : reconfig }) )
}
catch( e ){
    printjson( e )
}

assert.soon( function(){ return numRSHosts() > 2 } )

assert.soon( function(){ return numMongosHosts() > 2 } )

assert.soon( function(){ return configServerURL().indexOf( secondaries[1].host ) >= 0 } )

jsTestLog( "Done..." )

st.stop()