File: queryoptimizer10.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 (31 lines) | stat: -rw-r--r-- 953 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
// Optimal indexes are saved in the query plan cache, but not geo indexes. SERVER-5301

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

function clearQueryPlanCache() {
    t.ensureIndex( { zzz:1 } );
    t.dropIndex( { zzz:1 } );
}

function assertIndexRecordedForQuery( expectedCursor, query, explainQuery ) {
    clearQueryPlanCache();    
    explainQuery = explainQuery || query;
    t.find( query ).itcount();
    if ( !expectedCursor ) {
        assert( !t.find( explainQuery ).explain( true ).oldPlan ); 
    }
    else {
        assert.eq( expectedCursor, t.find( explainQuery ).explain( true ).oldPlan.cursor );
    }
}

t.ensureIndex( { a:1 } );
assertIndexRecordedForQuery( 'BtreeCursor a_1', { $or:[ { a:1 } ] }, { a:1 } );
assertIndexRecordedForQuery( 'BtreeCursor a_1', { a:1 } );

t.drop();

t.ensureIndex( { a:'2d' } );
assertIndexRecordedForQuery( null, { a:{ $near:[ 50, 50 ] } } );
assertIndexRecordedForQuery( null, { a:[ 50, 50 ] } );