Trim configuration value string which contains blank prefix or suffix string (#13984)

(cherry picked from commit fa47a9fe3c9bf4d3dde4a34c683644e49d8830a0)
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 8717fcd..e0b6610 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
@@ -142,7 +142,7 @@
                     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);
                     }
@@ -317,7 +317,7 @@
     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());
     }
 
@@ -333,7 +333,7 @@
     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());
     }
 
@@ -344,7 +344,7 @@
             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,7 @@
         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");
@@ -49,11 +54,46 @@
 
     }
 
+    @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");
+        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");
+
+        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 {
         public String name;
         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;
     }
 
 }