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
|
// SERVER-18222: Add $isArray aggregation expression.
(function() {
'use strict';
var coll = db.is_array_expr;
coll.drop();
// Non-array types.
assert.writeOK(coll.insert({_id: 0, x: 0}));
assert.writeOK(coll.insert({_id: 1, x: '0'}));
assert.writeOK(coll.insert({_id: 2, x: new ObjectId()}));
assert.writeOK(coll.insert({_id: 3, x: new NumberLong(0)}));
assert.writeOK(coll.insert({_id: 4, x: {y: []}}));
assert.writeOK(coll.insert({_id: 5, x: null}));
assert.writeOK(coll.insert({_id: 6, x: NaN}));
assert.writeOK(coll.insert({_id: 7, x: undefined}));
// Array types.
assert.writeOK(coll.insert({_id: 8, x: []}));
assert.writeOK(coll.insert({_id: 9, x: [0]}));
assert.writeOK(coll.insert({_id: 10, x: ['0']}));
// Project field is_array to represent whether the field x was an array.
var results = coll.aggregate([
{$sort: {_id: 1}},
{$project: {isArray: {$isArray: '$x'}}},
])
.toArray();
var expectedResults = [
{_id: 0, isArray: false},
{_id: 1, isArray: false},
{_id: 2, isArray: false},
{_id: 3, isArray: false},
{_id: 4, isArray: false},
{_id: 5, isArray: false},
{_id: 6, isArray: false},
{_id: 7, isArray: false},
{_id: 8, isArray: true},
{_id: 9, isArray: true},
{_id: 10, isArray: true},
];
assert.eq(results, expectedResults);
}());
|