summaryrefslogtreecommitdiff
path: root/jstests/core/basic3.js
blob: 61f68047d30c6fcf6bead67764d0b4b48656a6eb (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
45
// Tests that "." cannot be in field names
t = db.getCollection( "foo_basic3" );
t.drop();

//more diagnostics on bad save, if exception fails
doBadSave = function(param) {
    print("doing save with " + tojson(param));
    var res = t.save(param);
    // Should not get here.
    printjson(res);
};

//more diagnostics on bad save, if exception fails
doBadUpdate = function(query, update) {
    print("doing update with " + tojson(query) + " " + tojson(update));
    var res = t.update(query, update);
    // Should not get here.
    printjson(res);
};

assert.throws(doBadSave, [{"a.b":5}], ". in names aren't allowed doesn't work");

assert.throws(doBadSave, 
              [{ "x" : { "a.b" : 5 } }], 
              ". in embedded names aren't allowed doesn't work");

// following tests make sure update keys are checked
t.save({"a": 0,"b": 1});

assert.throws(doBadUpdate, [{a:0}, { "b.b" : 1 }], 
              "must deny '.' in key of update");

// upsert with embedded doc
assert.throws(doBadUpdate, [{a:10}, { c: {"b.b" : 1 }}], 
              "must deny embedded '.' in key of update");

// if it is a modifier, it should still go through
t.update({"a": 0}, {$set: { "c.c": 1}});
t.update({"a": 0}, {$inc: { "c.c": 1}});

// edge cases
assert.throws(doBadUpdate, [{a:0}, { "":{"b.b" : 1} }], 
              "must deny '' embedded '.' in key of update");
t.update({"a": 0}, {});