diff --git a/spark-sql-application/src/main/scala/org/apache/spark/sql/FlintJob.scala b/spark-sql-application/src/main/scala/org/apache/spark/sql/FlintJob.scala index aeaa57499..51bf4d734 100644 --- a/spark-sql-application/src/main/scala/org/apache/spark/sql/FlintJob.scala +++ b/spark-sql-application/src/main/scala/org/apache/spark/sql/FlintJob.scala @@ -286,9 +286,14 @@ object FlintJob extends Logging { } catch { case e: IllegalStateException if e.getCause().getMessage().contains("index_not_found_exception") => - osClient.createIndex(resultIndex, mapping) match { - case Right(_) => Right(()) - case Left(errorMsg) => Left(errorMsg) + try { + osClient.createIndex(resultIndex, mapping) + Right(()) + } catch { + case e: Exception => + val error = s"Failed to create result index $resultIndex" + logError(error, e) + Left(error) } case e: Exception => val error = "Failed to verify existing mapping" diff --git a/spark-sql-application/src/main/scala/org/apache/spark/sql/OSClient.scala b/spark-sql-application/src/main/scala/org/apache/spark/sql/OSClient.scala index e40e8dc7c..9add8be79 100644 --- a/spark-sql-application/src/main/scala/org/apache/spark/sql/OSClient.scala +++ b/spark-sql-application/src/main/scala/org/apache/spark/sql/OSClient.scala @@ -42,7 +42,7 @@ class OSClient(val flintOptions: FlintOptions) extends Logging { * use Either for representing success or failure. A Right value indicates success, while a * Left value indicates an error. */ - def createIndex(osIndexName: String, mapping: String): Either[String, Unit] = { + def createIndex(osIndexName: String, mapping: String): Unit = { logInfo(s"create $osIndexName") using(FlintClientBuilder.build(flintOptions).createClient()) { client => @@ -52,12 +52,9 @@ class OSClient(val flintOptions: FlintOptions) extends Logging { try { client.indices.create(request, RequestOptions.DEFAULT) logInfo(s"create $osIndexName successfully") - Right(()) } catch { case e: Exception => - val error = s"Failed to create result index $osIndexName" - logError(error, e) - Left(error) + throw new IllegalStateException(s"Failed to create result index $osIndexName", e); } } }