blob: e1b19ad2c1f9bc3f1bf6067b9cad953bf7870135 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
|
// projecting a non-existent subfield should work as it does in a query with projection
c = db.c;
c.drop();
c.save({a: [1]});
c.save({a: {c: 1}});
c.save({a: [{c: 1}, {b: 1, c: 1}, {c: 1}]});
c.save({a: 1});
c.save({b: 1});
// assert the aggregation and the query produce the same thing
assert.eq(c.aggregate({$project: {'a.b': 1}}).toArray(), c.find({}, {'a.b': 1}).toArray());
|