summaryrefslogtreecommitdiff
path: root/src/mongo/db
diff options
context:
space:
mode:
authorTed Tuckman <ted.tuckman@mongodb.com>2023-01-05 20:20:00 +0000
committerEvergreen Agent <no-reply@evergreen.mongodb.com>2023-01-05 21:20:36 +0000
commitbee604d6abf17bb7f51b16d97d66e1eb5824574a (patch)
tree633cdd0ef1c6c06fd692e755a515e65f29008a6f /src/mongo/db
parent4350dacd31d3fe1adf51a07cf3d59406fa2351e3 (diff)
downloadmongo-bee604d6abf17bb7f51b16d97d66e1eb5824574a.tar.gz
SERVER-72315 Add lowering test for UnwindNode
Diffstat (limited to 'src/mongo/db')
-rw-r--r--src/mongo/db/exec/sbe/abt/abt_lower_test.cpp168
-rw-r--r--src/mongo/db/test_output/exec/sbe/a_b_t_plan_generation/lower_unwind_node.txt49
2 files changed, 143 insertions, 74 deletions
diff --git a/src/mongo/db/exec/sbe/abt/abt_lower_test.cpp b/src/mongo/db/exec/sbe/abt/abt_lower_test.cpp
index 11ac0338b01..d9304f24429 100644
--- a/src/mongo/db/exec/sbe/abt/abt_lower_test.cpp
+++ b/src/mongo/db/exec/sbe/abt/abt_lower_test.cpp
@@ -186,9 +186,9 @@ protected:
} while (changed);
}
- ABT createMultipleBindings(std::vector<std::pair<std::string, std::string>> bindingList,
- ABT source,
- std::string sourceBinding) {
+ ABT createBindings(std::vector<std::pair<std::string, std::string>> bindingList,
+ ABT source,
+ std::string sourceBinding) {
for (auto [fieldName, bindingName] : bindingList) {
auto field =
make<EvalPath>(make<PathGet>(FieldNameType(fieldName), make<PathIdentity>()),
@@ -224,17 +224,66 @@ TEST_F(ABTPlanGeneration, LowerConstantExpression) {
runExpressionVariation(ctx, "boolean false", Constant::boolean(false));
}
-TEST_F(ABTPlanGeneration, LowerVarExpression) {
+TEST_F(ABTPlanGeneration, LowerCollationNode) {
GoldenTestContext ctx(&goldenTestConfig);
ctx.printTestHeader(GoldenTestContext::HeaderFormat::Text);
+ properties::PhysProps physProps;
+ properties::setPropertyOverwrite<properties::ProjectionRequirement>(
+ physProps, properties::ProjectionRequirement(ProjectionNameOrderPreservingSet({"sortA"})));
+ NodeProps collationNodeProp{getNextNodeID(),
+ {},
+ {},
+ physProps,
+ boost::none,
+ CostType::fromDouble(0),
+ CostType::fromDouble(0),
+ {false}};
+
runNodeVariation(
ctx,
- "varInProj",
- _node(make<EvaluationNode>("proj0",
- _path(make<EvalPath>(make<PathGet>("a", make<PathIdentity>()),
- make<Variable>(scanLabel))),
- _node(scanForTest()))));
+ "Lower collation node with single field",
+ _node(make<CollationNode>(
+ properties::CollationRequirement({{"sortA", CollationOp::Ascending}}),
+ createBindings({{"a", "sortA"}}, _node(scanForTest()), "scan0")),
+ collationNodeProp));
+
+ // Sort on multiple fields.
+ properties::PhysProps physProps2;
+ properties::setPropertyOverwrite<properties::ProjectionRequirement>(
+ physProps2,
+ properties::ProjectionRequirement(ProjectionNameOrderPreservingSet({"sortA", "sortB"})));
+ NodeProps collationNodeProp2{getNextNodeID(),
+ {},
+ {},
+ physProps2,
+ boost::none,
+ CostType::fromDouble(0),
+ CostType::fromDouble(0),
+ {false}};
+ runNodeVariation(
+ ctx,
+ "Lower collation node with two fields",
+ _node(make<CollationNode>(
+ properties::CollationRequirement(
+ {{"sortA", CollationOp::Ascending}, {"sortB", CollationOp::Descending}}),
+ createBindings({{"a", "sortA"}, {"b", "sortB"}}, _node(scanForTest()), "scan0")),
+ collationNodeProp2));
+}
+
+TEST_F(ABTPlanGeneration, LowerCoScanNode) {
+ GoldenTestContext ctx(&goldenTestConfig);
+ ctx.printTestHeader(GoldenTestContext::HeaderFormat::Text);
+ runNodeVariation(ctx, "CoScan", _node(make<CoScanNode>()));
+}
+
+TEST_F(ABTPlanGeneration, LowerMultipleEvaluationNodes) {
+ GoldenTestContext ctx(&goldenTestConfig);
+ ctx.printTestHeader(GoldenTestContext::HeaderFormat::Text);
+ runNodeVariation(
+ ctx,
+ "Lower two chained evaluation nodes",
+ createBindings({{"a", "proj0"}, {"b", "proj1"}}, _node(scanForTest()), "scan0"));
}
TEST_F(ABTPlanGeneration, LowerFilterNode) {
@@ -281,54 +330,6 @@ TEST_F(ABTPlanGeneration, LowerLimitSkipNode) {
_node(make<LimitSkipNode>(properties::LimitSkipRequirement(4, 2), _node(scanForTest()))));
}
-TEST_F(ABTPlanGeneration, LowerCollationNode) {
- GoldenTestContext ctx(&goldenTestConfig);
- ctx.printTestHeader(GoldenTestContext::HeaderFormat::Text);
-
- properties::PhysProps physProps;
- properties::setPropertyOverwrite<properties::ProjectionRequirement>(
- physProps, properties::ProjectionRequirement(ProjectionNameOrderPreservingSet({"sortA"})));
- NodeProps collationNodeProp{getNextNodeID(),
- {},
- {},
- physProps,
- boost::none,
- CostType::fromDouble(0),
- CostType::fromDouble(0),
- {false}};
-
- runNodeVariation(
- ctx,
- "Lower collation node with single field",
- _node(make<CollationNode>(
- properties::CollationRequirement({{"sortA", CollationOp::Ascending}}),
- createMultipleBindings({{"a", "sortA"}}, _node(scanForTest()), "scan0")),
- collationNodeProp));
-
- // Sort on multiple fields.
- properties::PhysProps physProps2;
- properties::setPropertyOverwrite<properties::ProjectionRequirement>(
- physProps2,
- properties::ProjectionRequirement(ProjectionNameOrderPreservingSet({"sortA", "sortB"})));
- NodeProps collationNodeProp2{getNextNodeID(),
- {},
- {},
- physProps2,
- boost::none,
- CostType::fromDouble(0),
- CostType::fromDouble(0),
- {false}};
- runNodeVariation(
- ctx,
- "Lower collation node with two fields",
- _node(make<CollationNode>(
- properties::CollationRequirement(
- {{"sortA", CollationOp::Ascending}, {"sortB", CollationOp::Descending}}),
- createMultipleBindings(
- {{"a", "sortA"}, {"b", "sortB"}}, _node(scanForTest()), "scan0")),
- collationNodeProp2));
-}
-
TEST_F(ABTPlanGeneration, LowerPhysicalScanNode) {
GoldenTestContext ctx(&goldenTestConfig);
ctx.printTestHeader(GoldenTestContext::HeaderFormat::Text);
@@ -369,38 +370,57 @@ TEST_F(ABTPlanGeneration, LowerPhysicalScanNode) {
}
}
-TEST_F(ABTPlanGeneration, LowerCoScanNode) {
+TEST_F(ABTPlanGeneration, LowerUniqueNode) {
GoldenTestContext ctx(&goldenTestConfig);
ctx.printTestHeader(GoldenTestContext::HeaderFormat::Text);
- runNodeVariation(ctx, "CoScan", _node(make<CoScanNode>()));
+ runNodeVariation(
+ ctx,
+ "Lower unique node with single key",
+ _node(make<UniqueNode>(ProjectionNameVector{"proj0"},
+ createBindings({{"a", "proj0"}}, _node(scanForTest()), "scan0"))));
+
+
+ runNodeVariation(
+ ctx,
+ "Lower unique node with multiple keys",
+ _node(make<UniqueNode>(ProjectionNameVector{"proj0", "proj1", "proj2"},
+ createBindings({{"a", "proj0"}, {"b", "proj1"}, {"c", "proj2"}},
+ _node(scanForTest()),
+ "scan0"))));
}
-TEST_F(ABTPlanGeneration, LowerMultipleEvaluationNodes) {
+TEST_F(ABTPlanGeneration, LowerUnwindNode) {
GoldenTestContext ctx(&goldenTestConfig);
ctx.printTestHeader(GoldenTestContext::HeaderFormat::Text);
runNodeVariation(
ctx,
- "Lower two chained evaluation nodes",
- createMultipleBindings({{"a", "proj0"}, {"b", "proj1"}}, _node(scanForTest()), "scan0"));
+ "Lower UnwindNode discard non-arrays",
+ _node(make<UnwindNode>(ProjectionName("proj0"),
+ ProjectionName("proj0_pid"),
+ false,
+ createBindings({{"a", "proj0"}}, _node(scanForTest()), "scan0"))));
+
+ runNodeVariation(
+ ctx,
+ "Lower UnwindNode keep non-arrays",
+ _node(make<UnwindNode>(ProjectionName("proj0"),
+ ProjectionName("proj0_pid"),
+ true,
+ createBindings({{"a", "proj0"}}, _node(scanForTest()), "scan0"))));
}
-TEST_F(ABTPlanGeneration, LowerUniqueNode) {
+TEST_F(ABTPlanGeneration, LowerVarExpression) {
GoldenTestContext ctx(&goldenTestConfig);
ctx.printTestHeader(GoldenTestContext::HeaderFormat::Text);
- runNodeVariation(ctx,
- "Lower unique node with single key",
- _node(make<UniqueNode>(
- ProjectionNameVector{"proj0"},
- createMultipleBindings({{"a", "proj0"}}, _node(scanForTest()), "scan0"))));
-
runNodeVariation(
ctx,
- "Lower unique node with multiple keys",
- _node(make<UniqueNode>(
- ProjectionNameVector{"proj0", "proj1", "proj2"},
- createMultipleBindings(
- {{"a", "proj0"}, {"b", "proj1"}, {"c", "proj2"}}, _node(scanForTest()), "scan0"))));
+ "varInProj",
+ _node(make<EvaluationNode>("proj0",
+ _path(make<EvalPath>(make<PathGet>("a", make<PathIdentity>()),
+ make<Variable>(scanLabel))),
+ _node(scanForTest()))));
}
+
} // namespace
} // namespace mongo::optimizer
diff --git a/src/mongo/db/test_output/exec/sbe/a_b_t_plan_generation/lower_unwind_node.txt b/src/mongo/db/test_output/exec/sbe/a_b_t_plan_generation/lower_unwind_node.txt
new file mode 100644
index 00000000000..e8080cd2add
--- /dev/null
+++ b/src/mongo/db/test_output/exec/sbe/a_b_t_plan_generation/lower_unwind_node.txt
@@ -0,0 +1,49 @@
+# Golden test output of ABTPlanGeneration/LowerUnwindNode
+
+==== VARIATION: Lower UnwindNode discard non-arrays ====
+-- INPUT:
+Unwind []
+| BindBlock:
+| [proj0]
+| Source []
+| [proj0_pid]
+| Source []
+Evaluation []
+| BindBlock:
+| [proj0]
+| FunctionCall [getField]
+| | Const ["a"]
+| Variable [scan0]
+PhysicalScan [{'<root>': scan0}, collName]
+ BindBlock:
+ [scan0]
+ Source []
+
+-- OUTPUT:
+[5] unwind s3 s4 s2 false
+[3] project [s2 = getField(s1, "a")]
+[1] scan s1 none none none none none [] @"<collUUID>" true false
+
+==== VARIATION: Lower UnwindNode keep non-arrays ====
+-- INPUT:
+Unwind [retainNonArrays]
+| BindBlock:
+| [proj0]
+| Source []
+| [proj0_pid]
+| Source []
+Evaluation []
+| BindBlock:
+| [proj0]
+| FunctionCall [getField]
+| | Const ["a"]
+| Variable [scan0]
+PhysicalScan [{'<root>': scan0}, collName]
+ BindBlock:
+ [scan0]
+ Source []
+
+-- OUTPUT:
+[11] unwind s3 s4 s2 true
+[9] project [s2 = getField(s1, "a")]
+[7] scan s1 none none none none none [] @"<collUUID>" true false