summaryrefslogtreecommitdiff
path: root/jstests/sharding/stale_version_write.js
blob: 1d665b6c65e2c1834d0f9f4e5f0d3022748a8fdb (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
// 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" )
assert.writeOK(collA.insert({ hello : "world" }));

var collB = mongosB.getCollection( "" + collA )
assert.writeOK(collB.insert({ hello : "world" }));

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 shard version mismatch..." );

assert.writeOK(collB.insert({ goodbye : "world" }));

print( "Inserted..." )

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

st.stop()