From 4a34b7f23b74e7454ecc228b44a19a0b791df780 Mon Sep 17 00:00:00 2001 From: Ladislav Sulak Date: Thu, 29 Feb 2024 14:26:30 +0100 Subject: [PATCH] #105: getSimpleName is using reflection, and reflection in Java 8 and Java 11 uses different algorithm - JLS3 "Binary Compatibility" you can read more about it if interested; this PR addresses that and removes reflection completely from this SerDe --- .../atum/model/utils/SerializationUtils.scala | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/model/src/main/scala/za/co/absa/atum/model/utils/SerializationUtils.scala b/model/src/main/scala/za/co/absa/atum/model/utils/SerializationUtils.scala index f690bb7ee..fcd95568d 100644 --- a/model/src/main/scala/za/co/absa/atum/model/utils/SerializationUtils.scala +++ b/model/src/main/scala/za/co/absa/atum/model/utils/SerializationUtils.scala @@ -66,15 +66,20 @@ object SerializationUtils { private case object ResultValueTypeSerializer extends CustomSerializer[ResultValueType](format => ( { case JString(resultValType) => resultValType match { - case "String" => String - case "Long" => Long - case "BigDecimal" => BigDecimal - case "Double" => Double + case "String" => String + case "Long" => Long + case "BigDecimal" => BigDecimal + case "Double" => Double } case JNull => null }, { - case resultValType: ResultValueType => JString(resultValType.getClass.getSimpleName.replace("$","")) + case resultValType: ResultValueType => resultValType match { + case String => JString("String") + case Long => JString("Long") + case BigDecimal => JString("BigDecimal") + case Double => JString("Double") + } })) }