X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=policy-agent%2Fsrc%2Ftest%2Fjava%2Forg%2Foransc%2Fpolicyagent%2Fconfiguration%2FApplicationConfigParserTest.java;h=5a6b0232a3e27a16fa952c0ca3674bbd9237bd49;hb=f45eedd18774bf9856800b43387bee3fa2e6152d;hp=02c84db878a9ccecc2c26b14b0221c9508a699d5;hpb=7c297ddb425a52dae965adc6a83629a14421ea05;p=nonrtric.git diff --git a/policy-agent/src/test/java/org/oransc/policyagent/configuration/ApplicationConfigParserTest.java b/policy-agent/src/test/java/org/oransc/policyagent/configuration/ApplicationConfigParserTest.java index 02c84db8..5a6b0232 100644 --- a/policy-agent/src/test/java/org/oransc/policyagent/configuration/ApplicationConfigParserTest.java +++ b/policy-agent/src/test/java/org/oransc/policyagent/configuration/ApplicationConfigParserTest.java @@ -20,7 +20,6 @@ package org.oransc.policyagent.configuration; -import static org.junit.jupiter.api.Assertions.assertAll; import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertThrows; @@ -36,55 +35,40 @@ import java.io.ByteArrayInputStream; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; -import java.net.MalformedURLException; import java.net.URL; import java.nio.charset.StandardCharsets; -import java.util.Properties; +import java.util.Map; import org.junit.jupiter.api.Test; -import org.onap.dmaap.mr.test.clients.ProtocolTypeConstants; import org.oransc.policyagent.exceptions.ServiceException; -import org.springframework.http.MediaType; -public class ApplicationConfigParserTest { +class ApplicationConfigParserTest { ApplicationConfigParser parserUnderTest = new ApplicationConfigParser(); @Test - public void whenCorrectDmaapConfig() throws Exception { + void whenCorrectConfig() throws Exception { JsonObject jsonRootObject = getJsonRootObject(); - parserUnderTest.parse(jsonRootObject); - - Properties actualPublisherConfig = parserUnderTest.getDmaapPublisherConfig(); - assertAll("publisherConfig", - () -> assertEquals("localhost:6845/events", actualPublisherConfig.get("ServiceName"), "Wrong ServiceName"), - () -> assertEquals("A1-POLICY-AGENT-WRITE", actualPublisherConfig.get("topic"), "Wrong topic"), - () -> assertEquals("localhost:6845", actualPublisherConfig.get("host"), "Wrong host"), - () -> assertEquals(MediaType.APPLICATION_JSON.toString(), actualPublisherConfig.get("contenttype"), - "Wrong contenttype"), - () -> assertEquals("admin", actualPublisherConfig.get("userName"), "Wrong userName"), - () -> assertEquals("admin", actualPublisherConfig.get("password"), "Wrong password"), - () -> assertEquals(ProtocolTypeConstants.HTTPNOAUTH.toString(), actualPublisherConfig.get("TransportType"), - "Wrong TransportType"), - () -> assertEquals(15000, actualPublisherConfig.get("timeout"), "Wrong timeout"), - () -> assertEquals(100, actualPublisherConfig.get("limit"), "Wrong limit")); - - Properties actualConsumerConfig = parserUnderTest.getDmaapConsumerConfig(); - assertAll("consumerConfig", - () -> assertEquals("localhost:6845/events", actualConsumerConfig.get("ServiceName"), "Wrong ServiceName"), - () -> assertEquals("A1-POLICY-AGENT-READ", actualConsumerConfig.get("topic"), "Wrong topic"), - () -> assertEquals("localhost:6845", actualConsumerConfig.get("host"), "Wrong host"), - () -> assertEquals(MediaType.APPLICATION_JSON.toString(), actualConsumerConfig.get("contenttype"), - "Wrong contenttype"), - () -> assertEquals("admin", actualConsumerConfig.get("userName"), "Wrong userName"), - () -> assertEquals("admin", actualConsumerConfig.get("password"), "Wrong password"), - () -> assertEquals("users", actualConsumerConfig.get("group"), "Wrong group"), - () -> assertEquals("policy-agent", actualConsumerConfig.get("id"), "Wrong id"), - () -> assertEquals(ProtocolTypeConstants.HTTPNOAUTH.toString(), actualConsumerConfig.get("TransportType"), - "Wrong TransportType"), - () -> assertEquals(15000, actualConsumerConfig.get("timeout"), "Wrong timeout"), - () -> assertEquals(100, actualConsumerConfig.get("limit"), "Wrong limit")); + ApplicationConfigParser.ConfigParserResult result = parserUnderTest.parse(jsonRootObject); + + String topicUrl = result.dmaapProducerTopicUrl(); + assertEquals("http://admin:admin@localhost:6845/events/A1-POLICY-AGENT-WRITE", topicUrl, "controller contents"); + + topicUrl = result.dmaapConsumerTopicUrl(); + assertEquals( + "http://admin:admin@localhost:6845/events/A1-POLICY-AGENT-READ/users/policy-agent?timeout=15000&limit=100", + topicUrl, "controller contents"); + + Map controllers = result.controllerConfigs(); + assertEquals(1, controllers.size(), "size"); + ImmutableControllerConfig expectedControllerConfig = ImmutableControllerConfig.builder() // + .baseUrl("http://localhost:8083/") // + .name("controller1") // + .userName("user") // + .password("password") // + .build(); // + assertEquals(expectedControllerConfig, controllers.get("controller1"), "controller contents"); } private JsonObject getJsonRootObject() throws JsonIOException, JsonSyntaxException, IOException { @@ -100,7 +84,7 @@ public class ApplicationConfigParserTest { } @Test - public void whenDmaapConfigHasSeveralStreamsPublishing() throws Exception { + void whenDmaapConfigHasSeveralStreamsPublishing() throws Exception { JsonObject jsonRootObject = getJsonRootObject(); JsonObject json = jsonRootObject.getAsJsonObject("config").getAsJsonObject("streams_publishes"); JsonObject fake_info_object = new JsonObject(); @@ -120,6 +104,7 @@ public class ApplicationConfigParserTest { private JsonObject dmaap_publisher; private JsonObject fake_info_object; + @Override public String toString() { return String.format("[dmaap_publisher=%s, fake_info_object=%s]", dmaap_publisher.toString(), fake_info_object.toString()); @@ -127,7 +112,7 @@ public class ApplicationConfigParserTest { } @Test - public void whenDmaapConfigHasSeveralStreamsSubscribing() throws Exception { + void whenDmaapConfigHasSeveralStreamsSubscribing() throws Exception { JsonObject jsonRootObject = getJsonRootObject(); JsonObject json = jsonRootObject.getAsJsonObject("config").getAsJsonObject("streams_subscribes"); JsonObject fake_info_object = new JsonObject(); @@ -147,6 +132,7 @@ public class ApplicationConfigParserTest { private JsonObject dmaap_subscriber; private JsonObject fake_info_object; + @Override public String toString() { return String.format("[dmaap_subscriber=%s, fake_info_object=%s]", dmaap_subscriber.toString(), fake_info_object.toString()); @@ -154,82 +140,18 @@ public class ApplicationConfigParserTest { } @Test - public void whenMalformedUrlStreamsSubscribing() throws Exception { - JsonObject jsonRootObject = getJsonRootObject(); - final String wrongTopicUrl = "WrongTopicUrl"; - JsonObject json = getDmaapInfo(jsonRootObject, "streams_subscribes", "dmaap_subscriber"); - json.addProperty("topic_url", wrongTopicUrl); - final String expectedMessage = "Could not parse the URL"; - - Exception actualException = assertThrows(ServiceException.class, () -> parserUnderTest.parse(jsonRootObject)); - - assertEquals(expectedMessage, actualException.getMessage().replace("\"", ""), - "Wrong error message when the streams subscribes' URL is malformed"); - assertEquals(MalformedURLException.class, actualException.getCause().getClass(), - "The exception is not a MalformedURLException"); - } - - @Test - public void whenMalformedUrlStreamsPublishing() throws Exception { - JsonObject jsonRootObject = getJsonRootObject(); - final String wrongTopicUrl = "WrongTopicUrl"; - JsonObject json = getDmaapInfo(jsonRootObject, "streams_publishes", "dmaap_publisher"); - json.addProperty("topic_url", wrongTopicUrl); - final String expectedMessage = "Could not parse the URL"; - - Exception actualException = assertThrows(ServiceException.class, () -> parserUnderTest.parse(jsonRootObject)); - - assertEquals(expectedMessage, actualException.getMessage().replace("\"", ""), - "Wrong error message when the streams publishes' URL is malformed"); - assertEquals(MalformedURLException.class, actualException.getCause().getClass(), - "The exception is not a MalformedURLException"); - } - - @Test - public void whenWrongMemberNameInObject() throws Exception { + void whenWrongMemberNameInObject() throws Exception { JsonObject jsonRootObject = getJsonRootObject(); JsonObject json = jsonRootObject.getAsJsonObject("config"); json.remove("ric"); - final String message = "Could not find member: ric in: " + json; + final String message = "Could not find member: 'ric' in: " + json; Exception actualException = assertThrows(ServiceException.class, () -> parserUnderTest.parse(jsonRootObject)); assertEquals(message, actualException.getMessage(), "Wrong error message when wrong member name in object"); } - @Test - public void whenWrongUrlPathStreamsSubscribing() throws Exception { - JsonObject jsonRootObject = getJsonRootObject(); - final String wrongTopicUrlString = - "http://admin:admin@localhost:6845/events/A1-POLICY-AGENT-READ/users/policy-agent/wrong-topic-url"; - final URL wrongTopicUrl = new URL(wrongTopicUrlString); - JsonObject json = getDmaapInfo(jsonRootObject, "streams_subscribes", "dmaap_subscriber"); - json.addProperty("topic_url", wrongTopicUrlString); - final String expectedMessage = "The path has incorrect syntax: " + wrongTopicUrl.getPath(); - - Exception actualException = assertThrows(ServiceException.class, () -> parserUnderTest.parse(jsonRootObject)); - - assertEquals(expectedMessage, actualException.getMessage(), - "Wrong error message when the streams subscribes' URL has incorrect syntax"); - } - - @Test - public void whenWrongUrlPathStreamsPublishing() throws Exception { - JsonObject jsonRootObject = getJsonRootObject(); - final String wrongTopicUrlString = - "http://admin:admin@localhost:6845/events/A1-POLICY-AGENT-WRITE/wrong-topic-url"; - final URL wrongTopicUrl = new URL(wrongTopicUrlString); - JsonObject json = getDmaapInfo(jsonRootObject, "streams_publishes", "dmaap_publisher"); - json.addProperty("topic_url", wrongTopicUrlString); - final String expectedMessage = "The path has incorrect syntax: " + wrongTopicUrl.getPath(); - - Exception actualException = assertThrows(ServiceException.class, () -> parserUnderTest.parse(jsonRootObject)); - - assertEquals(expectedMessage, actualException.getMessage(), - "Wrong error message when the streams publishes' URL has incorrect syntax"); - } - - public JsonObject getDmaapInfo(JsonObject jsonRootObject, String streamsPublishesOrSubscribes, + JsonObject getDmaapInfo(JsonObject jsonRootObject, String streamsPublishesOrSubscribes, String dmaapPublisherOrSubscriber) throws Exception { return jsonRootObject.getAsJsonObject("config").getAsJsonObject(streamsPublishesOrSubscribes) .getAsJsonObject(dmaapPublisherOrSubscriber).getAsJsonObject("dmaap_info");