// Test removal of a substantial proportion of inserted documents. SERVER-3803 // A complete test will only be performed against a DEBUG build. t = db.jstests_removea; Random.setRandomSeed(); for( v = 0; v < 2; ++v ) { // Try each index version. t.drop(); t.ensureIndex( { a:1 }, { v:v } ); S = 100; B = 100; for ( var x = 0; x < S; x++ ) { var batch = []; for ( var y = 0; y < B; y++ ) { var i = y + ( B * x ); batch.push( { a : i } ); } t.insert( batch ); } assert.eq( t.count(), S * B ); toDrop = []; for( i = 0; i < S * B ; ++i ) { toDrop.push( Random.randInt( 10000 ) ); // Dups in the query will be ignored. } // Remove many of the documents; $atomic prevents use of a ClientCursor, which would invoke a // different bucket deallocation procedure than the one to be tested (see SERVER-4575). var res = t.remove( { a:{ $in:toDrop }, $atomic:true } ); assert.writeOK( res ); }