File: replmonitor_bad_seed.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 (60 lines) | stat: -rw-r--r-- 2,029 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
/**
 * This tests tries to check that a ReplicaSetMonitor initialized with a
 * replica set seed that has none of the nodes up will be able to recover
 * once the replica set come back up.
 *
 * ReplSetMonitor is tested indirectly through mongos. This is because
 * attempting to create a connection through the Mongo constructor won't
 * work because the shell will throw an exception before the mongo shell
 * binds the variable properly to the js environment (in simple terms,
 * the connection object is never returned when it cannot connect to it).
 * Another reason for using mongos in this test is so we can use
 * connPoolStats to synchronize the test and make sure that the monitor
 * was able to refresh before proceeding to check.
 */

var rsOpt = { oplogSize: 10 };
var st = new ShardingTest({ shards: 1, rs: rsOpt });
var mongos = st.s;
var replTest = st.rs0;

var adminDB = mongos.getDB('admin');
//adminDB.runCommand({ addShard: replTest.getURL() });

adminDB.runCommand({ enableSharding: 'test' });
adminDB.runCommand({ shardCollection: 'test.user', key: { x: 1 }});

/* The cluster now has the shard information. Then kill the replica set so
 * when mongos restarts and tries to create a ReplSetMonitor for that shard,
 * it will not be able to connect to any of the seed servers.
 */
replTest.stopSet();
st.restartMongos(0);
mongos = st.s; // refresh mongos with the new one

var coll = mongos.getDB('test').user;

var verifyInsert = function() {
    var beforeCount = coll.find().count();
    coll.insert({ x: 1 });
    coll.getDB().getLastError();
    var afterCount = coll.find().count();

    assert.eq(beforeCount + 1, afterCount);
};

jsTest.log('Insert to a downed replSet');
assert.throws(verifyInsert);

replTest.startSet({ oplogSize: 10 });
replTest.initiate();
replTest.awaitSecondaryNodes();

jsTest.log('Insert to an online replSet');

// Verify that the replSetMonitor can reach the restarted set.
ReplSetTest.awaitRSClientHosts(mongos, replTest.nodes, { ok: true });
verifyInsert();

st.stop();