summaryrefslogtreecommitdiff
path: root/jstests/core/api_version_new_52_language_features.js
blob: b1ab2107fbf968d2ec42983287875cd265c9a1df (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
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
98
99
/**
 * Tests that language features introduced in version 5.2 are included in API Version 1.
 *
 * The test runs commands that are not allowed with security token: top.
 * @tags: [
 *   not_allowed_with_security_token,
 *   requires_fcv_60,
 *   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: {},
    }));
}
})();