summaryrefslogtreecommitdiff
path: root/jstests/indexp.js
blob: cc6a2bb523e2711b17635a052e7df0fe6079e80a (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
// Check recording and playback of good query plans with different index types SERVER-958.

t = db.jstests_indexp;
t.drop();

function expectRecordedPlan( query, idx ) {
    explain = t.find( query ).explain( true );
    assert( explain.oldPlan );
 	assert.eq( "BtreeCursor " + idx, explain.oldPlan.cursor );
}

function expectNoRecordedPlan( query ) {
 	assert.isnull( t.find( query ).explain( true ).oldPlan );
}

// Basic test
t.drop();
t.ensureIndex( {a:1} );
t.save( {a:1} );
t.find( {a:1,x:1} ).itcount();
expectRecordedPlan( {a:1,x:1}, "a_1" );

// Index type changes
t.drop();
t.ensureIndex( {a:1} );
t.save( {a:1} );
t.find( {a:1,x:1} ).itcount();
t.save( {a:[1,2]} );
expectNoRecordedPlan( {a:1,x:1} );

// Multi key QueryPattern reuses index
t.drop();
t.ensureIndex( {a:1} );
t.ensureIndex( {x:1} );
t.save( {a:[1,2],x:1} );
for( i = 0; i < 5; ++i ) {
    t.save( {a:-1,x:i} );
}
t.find( {a:{$gt:0},x:{$gt:0}} ).itcount();
expectRecordedPlan( {a:{$gt:0,$lt:5},x:{$gt:0}}, "a_1" );

// Single key QueryPattern is dropped.
t.drop();
t.ensureIndex( {a:1} );
t.save( {a:1} );
t.find( {a:{$gt:0,$lt:5},x:1} ).itcount();
t.save( {a:[1,2]} );
expectNoRecordedPlan( {a:{$gt:0,$lt:5},x:1} );

// Invalid query with only valid fields used 
// SERVER-2864
t.drop();
t.ensureIndex( {a:1} );
t.save( {a:1}  );
t.find( {a:1,b:{$gt:5,$lt:0},x:1} ).itcount();
expectRecordedPlan( {a:1,b:{$gt:5,$lt:0},x:1}, "a_1" );

// SERVER-2864
t.drop();
t.ensureIndex( {a:1} );
t.ensureIndex( {c:1} );
t.save( {a:1,c:1} );
t.save( {c:1} );
t.find( {a:1,b:{$gt:5,$lt:0},c:1} ).itcount();
expectRecordedPlan( {a:1,b:{$gt:5,$lt:0},c:1}, "a_1" );

// SERVER-2864
t.drop();
t.ensureIndex( {a:1} );
t.save( {a:1} );
t.find( {a:{$gt:5,$lt:0},x:1} ).itcount();
expectNoRecordedPlan( {a:{$gt:0,$lt:5},x:1}, "a_1" );

// Dummy query plan not stored
t.drop();
t.ensureIndex( {a:1} );
t.save( {a:1} );
t.find( {a:{$gt:5,$lt:0},x:1} ).itcount();
expectNoRecordedPlan( {a:{$gt:5,$lt:0},x:1} );