blob: 1c153a1e6757471150b6feb9f5984181293f5233 (
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
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
79
80
81
82
83
84
85
86
|
//
// Tests upgrading a replica set
//
load( './jstests/multiVersion/libs/multi_rs.js' );
load( './jstests/libs/test_background_ops.js' );
// 3.2.1 is the final version to use the old style replSetUpdatePosition command.
var oldVersion = "3.2.1";
var nodes = { n1 : { binVersion : oldVersion },
n2 : { binVersion : oldVersion },
a3 : { binVersion : oldVersion } };
var rst = new ReplSetTest({ nodes : nodes });
rst.startSet();
rst.initiate();
// Wait for a primary node...
var primary = rst.getPrimary();
var otherOpConn = new Mongo( rst.getURL() );
var insertNS = "test.foo";
jsTest.log( "Starting parallel operations during upgrade..." );
function findAndInsert( rsURL, coll ){
var coll = new Mongo( rsURL ).getCollection( coll + "" );
var count = 0;
jsTest.log( "Starting finds and inserts..." );
while( ! isFinished() ){
try{
coll.insert({ _id : count, hello : "world" });
assert.eq( null, coll.getDB().getLastError() );
assert.neq( null, coll.findOne({ _id : count }) );
}
catch( e ){
printjson( e );
}
count++;
}
jsTest.log( "Finished finds and inserts..." );
return count;
}
var joinFindInsert =
startParallelOps( primary, // The connection where the test info is passed and stored
findAndInsert,
[ rst.getURL(), insertNS ] );
jsTest.log( "Upgrading replica set..." );
rst.upgradeSet({ binVersion: "latest" });
jsTest.log( "Replica set upgraded." );
// Wait for primary
var primary = rst.getPrimary();
printjson( rst.status() );
// Allow more valid writes to go through
sleep( 10 * 1000 );
joinFindInsert();
var totalInserts = primary.getCollection( insertNS ).find().sort({ _id : -1 }).next()._id + 1;
var dataFound = primary.getCollection( insertNS ).count();
jsTest.log( "Found " + dataFound + " docs out of " + tojson( totalInserts ) + " inserted." );
assert.gt( dataFound / totalInserts, 0.5 );
rst.stopSet();
|