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
|
t = db.index_sparse1;
t.drop();
t.insert( { _id : 1 , x : 1 } )
t.insert( { _id : 2 , x : 2 } )
t.insert( { _id : 3 , x : 2 } )
t.insert( { _id : 4 } )
t.insert( { _id : 5 } )
assert.eq( 5 , t.count() , "A1" )
assert.eq( 5 , t.find().sort( { x : 1 } ).itcount() , "A2" )
t.ensureIndex( { x : 1 } )
assert.eq( 2 , t.getIndexes().length , "B1" )
assert.eq( 5 , t.find().sort( { x : 1 } ).itcount() , "B2" )
t.dropIndex( { x : 1 } )
assert.eq( 1 , t.getIndexes().length , "B3" )
t.ensureIndex( { x : 1 } , { sparse : 1 } )
assert.eq( 2 , t.getIndexes().length , "C1" )
assert.eq( 3 , t.find().sort( { x : 1 } ).itcount() , "C2" )
t.dropIndex( { x : 1 } )
assert.eq( 1 , t.getIndexes().length , "C3" )
// -- sparse & unique
t.remove( { _id : 2 } )
// test that we can't create a unique index without sparse
t.ensureIndex( { x : 1 } , { unique : 1 } )
assert( db.getLastError() , "D1" )
assert.eq( 1 , t.getIndexes().length , "D2" )
t.ensureIndex( { x : 1 } , { unique : 1 , sparse : 1 } )
assert.eq( 2 , t.getIndexes().length , "E1" )
t.dropIndex( { x : 1 } )
assert.eq( 1 , t.getIndexes().length , "E3" )
t.insert( { _id : 2 , x : 2 } )
t.ensureIndex( { x : 1 } , { unique : 1 , sparse : 1 } )
assert.eq( 1 , t.getIndexes().length , "F1" )
|