This is an automated email from the ASF dual-hosted git repository.

hongze pushed a commit to branch main
in repository https://gitbox.apache.org/repos/asf/incubator-gluten.git


The following commit(s) were added to refs/heads/main by this push:
     new efeef65f09 [GLUTEN-7143][VL] RAS: Revert #7731, disable the relevant 
test cases since RAS doesn't report fallback details due to #7763 (#7764)
efeef65f09 is described below

commit efeef65f0984dbe0dca9f10177993f10eeb53a95
Author: Hongze Zhang <[email protected]>
AuthorDate: Fri Nov 1 14:27:28 2024 +0800

    [GLUTEN-7143][VL] RAS: Revert #7731, disable the relevant test cases since 
RAS doesn't report fallback details due to #7763 (#7764)
---
 .../main/scala/org/apache/gluten/ras/memo/Memo.scala |  1 -
 .../extension/columnar/enumerated/RasOffload.scala   | 15 +++++++++------
 .../spark/sql/gluten/GlutenFallbackSuite.scala       |  5 +++++
 .../expressions/GlutenExpressionMappingSuite.scala   | 20 +++++++++++---------
 4 files changed, 25 insertions(+), 16 deletions(-)

diff --git 
a/gluten-ras/common/src/main/scala/org/apache/gluten/ras/memo/Memo.scala 
b/gluten-ras/common/src/main/scala/org/apache/gluten/ras/memo/Memo.scala
index c671203573..68a8ca7457 100644
--- a/gluten-ras/common/src/main/scala/org/apache/gluten/ras/memo/Memo.scala
+++ b/gluten-ras/common/src/main/scala/org/apache/gluten/ras/memo/Memo.scala
@@ -158,7 +158,6 @@ object Memo {
         }
 
         // The new node already memorized to memo.
