Added new tests for SdcRestClientUtils
Added new tests.
Fixed sonar issue:
# added private constructor to the SdcRestClientUtils
# used String.format instead of stream.collect
Issue-ID: SDC-2327
Signed-off-by: Krystian Kedron <k.kedron@partner.samsung.com>
Change-Id: I904e4a7e31bab8f26dbdbb03a956bc4b1dc5922e
diff --git a/dcaedt_catalog/asdc/src/main/java/org/onap/sdc/dcae/utils/SdcRestClientUtils.java b/dcaedt_catalog/asdc/src/main/java/org/onap/sdc/dcae/utils/SdcRestClientUtils.java
index 88c89a7..13e6e9d 100644
--- a/dcaedt_catalog/asdc/src/main/java/org/onap/sdc/dcae/utils/SdcRestClientUtils.java
+++ b/dcaedt_catalog/asdc/src/main/java/org/onap/sdc/dcae/utils/SdcRestClientUtils.java
@@ -3,6 +3,7 @@
* SDC
* ================================================================================
* Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
+ * Modifications Copyright (c) 2019 Samsung
* ================================================================================
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@@ -34,12 +35,14 @@
import java.util.ArrayList;
import java.util.EnumMap;
import java.util.List;
-import java.util.stream.Collectors;
public class SdcRestClientUtils {
private static final String SDC_CATALOG_PATH = "/sdc/v1/catalog/";
+ private SdcRestClientUtils() {
+ }
+
// TODO consider moving params elsewhere (user/password/instanceId can be constant)
public static EnumMap<SdcConsumerInfo, String> extractConsumerInfoFromUri(URI configUri) {
EnumMap<SdcConsumerInfo, String> userInfoMap = new EnumMap<>(SdcConsumerInfo.class);
@@ -68,7 +71,7 @@
filters.add("category="+category);
if(!StringUtils.isEmpty(subcategory))
filters.add("subCategory="+subcategory);
- return "?"+filters.stream().collect(Collectors.joining("&"));
+ return "?"+ String.join("&", filters);
}
public static UserRemarks buildUserRemarksObject(String userRemarks) {
diff --git a/dcaedt_catalog/asdc/src/test/java/org/onap/sdc/dcae/utils/utils/SdcRestClientUtilsTest.java b/dcaedt_catalog/asdc/src/test/java/org/onap/sdc/dcae/utils/utils/SdcRestClientUtilsTest.java
new file mode 100644
index 0000000..516f68c
--- /dev/null
+++ b/dcaedt_catalog/asdc/src/test/java/org/onap/sdc/dcae/utils/utils/SdcRestClientUtilsTest.java
@@ -0,0 +1,167 @@
+/*-
+ * ============LICENSE_START=======================================================
+ * SDC
+ * ================================================================================
+ * Copyright (C) 2019 Samsung. 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.onap.sdc.dcae.utils.utils;
+
+import static org.junit.Assert.assertEquals;
+
+import java.lang.reflect.Field;
+import java.net.URI;
+import java.net.URISyntaxException;
+import java.util.EnumMap;
+
+import org.json.JSONObject;
+import org.junit.Rule;
+import org.junit.Test;
+import org.junit.rules.ExpectedException;
+import org.junit.runner.RunWith;
+import org.mockito.runners.MockitoJUnitRunner;
+import org.onap.sdc.dcae.composition.restmodels.sdc.Artifact;
+import org.onap.sdc.dcae.enums.ArtifactGroupType;
+import org.onap.sdc.dcae.enums.SdcConsumerInfo;
+import org.onap.sdc.dcae.utils.SdcRestClientUtils;
+import org.springframework.util.Base64Utils;
+
+import com.fasterxml.jackson.core.JsonProcessingException;
+
+@RunWith(MockitoJUnitRunner.class)
+public class SdcRestClientUtilsTest {
+
+ private static final String USER_INFO = "USER_INFO";
+ private static final String INSTANCE_INFO = "321";
+ private static final String SCHEMA = "testSchema";
+ private static final String HOST = "testHost";
+ private static final int PORT = 123;
+ private static final String PATH = "/test/path";
+ private static final String RESOURCE_TYPE = "testResourceType";
+ private static final String CATEGORY = "testCategory";
+ private static final String SUB_CATEGORY = "testSubcategory";
+ private static final String DESCRIPTION = "testDescription";
+ private static final String NAME = "testName";
+ private static final String LABEL = "testLabel";
+ private static final String PAYLOAD_STRING = "testPayload";
+ private static final byte[] PAYLOAD = PAYLOAD_STRING.getBytes();
+ private static final String FRAGMENT_NOT_FOUND_EXCEPTION_MESSAGE =
+ "The URI must contain a fragment specification, to be used as SDC instance id";
+
+ @Rule
+ public ExpectedException expectedException = ExpectedException.none();
+
+ @Test
+ public void testExtractConsumerInfoFormat()
+ throws URISyntaxException, NoSuchFieldException, IllegalAccessException {
+ // given
+ URI configUri = new URI(SCHEMA, USER_INFO, HOST, PORT, PATH, null, INSTANCE_INFO);
+
+ // when
+ EnumMap<SdcConsumerInfo, String> userInfoMap =
+ SdcRestClientUtils.extractConsumerInfoFromUri(configUri);
+
+ // then
+ assertEquals("Basic " + Base64Utils.encodeToString(USER_INFO.getBytes()),
+ userInfoMap.get(SdcConsumerInfo.AUTH));
+ assertEquals(INSTANCE_INFO, userInfoMap.get(SdcConsumerInfo.INSTANCE_ID));
+
+ assertEquals(String.format("%s://%s:%d%s", SCHEMA, HOST, PORT, PATH) + getSdcCatalogPath(),
+ userInfoMap.get(SdcConsumerInfo.CATALOG_URL));
+ }
+
+ @Test
+ public void testExtractConsumerWithoutInstanceInfo() throws URISyntaxException {
+ expectedException.expect(IllegalArgumentException.class);
+ expectedException.expectMessage(FRAGMENT_NOT_FOUND_EXCEPTION_MESSAGE);
+ // given
+ URI configUri = new URI(SCHEMA, USER_INFO, HOST, PORT, PATH, null, null);
+ // when - then
+ SdcRestClientUtils.extractConsumerInfoFromUri(configUri);
+ }
+
+ @Test
+ public void testBuildResourceFilterQuery() {
+ // when
+ String query =
+ SdcRestClientUtils.buildResourceFilterQuery(RESOURCE_TYPE, CATEGORY, SUB_CATEGORY);
+ // then
+ assertEquals(String.format("?resourceType=%s&category=%s&subCategory=%s", RESOURCE_TYPE,
+ CATEGORY, SUB_CATEGORY), query);
+ // when
+ query = SdcRestClientUtils.buildResourceFilterQuery(RESOURCE_TYPE, CATEGORY, null);
+ // then
+ assertEquals(String.format("?resourceType=%s&category=%s", RESOURCE_TYPE, CATEGORY), query);
+ // when
+ query = SdcRestClientUtils.buildResourceFilterQuery(RESOURCE_TYPE, null, null);
+ // then
+ assertEquals("?resourceType=" + RESOURCE_TYPE, query);
+ }
+
+ @Test
+ public void testArtifactGeneration() {
+ // when
+ Artifact artifact = SdcRestClientUtils.generateDeploymentArtifact(DESCRIPTION, NAME,
+ RESOURCE_TYPE, LABEL, PAYLOAD);
+
+ // then
+ assertEquals(DESCRIPTION, artifact.getDescription());
+ assertEquals(NAME, artifact.getArtifactName());
+ assertEquals(ArtifactGroupType.DEPLOYMENT.name(), artifact.getArtifactGroupType());
+ assertEquals(RESOURCE_TYPE, artifact.getArtifactType());
+ assertEquals(LABEL, artifact.getArtifactLabel());
+ assertEquals(Base64Utils.encodeToString(PAYLOAD), artifact.getPayloadData());
+
+ // when
+ artifact = SdcRestClientUtils.generateCatalogDcaeToscaArtifact(NAME, PATH, PAYLOAD);
+
+ // then
+ assertEquals(NAME, artifact.getArtifactName());
+ assertEquals(PATH, artifact.getArtifactURL());
+ assertEquals(PAYLOAD_STRING, artifact.getPayloadData());
+ }
+
+ @Test
+ public void testConvertArtifactToString() throws JsonProcessingException {
+ // when
+ Artifact artifact = SdcRestClientUtils.generateDeploymentArtifact(DESCRIPTION, NAME,
+ RESOURCE_TYPE, LABEL, PAYLOAD);
+ JSONObject resultJson = new JSONObject(SdcRestClientUtils.artifactToString(artifact));
+
+ // then
+ assertEquals(DESCRIPTION, resultJson.get("description"));
+ assertEquals(NAME, resultJson.get("artifactName"));
+ assertEquals(ArtifactGroupType.DEPLOYMENT.name(), resultJson.get("artifactGroupType"));
+ assertEquals(RESOURCE_TYPE, resultJson.get("artifactType"));
+ assertEquals(LABEL, resultJson.get("artifactLabel"));
+ assertEquals(Base64Utils.encodeToString(PAYLOAD), resultJson.get("payloadData"));
+
+ // when
+ artifact = SdcRestClientUtils.generateCatalogDcaeToscaArtifact(NAME, PATH, PAYLOAD);
+ resultJson = new JSONObject(SdcRestClientUtils.artifactToString(artifact));
+
+ // then
+ assertEquals(NAME, resultJson.get("artifactName"));
+ assertEquals(PATH, resultJson.get("artifactURL"));
+ assertEquals(PAYLOAD_STRING, resultJson.get("payloadData"));
+ }
+
+ private String getSdcCatalogPath() throws NoSuchFieldException, IllegalAccessException {
+ Field field = SdcRestClientUtils.class.getDeclaredField("SDC_CATALOG_PATH");
+ field.setAccessible(true);
+ return field.get(null).toString();
+ }
+}