summaryrefslogtreecommitdiff
path: root/jstests/storefunc.js
blob: f5d1c3be48a31e73372acee2d8d910cf2221e5fe (plain)
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
// Use a private sister database to avoid conflicts with other tests that use system.js
var testdb = db.getSisterDB("storefunc");

s = testdb.system.js;
s.remove({});
assert.eq( 0 , s.count() , "setup - A" );

s.save( { _id : "x" , value : "3" } );
assert.isnull( testdb.getLastError() , "setup - B" );
assert.eq( 1 , s.count() , "setup - C" );

s.remove( { _id : "x" } );
assert.eq( 0 , s.count() , "setup - D" );
s.save( { _id : "x" , value : "4" } );
assert.eq( 1 , s.count() , "setup - E" );

assert.eq( 4 , s.findOne( { _id : "x" } ).value , "E2 " );

assert.eq( 4 , s.findOne().value , "setup - F" );
s.update( { _id : "x" } , { $set : { value : 5  } } );
assert.eq( 1 , s.count() , "setup - G" );
assert.eq( 5 , s.findOne().value , "setup - H" );

assert.eq( 5 , testdb.eval( "return x" ) , "exec - 1 " );

s.update( { _id : "x" } , { $set : { value : 6  } } );
assert.eq( 1 , s.count() , "setup2 - A" );
assert.eq( 6 , s.findOne().value , "setup - B" );

assert.eq( 6 , testdb.eval( "return x" ) , "exec - 2 " );



s.insert( { _id : "bar" , value : function( z ){ return 17 + z; } } );
assert.eq( 22 , testdb.eval( "return bar(5);"  ) , "exec - 3 " );

assert( s.getIndexKeys().length > 0 , "no indexes" );
assert( s.getIndexKeys()[0]._id , "no _id index" );

assert.eq( "undefined" , testdb.eval( function(){ return typeof(zzz); } ) , "C1" );
s.save( { _id : "zzz" , value : 5 } )
assert.eq( "number" , testdb.eval( function(){ return typeof(zzz); } ) , "C2" );
s.remove( { _id : "zzz" } );
assert.eq( "undefined" , testdb.eval( function(){ return typeof(zzz); } ) , "C3" );