summaryrefslogtreecommitdiffstats
path: root/common-app-api
diff options
context:
space:
mode:
Diffstat (limited to 'common-app-api')
-rw-r--r--common-app-api/src/main/java/org/openecomp/sdc/common/impl/FSConfigurationSource.java43
-rw-r--r--common-app-api/src/test/java/org/openecomp/sdc/common/impl/FSConfigurationSourceTest.java61
2 files changed, 75 insertions, 29 deletions
diff --git a/common-app-api/src/main/java/org/openecomp/sdc/common/impl/FSConfigurationSource.java b/common-app-api/src/main/java/org/openecomp/sdc/common/impl/FSConfigurationSource.java
index 3f2f6a7a01..3aa220c5bc 100644
--- a/common-app-api/src/main/java/org/openecomp/sdc/common/impl/FSConfigurationSource.java
+++ b/common-app-api/src/main/java/org/openecomp/sdc/common/impl/FSConfigurationSource.java
@@ -16,10 +16,14 @@
* See the License for the specific language governing permissions and
* limitations under the License.
* ============LICENSE_END=========================================================
+ * Modifications copyright (c) 2019 Nokia
+ * ================================================================================
*/
package org.openecomp.sdc.common.impl;
+import java.util.Arrays;
+import java.util.stream.Collectors;
import org.openecomp.sdc.common.api.ConfigurationListener;
import org.openecomp.sdc.common.api.ConfigurationSource;
import org.openecomp.sdc.common.api.Constants;
@@ -32,10 +36,10 @@ import org.openecomp.sdc.common.util.YamlToObjectConverter;
*/
public class FSConfigurationSource implements ConfigurationSource {
- private YamlToObjectConverter yamlToObjectConverter = new YamlToObjectConverter();
+ private final YamlToObjectConverter yamlToObjectConverter = new YamlToObjectConverter();
- private ConfigFileChangeListener changeListener = null;
- private String appConfigDir = null;
+ private final ConfigFileChangeListener changeListener;
+ private final String appConfigDir;
public FSConfigurationSource(ConfigFileChangeListener changeListener, String appConfigDir) {
super();
@@ -81,34 +85,15 @@ public class FSConfigurationSource implements ConfigurationSource {
* @param className
* @return file name based on the class name
*/
- private static <T> String calculateFileName(Class<T> className) {
-
+ static <T> String calculateFileName(Class<T> className) {
String[] words = className.getSimpleName().split("(?=\\p{Upper})");
- StringBuilder builder = new StringBuilder();
-
- // There cannot be a null value returned from "split" - words != null is
- // redundant
- // if (words != null) {
- boolean isFirst = true;
- for (int i = 0; i < words.length; i++) {
-
- String word = words[i];
- if (word != null && !word.isEmpty()) {
- if (!isFirst) {
- builder.append("-");
- } else {
- isFirst = false;
- }
- builder.append(words[i].toLowerCase());
- }
- }
- return builder.toString() + Constants.YAML_SUFFIX;
-
- /*
- * } else { return className.getSimpleName().toLowerCase() + Constants.YAML_SUFFIX; }
- */
-
+ return Arrays.stream(words)
+ .map(String::toLowerCase)
+ .collect(Collectors.collectingAndThen(
+ Collectors.joining("-"),
+ str -> str + Constants.YAML_SUFFIX)
+ );
}
}
diff --git a/common-app-api/src/test/java/org/openecomp/sdc/common/impl/FSConfigurationSourceTest.java b/common-app-api/src/test/java/org/openecomp/sdc/common/impl/FSConfigurationSourceTest.java
new file mode 100644
index 0000000000..b9116bb34d
--- /dev/null
+++ b/common-app-api/src/test/java/org/openecomp/sdc/common/impl/FSConfigurationSourceTest.java
@@ -0,0 +1,61 @@
+/*-
+ * ============LICENSE_START=======================================================
+ * SDC
+ * ================================================================================
+ * Copyright (C) 2019 Nokia. All rights reserved.
+ * ================================================================================
+ * Licensed 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.
+ * ============LICENSE_END=========================================================
+ */
+
+package org.openecomp.sdc.common.impl;
+
+import static org.junit.Assert.assertEquals;
+
+import org.junit.Test;
+import org.openecomp.sdc.be.config.Configuration;
+import org.openecomp.sdc.be.config.ErrorConfiguration;
+import org.openecomp.sdc.be.config.Neo4jErrorsConfiguration;
+import org.openecomp.sdc.common.api.Constants;
+
+public class FSConfigurationSourceTest {
+ @Test
+ public void calculateFileNameWhenSplitRequired() {
+ Class<ErrorConfiguration> clazz = ErrorConfiguration.class;
+
+ String expected = "error-configuration" + Constants.YAML_SUFFIX;
+ String actual = FSConfigurationSource.calculateFileName(clazz);
+
+ assertEquals(expected, actual);
+ }
+
+ @Test
+ public void calculateFileNameWhenNoSplitRequired() {
+ Class<Configuration> clazz = Configuration.class;
+
+ String expected = "configuration" + Constants.YAML_SUFFIX;
+ String actual = FSConfigurationSource.calculateFileName(clazz);
+
+ assertEquals(expected, actual);
+ }
+
+ @Test
+ public void calculateFileNameWithCamelCaseAndDigits() {
+ Class<Neo4jErrorsConfiguration> clazz = Neo4jErrorsConfiguration.class;
+
+ String expected = "neo4j-errors-configuration" + Constants.YAML_SUFFIX;
+ String actual = FSConfigurationSource.calculateFileName(clazz);
+
+ assertEquals(expected, actual);
+ }
+} \ No newline at end of file