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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
// test $set with array indicies
t = db.jstests_set7;
t.drop();
t.save( {a:[0,1,2,3]} );
t.update( {}, {$set:{"a.0":2}} );
assert.eq( [2,1,2,3], t.findOne().a );
t.update( {}, {$set:{"a.4":5}} );
assert.eq( [2,1,2,3,5], t.findOne().a );
t.update( {}, {$set:{"a.9":9}} );
assert.eq( [2,1,2,3,5,null,null,null,null,9], t.findOne().a );
t.drop();
t.save( {a:[0,1,2,3]} );
t.update( {}, {$set:{"a.9":9,"a.7":7}} );
assert.eq( [0,1,2,3,null,null,null,7,null,9], t.findOne().a );
t.drop();
t.save( {a:[0,1,2,3,4,5,6,7,8,9,10]} );
t.update( {}, {$set:{"a.11":11} } );
assert.eq( [0,1,2,3,4,5,6,7,8,9,10,11], t.findOne().a );
t.drop();
t.save( {} );
t.update( {}, {$set:{"a.0":4}} );
assert.eq( {"0":4}, t.findOne().a );
t.drop();
t.update( {"a.0":4}, {$set:{b:1}}, true );
assert.eq( {"0":4}, t.findOne().a );
t.drop();
t.save( {a:[]} );
t.update( {}, {$set:{"a.f":1}} );
assert( db.getLastError() );
assert.eq( [], t.findOne().a );
// Test requiring proper ordering of multiple mods.
t.drop();
t.save( {a:[0,1,2,3,4,5,6,7,8,9,10]} );
t.update( {}, {$set:{"a.11":11,"a.2":-2}} );
assert.eq( [0,1,-2,3,4,5,6,7,8,9,10,11], t.findOne().a );
// Test upsert case
t.drop();
t.update( {a:[0,1,2,3,4,5,6,7,8,9,10]}, {$set:{"a.11":11} }, true );
assert.eq( [0,1,2,3,4,5,6,7,8,9,10,11], t.findOne().a );
// SERVER-3750
t.drop();
t.save( {a:[]} );
t.update( {}, {$set:{"a.1500000":1}} ); // current limit
assert( db.getLastError() == null );
t.drop();
t.save( {a:[]} );
t.update( {}, {$set:{"a.1500001":1}} ); // 1 over limit
assert.eq(15891 , db.getLastErrorObj().code );
t.drop();
t.save( {a:[]} );
t.update( {}, {$set:{"a.1000000000":1}} ); // way over limit
assert.eq(15891 , db.getLastErrorObj().code );
|