From 09dd24ca29948735a8a84f2a70741bb97f4d057b Mon Sep 17 00:00:00 2001 From: nemonlou Date: Thu, 22 Aug 2024 21:08:36 +0800 Subject: [PATCH] [GLUTEN-6981][CH]Not supported operator TakeOrderedAndProjectExecTransformer for BroadcastRelation --- .../clickhouse/CHSparkPlanExecApi.scala | 2 ++ .../GlutenClickHouseTPCDSParquetSuite.scala | 17 +++++++++++++++++ 2 files changed, 19 insertions(+) diff --git a/backends-clickhouse/src/main/scala/org/apache/gluten/backendsapi/clickhouse/CHSparkPlanExecApi.scala b/backends-clickhouse/src/main/scala/org/apache/gluten/backendsapi/clickhouse/CHSparkPlanExecApi.scala index 6761269651c1b..bfa59aee73186 100644 --- a/backends-clickhouse/src/main/scala/org/apache/gluten/backendsapi/clickhouse/CHSparkPlanExecApi.scala +++ b/backends-clickhouse/src/main/scala/org/apache/gluten/backendsapi/clickhouse/CHSparkPlanExecApi.scala @@ -524,6 +524,8 @@ class CHSparkPlanExecApi extends SparkPlanExecApi with Logging { wrapChild(r2c) case union: ColumnarUnionExec => wrapChild(union) + case ordered: TakeOrderedAndProjectExecTransformer => + wrapChild(ordered) case other => throw new GlutenNotSupportException( s"Not supported operator ${other.nodeName} for BroadcastRelation") diff --git a/backends-clickhouse/src/test/scala/org/apache/gluten/execution/tpcds/GlutenClickHouseTPCDSParquetSuite.scala b/backends-clickhouse/src/test/scala/org/apache/gluten/execution/tpcds/GlutenClickHouseTPCDSParquetSuite.scala index d0b270d2aae52..08f4522d9ce4b 100644 --- a/backends-clickhouse/src/test/scala/org/apache/gluten/execution/tpcds/GlutenClickHouseTPCDSParquetSuite.scala +++ b/backends-clickhouse/src/test/scala/org/apache/gluten/execution/tpcds/GlutenClickHouseTPCDSParquetSuite.scala @@ -336,5 +336,22 @@ class GlutenClickHouseTPCDSParquetSuite extends GlutenClickHouseTPCDSAbstractSui compareResultsAgainstVanillaSpark(sql5, compareResult = true, _ => {}) } + test("TakeOrderedAndProjectExecTransformer in broadcastRelation") { + val q = + """ + | with dd as ( + | select d_date_sk, count(*) as cn + | from date_dim + | where d_date_sk is not null + | group by d_date_sk + | order by cn desc + | limit 10) + | select count(ss.ss_sold_date_sk) + | from store_sales ss, dd + | where ss_sold_date_sk=dd.d_date_sk+1 + |""".stripMargin + runQueryAndCompare(q)(checkGlutenOperatorMatch[TakeOrderedAndProjectExecTransformer]) + } + } // scalastyle:on line.size.limit