This is an automated email from the ASF dual-hosted git repository. kirs pushed a commit to branch master in repository https://gitbox.apache.org/repos/asf/doris.git
The following commit(s) were added to refs/heads/master by this push: new 945edf8dbff [chore](dependencies)upgrade fe dependencies (#41142) 945edf8dbff is described below commit 945edf8dbffaa25c987bcefad59b6cde52772d4f Author: Calvin Kirs <k...@apache.org> AuthorDate: Wed Oct 9 14:24:20 2024 +0800 [chore](dependencies)upgrade fe dependencies (#41142) ## Proposed changes upgrade commons-configuration2 to 2.11.0 upgrade logging-interceptor to 4.12.0 upgrade commons-compress to 1.27.1 upgrade jetty-bom to 9.4.56.v20240826 upgrade azure-sdk to 1.2.27 Iceberg depends on configuration2, and configuration2 relies on a newer version of commons-lang3. However, there were significant breaking changes in commons-lang3, which made it incompatible.https://issues.apache.org/jira/browse/LANG-1705 As a result, I rewrote the clone method. --- .../doris/common/util/SerializationUtils.java | 71 +++++++++++++ .../main/java/org/apache/doris/qe/VariableMgr.java | 2 +- .../doris/common/util/SerializationUtilsTest.java | 110 +++++++++++++++++++++ .../datasource/iceberg/IcebergTransactionTest.java | 2 +- fe/pom.xml | 16 ++- 5 files changed, 194 insertions(+), 7 deletions(-) diff --git a/fe/fe-core/src/main/java/org/apache/doris/common/util/SerializationUtils.java b/fe/fe-core/src/main/java/org/apache/doris/common/util/SerializationUtils.java new file mode 100644 index 00000000000..cc18bcb0a10 --- /dev/null +++ b/fe/fe-core/src/main/java/org/apache/doris/common/util/SerializationUtils.java @@ -0,0 +1,71 @@ +// Licensed to the Apache Software Foundation (ASF) under one +// or more contributor license agreements. See the NOTICE file +// distributed with this work for additional information +// regarding copyright ownership. The ASF licenses this file +// to you under the Apache License, Version 2.0 (the +// "License"); you may not use this file except in compliance +// with the License. You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, +// software distributed under the License is distributed on an +// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +// KIND, either express or implied. See the License for the +// specific language governing permissions and limitations +// under the License. + +package org.apache.doris.common.util; + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.ObjectInputStream; +import java.io.ObjectOutputStream; +import java.io.Serializable; + +/** + * A utility class for serializing and deep cloning Serializable objects. + * <p> + * This class provides a method to clone an object by serializing it to a byte array + * and then deserializing it back to an object. This approach ensures that a deep copy + * is created, meaning that all objects referenced by the original object are also cloned. + * <p> + * Note: The object to be cloned must implement the {@link Serializable} interface. + */ +public class SerializationUtils { + + /** + * Clones a Serializable object by serializing and deserializing it. + * + * @param object the object to be cloned. Must be Serializable. + * @param <T> the type of the object to clone. Must extend Serializable. + * @return a deep copy of the provided object, or null if the input object is null. + * @throws RuntimeException if cloning fails due to I/O or class not found exceptions. + */ + public static <T> T clone(final T object) { + // Check if the object is null; if true, return null + if (object == null) { + return null; // Return null for null input + } + + try { + // Serialize the object to a byte array + try (ByteArrayOutputStream baos = new ByteArrayOutputStream(); // Output stream to hold the serialized data + ObjectOutputStream oos = new ObjectOutputStream(baos)) { // ObjectOutputStream for serialization + oos.writeObject(object); // Write the object to the output stream + oos.flush(); // Ensure all data is written + + // Deserialize the byte array back to an object + // Input stream from byte array + try (ByteArrayInputStream bais = new ByteArrayInputStream(baos.toByteArray()); + ObjectInputStream ois = new ObjectInputStream(bais)) { // ObjectInputStream for deserialization + return (T) ois.readObject(); // Read and return the cloned object + } + } + } catch (IOException | ClassNotFoundException e) { + // Wrap any exceptions thrown during serialization/deserialization + throw new RuntimeException("Cloning failed", e); + } + } +} diff --git a/fe/fe-core/src/main/java/org/apache/doris/qe/VariableMgr.java b/fe/fe-core/src/main/java/org/apache/doris/qe/VariableMgr.java index 8bb4210c605..a69ca0776e2 100644 --- a/fe/fe-core/src/main/java/org/apache/doris/qe/VariableMgr.java +++ b/fe/fe-core/src/main/java/org/apache/doris/qe/VariableMgr.java @@ -31,6 +31,7 @@ import org.apache.doris.common.ErrorCode; import org.apache.doris.common.ErrorReport; import org.apache.doris.common.PatternMatcher; import org.apache.doris.common.VariableAnnotation; +import org.apache.doris.common.util.SerializationUtils; import org.apache.doris.nereids.trees.expressions.literal.Literal; import org.apache.doris.persist.GlobalVarPersistInfo; @@ -40,7 +41,6 @@ import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableSortedMap; import com.google.common.collect.Lists; import com.google.common.collect.Maps; -import org.apache.commons.lang3.SerializationUtils; import org.apache.commons.lang3.StringUtils; import org.apache.commons.text.similarity.JaroWinklerDistance; import org.apache.logging.log4j.LogManager; diff --git a/fe/fe-core/src/test/java/org/apache/doris/common/util/SerializationUtilsTest.java b/fe/fe-core/src/test/java/org/apache/doris/common/util/SerializationUtilsTest.java new file mode 100644 index 00000000000..345fa4c5060 --- /dev/null +++ b/fe/fe-core/src/test/java/org/apache/doris/common/util/SerializationUtilsTest.java @@ -0,0 +1,110 @@ +// Licensed to the Apache Software Foundation (ASF) under one +// or more contributor license agreements. See the NOTICE file +// distributed with this work for additional information +// regarding copyright ownership. The ASF licenses this file +// to you under the Apache License, Version 2.0 (the +// "License"); you may not use this file except in compliance +// with the License. You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, +// software distributed under the License is distributed on an +// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +// KIND, either express or implied. See the License for the +// specific language governing permissions and limitations +// under the License. + +package org.apache.doris.common.util; + +import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.Test; + +import java.io.Serializable; +import java.util.HashMap; +import java.util.Objects; + +public class SerializationUtilsTest { + + + private final HashMap<String, Object> sampleMap = new HashMap<>(); + private final String sampleString = "sampleString"; + private final Integer sampleInteger = 456; + + public SerializationUtilsTest() { + sampleMap.put("KEY_ONE", sampleString); + sampleMap.put("KEY_TWO", sampleInteger); + } + + @Test + public void testClone() { + final Object clonedObject = SerializationUtils.clone(sampleMap); + Assertions.assertNotNull(clonedObject); + Assertions.assertTrue(clonedObject instanceof HashMap<?, ?>); + Assertions.assertNotSame(clonedObject, sampleMap); + + final HashMap<?, ?> clonedMap = (HashMap<?, ?>) clonedObject; + Assertions.assertEquals(sampleString, clonedMap.get("KEY_ONE")); + Assertions.assertNotSame(sampleString, clonedMap.get("KEY_ONE")); + Assertions.assertEquals(sampleInteger, clonedMap.get("KEY_TWO")); + Assertions.assertNotSame(sampleInteger, clonedMap.get("KEY_TWO")); + Assertions.assertEquals(sampleMap, clonedMap); + } + + @Test + public void testCloneNull() { + final Object clonedObject = SerializationUtils.clone(null); + Assertions.assertNull(clonedObject); + } + + @Test + public void testCloneWithWriteReplace() { + Child childObject = new Child(true); + Parent clonedParent = SerializationUtils.clone(childObject); + + Assertions.assertNotSame(childObject, clonedParent); + Assertions.assertEquals(new Parent(true), clonedParent); + } + + static class Parent implements Serializable { + private static final long serialVersionUID = 1L; + protected boolean status; + + Parent(boolean status) { + this.status = status; + } + + protected Parent(Parent parent) { + this.status = parent.status; + } + + protected Object writeReplace() { + return new Parent(this); + } + + @Override + public int hashCode() { + return Objects.hash(status); + } + + @Override + public boolean equals(Object obj) { + if (this == obj) { + return true; + } + if (obj == null || getClass() != obj.getClass()) { + return false; + } + Parent other = (Parent) obj; + return status == other.status; + } + } + + static class Child extends Parent { + private static final long serialVersionUID = 2L; + + Child(boolean status) { + super(status); + } + } +} diff --git a/fe/fe-core/src/test/java/org/apache/doris/datasource/iceberg/IcebergTransactionTest.java b/fe/fe-core/src/test/java/org/apache/doris/datasource/iceberg/IcebergTransactionTest.java index 432cc47f307..66c3ea19710 100644 --- a/fe/fe-core/src/test/java/org/apache/doris/datasource/iceberg/IcebergTransactionTest.java +++ b/fe/fe-core/src/test/java/org/apache/doris/datasource/iceberg/IcebergTransactionTest.java @@ -19,6 +19,7 @@ package org.apache.doris.datasource.iceberg; import org.apache.doris.common.UserException; import org.apache.doris.common.info.SimpleTableInfo; +import org.apache.doris.common.util.SerializationUtils; import org.apache.doris.datasource.ExternalCatalog; import org.apache.doris.nereids.trees.plans.commands.insert.IcebergInsertCommandContext; import org.apache.doris.thrift.TFileContent; @@ -27,7 +28,6 @@ import org.apache.doris.thrift.TIcebergCommitData; import com.google.common.collect.Maps; import mockit.Mock; import mockit.MockUp; -import org.apache.commons.lang3.SerializationUtils; import org.apache.hadoop.conf.Configuration; import org.apache.iceberg.CatalogProperties; import org.apache.iceberg.FileScanTask; diff --git a/fe/pom.xml b/fe/pom.xml index 56fba1a27fd..bc16baba127 100644 --- a/fe/pom.xml +++ b/fe/pom.xml @@ -239,9 +239,10 @@ under the License. <cglib.version>2.2</cglib.version> <commons-cli.version>1.4</commons-cli.version> <commons-filerupload.version>1.5</commons-filerupload.version> + <commons-configuration2.version>2.11.0</commons-configuration2.version> <commons-codec.version>1.13</commons-codec.version> <commons-lang.version>2.6</commons-lang.version> - <commons-lang3.version>3.9</commons-lang3.version> + <commons-lang3.version>3.17.0</commons-lang3.version> <commons-pool2.version>2.2</commons-pool2.version> <commons-pool.version>1.5.1</commons-pool.version> <commons-text.version>1.10.0</commons-text.version> @@ -287,7 +288,7 @@ under the License. <automaton.version>1.11-8</automaton.version> <generex.version>1.0.1</generex.version> <fabric8.kubernetes.version>6.7.2</fabric8.kubernetes.version> - <logging-interceptor.version>4.7.2</logging-interceptor.version> + <logging-interceptor.version>4.12.0</logging-interceptor.version> <okhttp.version>4.9.3</okhttp.version> <okio.version>3.4.0</okio.version> <snakeyaml.version>2.0</snakeyaml.version> @@ -324,7 +325,7 @@ under the License. <parquet.version>1.13.1</parquet.version> <commons-collections.version>3.2.2</commons-collections.version> - <commons-compress.version>1.22</commons-compress.version> + <commons-compress.version>1.27.1</commons-compress.version> <scala.version>2.12.10</scala.version> <kryo.version>4.0.2</kryo.version> <lombok.version>1.18.24</lombok.version> @@ -352,7 +353,7 @@ under the License. <woodstox.version>6.5.1</woodstox.version> <kerby.version>2.0.3</kerby.version> <jettison.version>1.5.4</jettison.version> - <jetty.version>9.4.55.v20240627</jetty.version> + <jetty.version>9.4.56.v20240826</jetty.version> <immutables.version>2.9.3</immutables.version> <ivy.version>2.5.2</ivy.version> <icu4j.version>75.1</icu4j.version> @@ -371,7 +372,7 @@ under the License. <jakarta.annotation-api.version>2.1.1</jakarta.annotation-api.version> <asm.version>9.4</asm.version> <airlift.version>202</airlift.version> - <azure.sdk.version>1.2.24</azure.sdk.version> + <azure.sdk.version>1.2.27</azure.sdk.version> <azure.sdk.batch.version>12.22.0</azure.sdk.batch.version> <semver4j.version>5.3.0</semver4j.version> <aliyun-sdk-oss.version>3.15.0</aliyun-sdk-oss.version> @@ -746,6 +747,11 @@ under the License. <artifactId>commons-fileupload</artifactId> <version>${commons-filerupload.version}</version> </dependency> + <dependency> + <groupId>org.apache.commons</groupId> + <artifactId>commons-configuration2</artifactId> + <version>${commons-configuration2.version}</version> + </dependency> <!-- https://mvnrepository.com/artifact/commons-codec/commons-codec --> <dependency> --------------------------------------------------------------------- To unsubscribe, e-mail: commits-unsubscr...@doris.apache.org For additional commands, e-mail: commits-h...@doris.apache.org