0
0
mirror of https://github.com/mongodb/mongo.git synced 2024-12-01 01:21:03 +01:00
mongodb/jstests/distinct3.js

34 lines
1.1 KiB
JavaScript
Raw Normal View History

2011-12-26 20:06:36 +01:00
// Yield and delete test case for query optimizer cursor. SERVER-4401
t = db.jstests_distinct3;
t.drop();
t.ensureIndex({a:1});
t.ensureIndex({b:1});
for( i = 0; i < 50; ++i ) {
for( j = 0; j < 20; ++j ) {
t.save({a:i,c:i,d:j});
}
}
for( i = 0; i < 1000; ++i ) {
t.save({b:i,c:i+50});
}
db.getLastError();
// Attempt to remove the last match for the {a:1} index scan while distinct is yielding.
p = startParallelShell( 'for( i = 0; i < 2500; ++i ) { ' +
' db.jstests_distinct3.remove( { a:49 } ); ' +
' for( j = 0; j < 20; ++j ) { ' +
' db.jstests_distinct3.save( { a:49, c:49, d:j } ); ' +
' } ' +
'} ' +
'db.getLastError(); ' );
for( i = 0; i < 100; ++i ) {
count = t.distinct( 'c', {$or:[{a:{$gte:0},d:0},{b:{$gte:0}}]} ).length;
assert.gt( count, 1000 );
}
p();