summaryrefslogtreecommitdiff
path: root/jstests/core/pull_or.js
blob: 9ef1e091d2942972696c3994a2f1f6281be8bf77 (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
// Cannot implicitly shard accessed collections because of following errmsg: A single
// update/delete on a sharded collection must contain an exact match on _id or contain the shard
// key.
// @tags: [assumes_unsharded_collection]

t = db.pull_or;
t.drop();

doc = {
    _id: 1,
    a: {b: [{x: 1}, {y: 'y'}, {x: 2}, {z: 'z'}]}
};

t.insert(doc);

t.update({}, {$pull: {'a.b': {'y': {$exists: true}}}});

assert.eq([{x: 1}, {x: 2}, {z: 'z'}], t.findOne().a.b);

t.drop();
t.insert(doc);
t.update({}, {$pull: {'a.b': {$or: [{'y': {$exists: true}}, {'z': {$exists: true}}]}}});

assert.eq([{x: 1}, {x: 2}], t.findOne().a.b);