summaryrefslogtreecommitdiff
path: root/jstests/sharding/writeback_shard_version.js
blob: f896ed47bb92aad302fe540e87d3a57934a54cb6 (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
// Tests whether a reset sharding version triggers errors

jsTest.log( "Starting sharded cluster..." )

var st = new ShardingTest( { shards : 1, mongos : 2, verbose : 2, separateConfig : 1  } )

st.stopBalancer()

var mongosA = st.s0
var mongosB = st.s1

jsTest.log( "Adding new collections...")

var collA = mongosA.getCollection( jsTestName() + ".coll" )
collA.insert({ hello : "world" })
assert.eq( null, collA.getDB().getLastError() )

var collB = mongosB.getCollection( "" + collA )
collB.insert({ hello : "world" })
assert.eq( null, collB.getDB().getLastError() )

jsTest.log( "Enabling sharding..." )

printjson( mongosA.getDB( "admin" ).runCommand({ enableSharding : "" + collA.getDB() }) )
printjson( mongosA.getDB( "admin" ).runCommand({ shardCollection : "" + collA, key : { _id : 1 } }) )

// MongoD doesn't know about the config shard version *until* MongoS tells it
collA.findOne()

jsTest.log( "Trigger wbl..." )

collB.insert({ goodbye : "world" })
assert.eq( null, collB.getDB().getLastError() )

print( "Inserted..." )

assert.eq( 3, collA.find().itcount() )
assert.eq( 3, collB.find().itcount() )

st.stop()