// Cannot implicitly shard accessed collections because of unsupported group operator on sharded // collection. // @tags: [assumes_unsharded_collection] t = db.jstests_group6; t.drop(); for (i = 1; i <= 10; ++i) { t.save({i: new NumberLong(i), y: 1}); } assert.eq.automsg( "55", "t.group( {key:'y', reduce:function(doc,out){ out.i += doc.i; }, initial:{i:0} } )[ 0 ].i"); t.drop(); for (i = 1; i <= 10; ++i) { if (i % 2 == 0) { t.save({i: new NumberLong(i), y: 1}); } else { t.save({i: i, y: 1}); } } assert.eq.automsg( "55", "t.group( {key:'y', reduce:function(doc,out){ out.i += doc.i; }, initial:{i:0} } )[ 0 ].i"); t.drop(); for (i = 1; i <= 10; ++i) { if (i % 2 == 1) { t.save({i: new NumberLong(i), y: 1}); } else { t.save({i: i, y: 1}); } } assert.eq.automsg( "55", "t.group( {key:'y', reduce:function(doc,out){ out.i += doc.i; }, initial:{i:0} } )[ 0 ].i"); assert.eq.automsg( "NumberLong(10)", "t.group( {$reduce: function(doc, prev) { prev.count += 1; }, initial: {count: new NumberLong(0) }} )[ 0 ].count");