~ubuntu-branches/ubuntu/trusty/mongodb/trusty-proposed

« back to all changes in this revision

Viewing changes to jstests/mr4.js

  • Committer: Bazaar Package Importer
  • Author(s): Antonin Kral
  • Date: 2010-01-29 19:48:45 UTC
  • Revision ID: james.westby@ubuntu.com-20100129194845-8wbmkf626fwcavc9
Tags: upstream-1.3.1
ImportĀ upstreamĀ versionĀ 1.3.1

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
 
 
2
t = db.mr4;
 
3
t.drop();
 
4
 
 
5
t.save( { x : 1 , tags : [ "a" , "b" ] } );
 
6
t.save( { x : 2 , tags : [ "b" , "c" ] } );
 
7
t.save( { x : 3 , tags : [ "c" , "a" ] } );
 
8
t.save( { x : 4 , tags : [ "b" , "c" ] } );
 
9
 
 
10
m = function(){
 
11
    this.tags.forEach(
 
12
        function(z){
 
13
            emit( z , { count : xx } );
 
14
        }
 
15
    );
 
16
};
 
17
 
 
18
r = function( key , values ){
 
19
    var total = 0;
 
20
    for ( var i=0; i<values.length; i++ ){
 
21
        total += values[i].count;
 
22
    }
 
23
    return { count : total };
 
24
};
 
25
 
 
26
res = t.mapReduce( m , r , { scope : { xx : 1 } } );
 
27
z = res.convertToSingleObject()
 
28
 
 
29
assert.eq( 3 , Object.keySet( z ).length , "A1" );
 
30
assert.eq( 2 , z.a.count , "A2" );
 
31
assert.eq( 3 , z.b.count , "A3" );
 
32
assert.eq( 3 , z.c.count , "A4" );
 
33
 
 
34
res.drop();
 
35
 
 
36
 
 
37
res = t.mapReduce( m , r , { scope : { xx : 2 } } );
 
38
z = res.convertToSingleObject()
 
39
 
 
40
assert.eq( 3 , Object.keySet( z ).length , "A1" );
 
41
assert.eq( 4 , z.a.count , "A2" );
 
42
assert.eq( 6 , z.b.count , "A3" );
 
43
assert.eq( 6 , z.c.count , "A4" );
 
44
 
 
45
res.drop();