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

yong pushed a commit to branch branch-2.8
in repository https://gitbox.apache.org/repos/asf/pulsar.git

commit beb15d23253a627021db6938102b3a463166590f
Author: Hang Chen <[email protected]>
AuthorDate: Fri Jan 28 02:08:25 2022 +0800

    Trim configuration value string which contains blank prefix or suffix 
string (#13984)
    
    (cherry picked from commit fa47a9fe3c9bf4d3dde4a34c683644e49d8830a0)
---
 .../org/apache/pulsar/common/util/FieldParser.java |  8 ++---
 .../apache/pulsar/common/util/FieldParserTest.java | 40 ++++++++++++++++++++++
 2 files changed, 44 insertions(+), 4 deletions(-)

diff --git 
a/pulsar-common/src/main/java/org/apache/pulsar/common/util/FieldParser.java 
b/pulsar-common/src/main/java/org/apache/pulsar/common/util/FieldParser.java
index a17045a..0aa19b2 100644
--- a/pulsar-common/src/main/java/org/apache/pulsar/common/util/FieldParser.java
+++ b/pulsar-common/src/main/java/org/apache/pulsar/common/util/FieldParser.java
@@ -141,7 +141,7 @@ public final class FieldParser {
                     f.setAccessible(true);
                     String v = properties.get(f.getName());
                     if (!StringUtils.isBlank(v)) {
-                        f.set(obj, value(v, f));
+                        f.set(obj, value(trim(v), f));
                     } else {
                         setEmptyValue(v, f, obj);
                     }
@@ -316,7 +316,7 @@ public final class FieldParser {
     public static <T> List<T> stringToList(String val, Class<T> type) {
         String[] tokens = trim(val).split(",");
         return Arrays.stream(tokens).map(t -> {
-            return convert(t, type);
+            return convert(trim(t), type);
         }).collect(Collectors.toList());
     }
 
@@ -332,7 +332,7 @@ public final class FieldParser {
     public static <T> Set<T> stringToSet(String val, Class<T> type) {
         String[] tokens = trim(val).split(",");
         return Arrays.stream(tokens).map(t -> {
-            return convert(t, type);
+            return convert(trim(t), type);
         }).collect(Collectors.toSet());
     }
 
@@ -343,7 +343,7 @@ public final class FieldParser {
             String[] keyValue = trim(token).split("=");
             checkArgument(keyValue.length == 2,
                     strValue + " map-value is not in correct format 
key1=value,key2=value2");
-            map.put(convert(keyValue[0], keyType), convert(keyValue[1], 
valueType));
+            map.put(convert(trim(keyValue[0]), keyType), 
convert(trim(keyValue[1]), valueType));
         }
         return map;
     }
diff --git 
a/pulsar-common/src/test/java/org/apache/pulsar/common/util/FieldParserTest.java
 
b/pulsar-common/src/test/java/org/apache/pulsar/common/util/FieldParserTest.java
index a085311..a8a3fee 100644
--- 
a/pulsar-common/src/test/java/org/apache/pulsar/common/util/FieldParserTest.java
+++ 
b/pulsar-common/src/test/java/org/apache/pulsar/common/util/FieldParserTest.java
@@ -19,9 +19,13 @@
 package org.apache.pulsar.common.util;
 
 import static org.testng.Assert.assertEquals;
+import static org.testng.Assert.assertTrue;
 
+import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
 
+import java.util.Set;
 import org.testng.annotations.Test;
 
 import com.google.common.collect.Maps;
@@ -35,6 +39,33 @@ public class FieldParserTest {
         properties.put("stringStringMap", "key1=value1,key2=value2");
         properties.put("stringIntMap", "key1=1,key2=2");
         properties.put("longStringMap", "1=value1,2=value2");
+
+        MyConfig config = new MyConfig();
+        FieldParser.update(properties, config);
+        assertEquals(config.name, "config");
+        assertEquals(config.stringStringMap.get("key1"), "value1");
+        assertEquals(config.stringStringMap.get("key2"), "value2");
+
+        assertEquals((int) config.stringIntMap.get("key1"), 1);
+        assertEquals((int) config.stringIntMap.get("key2"), 2);
+
+        assertEquals(config.longStringMap.get(1L), "value1");
+        assertEquals(config.longStringMap.get(2L), "value2");
+
+    }
+
+    @Test
+    public void testWithBlankVallueConfig() {
+        Map<String, String> properties = new HashMap<>();
+        properties.put("name", "  config   ");
+        properties.put("stringStringMap", "key1=value1  , key2=   value2  ");
+        properties.put("stringIntMap", "key1 = 1, key2 =  2 ");
+        properties.put("longStringMap", " 1 =value1  ,2  =value2    ");
+        properties.put("longList", " 1, 3,  8 , 0  ,9   ");
+        properties.put("stringList", "  aa, bb   ,  cc, ee  ");
+        properties.put("longSet", " 1, 3,  8 , 0 , 3, 1   ,9   ");
+        properties.put("stringSet", "  aa, bb   ,  cc, ee , bb,  aa ");
+
         MyConfig config = new MyConfig();
         FieldParser.update(properties, config);
         assertEquals(config.name, "config");
@@ -47,6 +78,11 @@ public class FieldParserTest {
         assertEquals(config.longStringMap.get(1L), "value1");
         assertEquals(config.longStringMap.get(2L), "value2");
 
+        assertEquals((long)config.longList.get(2), 8);
+        assertEquals(config.stringList.get(1), "bb");
+
+        assertTrue(config.longSet.contains(3L));
+        assertTrue(config.stringSet.contains("bb"));
     }
 
     public static class MyConfig {
@@ -54,6 +90,10 @@ public class FieldParserTest {
         public Map<String, String> stringStringMap;
         public Map<String, Integer> stringIntMap;
         public Map<Long, String> longStringMap;
+        public List<Long> longList;
+        public List<String> stringList;
+        public Set<Long> longSet;
+        public Set<String> stringSet;
     }
 
 }

Reply via email to