Files
mongo/jstests/core/distinct_array1.js
Randolph Tan 5595b94560 SERVER-12127 migrate js tests to jscore suite when not related to writes
Moved test jstest/[a-i].js -> jstests/core/ and made changes to comply with write command api
2014-02-28 16:26:33 -05:00

92 lines
2.4 KiB
JavaScript

t = db.distinct_array1;
t.drop();
t.save( { a : [1,2,3] } )
t.save( { a : [2,3,4] } )
t.save( { a : [3,4,5] } )
t.save( { a : 9 } )
// Without index.
res = t.distinct( "a" ).sort();
assert.eq( "1,2,3,4,5,9" , res.toString() , "A1" );
// Array element 0 without index.
res = t.distinct( "a.0" ).sort();
assert.eq( "1,2,3" , res.toString() , "A2" );
// Array element 1 without index.
res = t.distinct( "a.1" ).sort();
assert.eq( "2,3,4" , res.toString() , "A3" );
// With index.
t.ensureIndex( { a : 1 } );
res = t.distinct( "a" ).sort();
assert.eq( "1,2,3,4,5,9" , res.toString() , "A4" );
// Array element 0 with index.
res = t.distinct( "a.0" ).sort();
assert.eq( "1,2,3" , res.toString() , "A5" );
// Array element 1 with index.
res = t.distinct( "a.1" ).sort();
assert.eq( "2,3,4" , res.toString() , "A6" );
//t.drop();
t.save( { a : [{b:"a"}, {b:"d"}] , c : 12 } );
t.save( { a : [{b:"b"}, {b:"d"}] , c : 12 } );
t.save( { a : [{b:"c"}, {b:"e"}] , c : 12 } );
t.save( { a : [{b:"c"}, {b:"f"}] , c : 12 } );
t.save( { a : [] , c : 12 } );
t.save( { a : { b : "z"} , c : 12 } );
// Without index.
res = t.distinct( "a.b" ).sort();
assert.eq( "a,b,c,d,e,f,z" , res.toString() , "B1" );
// Array element 0 without index
res = t.distinct( "a.0.b" ).sort();
assert.eq( "a,b,c" , res.toString() , "B2" );
// Array element 1 without index
res = t.distinct( "a.1.b" ).sort();
assert.eq( "d,e,f" , res.toString() , "B3" );
// With index.
t.ensureIndex( { "a.b" : 1 } );
res = t.distinct( "a.b" );
res.sort()
assert.eq( "a,b,c,d,e,f,z" , res.toString() , "B4" );
// _id as an document containing an array
t.save( { _id : { a : [1,2,3] } } )
t.save( { _id : { a : [2,3,4] } } )
t.save( { _id : { a : [3,4,5] } } )
t.save( { _id : { a : 9 } } )
// Without index.
res = t.distinct( "_id.a" ).sort();
assert.eq( "1,2,3,4,5,9" , res.toString() , "C1" );
// Array element 0 without index.
res = t.distinct( "_id.a.0" ).sort();
assert.eq( "1,2,3" , res.toString() , "C2" );
// Array element 1 without index.
res = t.distinct( "_id.a.1" ).sort();
assert.eq( "2,3,4" , res.toString() , "C3" );
// With index.
t.ensureIndex( { "_id.a" : 1 } );
res = t.distinct( "_id.a" ).sort();
assert.eq( "1,2,3,4,5,9" , res.toString() , "C4" );
// Array element 0 with index.
res = t.distinct( "_id.a.0" ).sort();
assert.eq( "1,2,3" , res.toString() , "C5" );
// Array element 1 with index.
res = t.distinct( "_id.a.1" ).sort();
assert.eq( "2,3,4" , res.toString() , "C6" );