-
         val cachedCluster = parent.cache(cacheKey)
         if (cachedCluster == targetCluster) {
           // The new node already memorized to memo and in the target cluster.
diff --git 
a/gluten-substrait/src/main/scala/org/apache/gluten/extension/columnar/enumerated/RasOffload.scala
 
b/gluten-substrait/src/main/scala/org/apache/gluten/extension/columnar/enumerated/RasOffload.scala
index 15522e4986..84a09d2cce 100644
--- 
a/gluten-substrait/src/main/scala/org/apache/gluten/extension/columnar/enumerated/RasOffload.scala
+++ 
b/gluten-substrait/src/main/scala/org/apache/gluten/extension/columnar/enumerated/RasOffload.scala
@@ -17,7 +17,7 @@
 package org.apache.gluten.extension.columnar.enumerated
 
 import org.apache.gluten.extension.GlutenPlan
-import org.apache.gluten.extension.columnar.{FallbackTags, OffloadSingleNode}
+import org.apache.gluten.extension.columnar.OffloadSingleNode
 import org.apache.gluten.extension.columnar.rewrite.RewriteSingleNode
 import org.apache.gluten.extension.columnar.validator.Validator
 import org.apache.gluten.ras.path.Pattern
@@ -81,7 +81,7 @@ object RasOffload {
         validator.validate(node) match {
           case Validator.Passed =>
           case Validator.Failed(reason) =>
-            FallbackTags.add(node, reason)
+            // TODO: Tag the original plan with fallback reason.
             return List.empty
         }
 
@@ -105,15 +105,18 @@ object RasOffload {
                 val offloadedNodes = offloadedPlan.collect[GlutenPlan] { case 
t: GlutenPlan => t }
                 val outComes = 
offloadedNodes.map(_.doValidate()).filter(!_.ok())
                 if (outComes.nonEmpty) {
-                  // 5. If native validation fails on the offloaded node, 
return the
-                  // original one.
-                  outComes.foreach(FallbackTags.add(from, _))
+                  // 4. If native validation fails on at least one of the 
offloaded nodes, return
+                  // the original one.
+                  //
+                  // TODO: Tag the original plan with fallback reason. This is 
a non-trivial work
+                  //  in RAS as the query plan we got here may be a copy so 
may not propagate tags
+                  //  to original plan.
                   from
                 } else {
                   offloadedPlan
                 }
               case Validator.Failed(reason) =>
-                FallbackTags.add(from, reason)
+                // TODO: Tag the original plan with fallback reason.
                 from
             }
         }
diff --git 
a/gluten-ut/spark34/src/test/scala/org/apache/spark/sql/gluten/GlutenFallbackSuite.scala
 
b/gluten-ut/spark34/src/test/scala/org/apache/spark/sql/gluten/GlutenFallbackSuite.scala
index d7ec1f0fa5..7855f289a7 100644
--- 
a/gluten-ut/spark34/src/test/scala/org/apache/spark/sql/gluten/GlutenFallbackSuite.scala
+++ 
b/gluten-ut/spark34/src/test/scala/org/apache/spark/sql/gluten/GlutenFallbackSuite.scala
@@ -21,6 +21,7 @@ import org.apache.gluten.events.GlutenPlanFallbackEvent
 import org.apache.gluten.execution.FileSourceScanExecTransformer
 import org.apache.gluten.utils.BackendTestUtils
 
+import org.apache.spark.SparkConf
 import org.apache.spark.scheduler.{SparkListener, SparkListenerEvent}
 import org.apache.spark.sql.{GlutenSQLTestsTrait, Row}
 import org.apache.spark.sql.execution.ProjectExec
@@ -32,6 +33,10 @@ import org.apache.spark.status.ElementTrackingStore
 import scala.collection.mutable.ArrayBuffer
 
 class GlutenFallbackSuite extends GlutenSQLTestsTrait with 
AdaptiveSparkPlanHelper {
+  override def sparkConf: SparkConf = {
+    super.sparkConf
+      .set(GlutenConfig.RAS_ENABLED.key, "false")
+  }
 
   testGluten("test fallback logging") {
     val testAppender = new LogAppender("fallback reason")
diff --git 
a/gluten-ut/test/src/test/scala/org/apache/gluten/expressions/GlutenExpressionMappingSuite.scala
 
b/gluten-ut/test/src/test/scala/org/apache/gluten/expressions/GlutenExpressionMappingSuite.scala
index 68b9ab1a36..693b46283c 100644
--- 
a/gluten-ut/test/src/test/scala/org/apache/gluten/expressions/GlutenExpressionMappingSuite.scala
+++ 
b/gluten-ut/test/src/test/scala/org/apache/gluten/expressions/GlutenExpressionMappingSuite.scala
@@ -98,16 +98,18 @@ class GlutenExpressionMappingSuite
   testWithSpecifiedSparkVersion(
     "GLUTEN-7213: Check fallback reason with CheckOverflowInTableInsert",
     Some("3.4")) {
-    withTable("t1", "t2") {
-      sql("create table t1 (a float) using parquet")
-      sql("insert into t1 values(1.1)")
-      sql("create table t2 (b decimal(10,4)) using parquet")
+    withSQLConf(GlutenConfig.RAS_ENABLED.key -> "false") {
+      withTable("t1", "t2") {
+        sql("create table t1 (a float) using parquet")
+        sql("insert into t1 values(1.1)")
+        sql("create table t2 (b decimal(10,4)) using parquet")
 
-      val msg =
-        "CheckOverflowInTableInsert is used in ANSI mode, but Gluten does not 
support ANSI mode."
-      import org.apache.spark.sql.execution.GlutenImplicits._
-      val fallbackSummary = sql("insert overwrite t2 select * from 
t1").fallbackSummary()
-      
assert(fallbackSummary.fallbackNodeToReason.flatMap(_.values).exists(_.contains(msg)))
+        val msg =
+          "CheckOverflowInTableInsert is used in ANSI mode, but Gluten does 
not support ANSI mode."
+        import org.apache.spark.sql.execution.GlutenImplicits._
+        val fallbackSummary = sql("insert overwrite t2 select * from 
t1").fallbackSummary()
+        
assert(fallbackSummary.fallbackNodeToReason.flatMap(_.values).exists(_.contains(msg)))
+      }
     }
   }
 }


---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to