aboutsummaryrefslogtreecommitdiffstats
path: root/yql/essentials/sql/v1/sql_ut.cpp
diff options
context:
space:
mode:
authorvokayndzop <vokayndzop@yandex-team.com>2025-01-29 16:25:37 +0300
committervokayndzop <vokayndzop@yandex-team.com>2025-01-29 17:18:25 +0300
commitbe07767ad39d693f1f8165c85adf05f925ff84bf (patch)
tree827003dadb10987e5aba89309eddb7902034ca31 /yql/essentials/sql/v1/sql_ut.cpp
parent6a31c2b82c0136d2a116b7be4e155d1898d4e7eb (diff)
downloadydb-be07767ad39d693f1f8165c85adf05f925ff84bf.tar.gz
MR: aggregation in MEASURES
commit_hash:5357736eed7a221ff5844d4351abe23e65930632
Diffstat (limited to 'yql/essentials/sql/v1/sql_ut.cpp')
-rw-r--r--yql/essentials/sql/v1/sql_ut.cpp39
1 files changed, 39 insertions, 0 deletions
diff --git a/yql/essentials/sql/v1/sql_ut.cpp b/yql/essentials/sql/v1/sql_ut.cpp
index 6bdd2c7e44..bd385c8feb 100644
--- a/yql/essentials/sql/v1/sql_ut.cpp
+++ b/yql/essentials/sql/v1/sql_ut.cpp
@@ -8162,3 +8162,42 @@ Y_UNIT_TEST_SUITE(QuerySplit) {
};)");
}
}
+
+Y_UNIT_TEST_SUITE(MatchRecognizeMeasuresAggregation) {
+ Y_UNIT_TEST(InsideSelect) {
+ ExpectFailWithError(R"sql(
+ SELECT FIRST(0), LAST(1);
+ )sql",
+ "<main>:2:20: Error: Cannot use FIRST and LAST outside the MATCH_RECOGNIZE context\n"
+ "<main>:2:30: Error: Cannot use FIRST and LAST outside the MATCH_RECOGNIZE context\n"
+ );
+ }
+
+ Y_UNIT_TEST(OutsideSelect) {
+ ExpectFailWithError(R"sql(
+ $lambda = ($x) -> (FIRST($x) + LAST($x));
+ SELECT $lambda(x) FROM plato.Input;
+ )sql",
+ "<main>:2:32: Error: Cannot use FIRST and LAST outside the MATCH_RECOGNIZE context\n"
+ "<main>:2:44: Error: Cannot use FIRST and LAST outside the MATCH_RECOGNIZE context\n"
+ );
+ }
+
+ Y_UNIT_TEST(AsAggregateFunction) {
+ ExpectFailWithError(R"sql(
+ SELECT FIRST(x), LAST(x) FROM plato.Input;
+ )sql",
+ "<main>:2:20: Error: Cannot use FIRST and LAST outside the MATCH_RECOGNIZE context\n"
+ "<main>:2:30: Error: Cannot use FIRST and LAST outside the MATCH_RECOGNIZE context\n"
+ );
+ }
+
+ Y_UNIT_TEST(AsWindowFunction) {
+ ExpectFailWithError(R"sql(
+ SELECT FIRST(x) OVER(), LAST(x) OVER() FROM plato.Input;
+ )sql",
+ "<main>:2:20: Error: Cannot use FIRST and LAST outside the MATCH_RECOGNIZE context\n"
+ "<main>:2:37: Error: Cannot use FIRST and LAST outside the MATCH_RECOGNIZE context\n"
+ );
+ }
+}