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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
/**
* Tests that language features introduced in version 5.2 are included in API Version 1.
*
* @tags: [
* requires_fcv_52,
* uses_api_parameters,
* ]
*/
(function() {
"use strict";
load("jstests/libs/api_version_helpers.js"); // For 'APIVersionHelpers'.
const collName = "api_version_new_52_language_features";
const viewName = collName + "_view";
const coll = db[collName];
coll.drop();
assert.commandWorked(coll.insert({a: 1, arr: [2, 1, 4]}));
const stablePipelines = [
[{$group: {_id: "$a", out: {$topN: {output: "$a", n: 2, sortBy: {a: 1}}}}}],
[{$group: {_id: "$a", out: {$top: {output: "$a", sortBy: {a: 1}}}}}],
[{$group: {_id: "$a", out: {$bottomN: {output: "$a", n: 2, sortBy: {a: 1}}}}}],
[{$group: {_id: "$a", out: {$bottom: {output: "$a", sortBy: {a: 1}}}}}],
[{$group: {_id: "$a", out: {$minN: {input: "$a", n: 2}}}}],
[{$group: {_id: "$a", out: {$maxN: {input: "$a", n: 2}}}}],
[{$group: {_id: "$a", out: {$firstN: {input: "$a", n: 2}}}}],
[{$group: {_id: "$a", out: {$lastN: {input: "$a", n: 2}}}}],
[{$set: {x: {$firstN: {input: "$arr", n: 2}}}}],
[{$set: {x: {$lastN: {input: "$arr", n: 2}}}}],
[{$set: {x: {$minN: {input: "$arr", n: 2}}}}],
[{$set: {x: {$maxN: {input: "$arr", n: 2}}}}],
[{$set: {x: {$sortArray: {input: "$arr", sortBy: 1}}}}],
[{
$setWindowFields: {
partitionBy: "$a",
sortBy: {a: 1},
output: {out: {$topN: {output: "$a", n: 2, sortBy: {a: 1}}}}
}
}],
[{
$setWindowFields: {
partitionBy: "$a",
sortBy: {a: 1},
output: {out: {$top: {output: "$a", sortBy: {a: 1}}}}
}
}],
[{
$setWindowFields: {
partitionBy: "$a",
sortBy: {a: 1},
output: {out: {$bottomN: {output: "$a", n: 2, sortBy: {a: 1}}}}
}
}],
[{
$setWindowFields: {
partitionBy: "$a",
sortBy: {a: 1},
output: {out: {$bottom: {output: "$a", sortBy: {a: 1}}}}
}
}],
[{
$setWindowFields:
{partitionBy: "$a", sortBy: {a: 1}, output: {out: {$minN: {input: "$a", n: 2}}}}
}],
[{
$setWindowFields:
{partitionBy: "$a", sortBy: {a: 1}, output: {out: {$maxN: {input: "$a", n: 2}}}}
}],
[{
$setWindowFields:
{partitionBy: "$a", sortBy: {a: 1}, output: {out: {$firstN: {input: "$a", n: 2}}}}
}],
[{
$setWindowFields:
{partitionBy: "$a", sortBy: {a: 1}, output: {out: {$lastN: {input: "$a", n: 2}}}}
}],
[{$setWindowFields: {partitionBy: "$a", sortBy: {a: 1}, output: {out: {$locf: "$a"}}}}],
[{$densify: {field: "val", partitionByFields: ["a"], range: {step: 1, bounds: "partition"}}}],
];
for (const pipeline of stablePipelines) {
// Assert running a pipeline with stages in API Version 1 succeeds.
APIVersionHelpers.assertAggregateSucceedsWithAPIStrict(pipeline, collName);
// Assert creating a view on a pipeline with stages in API Version 1 succeeds.
APIVersionHelpers.assertViewSucceedsWithAPIStrict(pipeline, viewName, collName);
// Assert error is not thrown when running without apiStrict=true.
assert.commandWorked(db.runCommand({
aggregate: coll.getName(),
pipeline: pipeline,
apiVersion: "1",
cursor: {},
}));
}
})();
|