summaryrefslogtreecommitdiff
path: root/jstests/replsets/replset7.js
blob: f29c1fbb953ef66748dac394edde3207cfca259e (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

// test for SERVER-5040 - if documents move forward during an initial sync.

var rt = new ReplSetTest( { name : "replset7tests" , nodes: 1 } );

var nodes = rt.startSet();
rt.initiate();
var master = rt.getMaster();

var md = master.getDB( 'd' );
var mdc = md[ 'c' ];

// prep the data
var doccount = 100000;
for( i = 0; i < doccount; ++i ) {
    mdc.insert( { _id:i, x:i } );
}
md.getLastError();

mdc.ensureIndex( { x : 1 }, { unique: true } );
md.getLastError();

// add a secondary
var slave = rt.add();
rt.reInitiate();
print ("initiation complete!");
var sc = slave.getDB( 'd' )[ 'c' ];
slave.setSlaveOk();

// Wait for slave to start cloning.
//assert.soon( function() { c = sc.find( { _id:1, x:1 } ); print( c ); return c > 0; } );


// Move all documents to the end by growing it
for (i = 0; i < doccount; ++i) {
    mdc.remove( { _id:i, x:i } );
    mdc.insert( { _id:doccount+i, x:i, bigstring: "ayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayayay" } );
    md.getLastError();
}

// Wait for replication to catch up.
rt.awaitSecondaryNodes();

// Do we have an index?
assert.eq (1, slave.getDB( 'd' )['system.indexes']
           .find({"v" : 1,"key" : {"x" : 1},"unique" : true,"ns" : "d.c","name" : "x_1"}).count());