summaryrefslogtreecommitdiff
path: root/jstests/sharding/stale_version_write.js
blob: e5885dcfa412f4cc0b6344767a380c0890e99d6b (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});

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();