blob: 42b0d93bb1587176721a51d9c22506729e2a2fd8 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
// 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]
let t = db.pull_or;
t.drop();
let 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);
|