summaryrefslogtreecommitdiff
path: root/jstests
diff options
context:
space:
mode:
Diffstat (limited to 'jstests')
-rw-r--r--jstests/aggregation/bugs/window_inside_facet.js77
-rw-r--r--jstests/libs/override_methods/implicitly_wrap_pipelines_in_facets.js2
2 files changed, 78 insertions, 1 deletions
diff --git a/jstests/aggregation/bugs/window_inside_facet.js b/jstests/aggregation/bugs/window_inside_facet.js
new file mode 100644
index 00000000000..baf9fcd5150
--- /dev/null
+++ b/jstests/aggregation/bugs/window_inside_facet.js
@@ -0,0 +1,77 @@
+// Test that $setWindowFields inside $facet correctly propagates its state when it encounters paused
+// execution.
+(function() {
+"use strict";
+
+const coll = db.window_inside_facet;
+coll.drop();
+
+assert.commandWorked(coll.insert([
+ {_id: 'a', n: 0},
+ {_id: 'b', n: 1},
+ {_id: 'c', n: 2},
+ {_id: 'd', n: 3},
+ {_id: 'e', n: 4},
+ {_id: 'f', n: 5}
+]));
+
+// Test window with a sort within $facet alongside another pipeline that will cause it to pause
+// execution. The sort will cause the window to hit paused execution immediately, before an advance.
+let result =
+ coll.aggregate({
+ $facet: {
+ facet1: [{
+ $setWindowFields: {
+ output: {prevId: {$shift: {by: -1, default: null, output: "$_id"}}},
+ sortBy: {_id: 1}
+ }
+ }],
+ facet2: [{$count: "count"}]
+ }
+ })
+ .toArray()[0];
+let expected = {
+ facet1: [
+ {_id: 'a', n: 0, prevId: null},
+ {_id: 'b', n: 1, prevId: 'a'},
+ {_id: 'c', n: 2, prevId: 'b'},
+ {_id: 'd', n: 3, prevId: 'c'},
+ {_id: 'e', n: 4, prevId: 'd'},
+ {_id: 'f', n: 5, prevId: 'e'}
+ ],
+ facet2: [{count: 6}]
+};
+assert.docEq(expected, result, "$setWindowFields with sort failed.");
+
+// Test window with no sort within $facet alongside another pipeline that will cause it to pause
+// execution. Having no sort will cause the window to hit paused execution after advancing.
+result = coll.aggregate({
+ $facet: {
+ facet1: [
+ {
+ $setWindowFields: {
+ output: {
+ min: {$min: "$n"},
+ max: {$max: "$n"},
+ }
+ }
+ },
+ {$sort: {_id: 1}}
+ ],
+ facet2: [{$count: "count"}]
+ }
+ })
+ .toArray()[0];
+expected = {
+ facet1: [
+ {_id: 'a', n: 0, min: 0, max: 5},
+ {_id: 'b', n: 1, min: 0, max: 5},
+ {_id: 'c', n: 2, min: 0, max: 5},
+ {_id: 'd', n: 3, min: 0, max: 5},
+ {_id: 'e', n: 4, min: 0, max: 5},
+ {_id: 'f', n: 5, min: 0, max: 5}
+ ],
+ facet2: [{count: 6}]
+};
+assert.docEq(expected, result, "$setWindowFields without sort failed.");
+}());
diff --git a/jstests/libs/override_methods/implicitly_wrap_pipelines_in_facets.js b/jstests/libs/override_methods/implicitly_wrap_pipelines_in_facets.js
index 92199015faf..0d4e0158b3e 100644
--- a/jstests/libs/override_methods/implicitly_wrap_pipelines_in_facets.js
+++ b/jstests/libs/override_methods/implicitly_wrap_pipelines_in_facets.js
@@ -67,7 +67,7 @@ Mongo.prototype.runCommand = function(dbName, cmdObj, options) {
}
cmdObj.pipeline = [
- {$facet: {originalPipeline: originalPipeline}},
+ {$facet: {originalPipeline: originalPipeline, extraPipeline: [{$count: "count"}]}},
{$unwind: '$originalPipeline'},
{$replaceRoot: {newRoot: '$originalPipeline'}},
];