From 2f00429d5531304d5403638ef0796764f79abb0b Mon Sep 17 00:00:00 2001 From: ramverma Date: Wed, 27 Mar 2019 16:27:36 +0000 Subject: Adding db provider parameters to pap config file Change-Id: I573a345bcf69eb40782277f211fff2b7c69c4f55 Issue-ID: POLICY-1443 Signed-off-by: ramverma --- .../pap/main/parameters/PapParameterGroup.java | 3 ++ .../policy/pap/main/startstop/PapActivator.java | 55 ++++++++++------------ .../policy/pap/main/parameters/CommonTestData.java | 54 +++++++++++++++------ .../resources/parameters/MinimumParameters.json | 8 ++++ .../resources/parameters/PapConfigParameters.json | 8 ++++ .../PapConfigParameters_InvalidName.json | 8 ++++ 6 files changed, 91 insertions(+), 45 deletions(-) (limited to 'main/src') diff --git a/main/src/main/java/org/onap/policy/pap/main/parameters/PapParameterGroup.java b/main/src/main/java/org/onap/policy/pap/main/parameters/PapParameterGroup.java index 21dcac0a..0690fadd 100644 --- a/main/src/main/java/org/onap/policy/pap/main/parameters/PapParameterGroup.java +++ b/main/src/main/java/org/onap/policy/pap/main/parameters/PapParameterGroup.java @@ -22,9 +22,11 @@ package org.onap.policy.pap.main.parameters; import lombok.Getter; + import org.onap.policy.common.parameters.ParameterGroupImpl; import org.onap.policy.common.parameters.annotations.NotBlank; import org.onap.policy.common.parameters.annotations.NotNull; +import org.onap.policy.models.provider.PolicyModelsProviderParameters; /** * Class to hold all parameters needed for pap component. @@ -37,6 +39,7 @@ import org.onap.policy.common.parameters.annotations.NotNull; public class PapParameterGroup extends ParameterGroupImpl { private RestServerParameters restServerParameters; private PdpParameters pdpParameters; + private PolicyModelsProviderParameters databaseProviderParameters; /** * Create the pap parameter group. diff --git a/main/src/main/java/org/onap/policy/pap/main/startstop/PapActivator.java b/main/src/main/java/org/onap/policy/pap/main/startstop/PapActivator.java index 0d078ac8..42634ee7 100644 --- a/main/src/main/java/org/onap/policy/pap/main/startstop/PapActivator.java +++ b/main/src/main/java/org/onap/policy/pap/main/startstop/PapActivator.java @@ -22,9 +22,9 @@ package org.onap.policy.pap.main.startstop; import java.util.Arrays; -import java.util.Base64; import java.util.Properties; import java.util.concurrent.atomic.AtomicReference; + import org.onap.policy.common.endpoints.event.comm.TopicEndpoint; import org.onap.policy.common.endpoints.event.comm.TopicSource; import org.onap.policy.common.endpoints.listeners.MessageTypeDispatcher; @@ -34,7 +34,6 @@ import org.onap.policy.common.utils.services.Registry; import org.onap.policy.common.utils.services.ServiceManagerContainer; import org.onap.policy.models.pdp.concepts.PdpStatus; import org.onap.policy.models.pdp.enums.PdpMessageType; -import org.onap.policy.models.provider.PolicyModelsProviderParameters; import org.onap.policy.pap.main.PapConstants; import org.onap.policy.pap.main.PolicyModelsProviderFactoryWrapper; import org.onap.policy.pap.main.PolicyPapRuntimeException; @@ -48,14 +47,14 @@ import org.onap.policy.pap.main.rest.PapRestServer; import org.onap.policy.pap.main.rest.PapStatisticsManager; /** - * This class wraps a distributor so that it can be activated as a complete service - * together with all its pap and forwarding handlers. + * This class wraps a distributor so that it can be activated as a complete service together with all its pap and + * forwarding handlers. * * @author Ram Krishna Verma (ram.krishna.verma@est.tech) */ public class PapActivator extends ServiceManagerContainer { - private static final String[] MSG_TYPE_NAMES = {"messageName"}; - private static final String[] REQ_ID_NAMES = {"response", "responseTo"}; + private static final String[] MSG_TYPE_NAMES = { "messageName" }; + private static final String[] REQ_ID_NAMES = { "response", "responseTo" }; private final PapParameterGroup papParameterGroup; @@ -65,14 +64,14 @@ public class PapActivator extends ServiceManagerContainer { private PapRestServer restServer; /** - * Listens for messages on the topic, decodes them into a {@link PdpStatus} message, - * and then dispatches them to {@link #reqIdDispatcher}. + * Listens for messages on the topic, decodes them into a {@link PdpStatus} message, and then dispatches them to + * {@link #reqIdDispatcher}. */ private final MessageTypeDispatcher msgDispatcher; /** - * Listens for {@link PdpStatus} messages and then routes them to the listener - * associated with the ID of the originating request. + * Listens for {@link PdpStatus} messages and then routes them to the listener associated with the ID of the + * originating request. */ private final RequestIdDispatcher reqIdDispatcher; @@ -82,7 +81,7 @@ public class PapActivator extends ServiceManagerContainer { * @param papParameterGroup the parameters for the pap service * @param topicProperties properties used to configure the topics */ - public PapActivator(final PapParameterGroup papParameterGroup, Properties topicProperties) { + public PapActivator(final PapParameterGroup papParameterGroup, final Properties topicProperties) { super("Policy PAP"); TopicEndpoint.manager.addTopicSinks(topicProperties); @@ -93,25 +92,18 @@ public class PapActivator extends ServiceManagerContainer { this.msgDispatcher = new MessageTypeDispatcher(MSG_TYPE_NAMES); this.reqIdDispatcher = new RequestIdDispatcher<>(PdpStatus.class, REQ_ID_NAMES); - } catch (RuntimeException e) { + } catch (final RuntimeException e) { throw new PolicyPapRuntimeException(e); } papParameterGroup.getRestServerParameters().setName(papParameterGroup.getName()); - // TODO add these to the json property file - PolicyModelsProviderParameters daoParams = new PolicyModelsProviderParameters(); - daoParams.setDatabaseUrl("jdbc:h2:mem:testdb"); - daoParams.setDatabaseUser("policy"); - daoParams.setDatabasePassword(Base64.getEncoder().encodeToString("P01icY".getBytes())); - daoParams.setPersistenceUnit("ToscaConceptTest"); - final Object pdpUpdateLock = new Object(); - PdpParameters pdpParams = papParameterGroup.getPdpParameters(); - AtomicReference pdpPub = new AtomicReference<>(); - AtomicReference pdpUpdTimers = new AtomicReference<>(); - AtomicReference pdpStChgTimers = new AtomicReference<>(); - AtomicReference daoFactory = new AtomicReference<>(); + final PdpParameters pdpParams = papParameterGroup.getPdpParameters(); + final AtomicReference pdpPub = new AtomicReference<>(); + final AtomicReference pdpUpdTimers = new AtomicReference<>(); + final AtomicReference pdpStChgTimers = new AtomicReference<>(); + final AtomicReference daoFactory = new AtomicReference<>(); // @formatter:off addAction("PAP parameters", @@ -119,7 +111,8 @@ public class PapActivator extends ServiceManagerContainer { () -> ParameterService.deregister(papParameterGroup.getName())); addAction("DAO Factory", - () -> daoFactory.set(new PolicyModelsProviderFactoryWrapper(daoParams)), + () -> daoFactory.set(new PolicyModelsProviderFactoryWrapper( + papParameterGroup.getDatabaseProviderParameters())), () -> daoFactory.get().close()); addAction("DAO Factory registration", @@ -197,8 +190,8 @@ public class PapActivator extends ServiceManagerContainer { * * @param runner function to run in the background */ - private void startThread(Runnable runner) { - Thread thread = new Thread(runner); + private void startThread(final Runnable runner) { + final Thread thread = new Thread(runner); thread.setDaemon(true); thread.start(); @@ -217,8 +210,8 @@ public class PapActivator extends ServiceManagerContainer { * Registers the dispatcher with the topic source(s). */ private void registerMsgDispatcher() { - for (TopicSource source : TopicEndpoint.manager - .getTopicSources(Arrays.asList(PapConstants.TOPIC_POLICY_PDP_PAP))) { + for (final TopicSource source : TopicEndpoint.manager + .getTopicSources(Arrays.asList(PapConstants.TOPIC_POLICY_PDP_PAP))) { source.register(msgDispatcher); } } @@ -227,8 +220,8 @@ public class PapActivator extends ServiceManagerContainer { * Unregisters the dispatcher from the topic source(s). */ private void unregisterMsgDispatcher() { - for (TopicSource source : TopicEndpoint.manager - .getTopicSources(Arrays.asList(PapConstants.TOPIC_POLICY_PDP_PAP))) { + for (final TopicSource source : TopicEndpoint.manager + .getTopicSources(Arrays.asList(PapConstants.TOPIC_POLICY_PDP_PAP))) { source.unregister(msgDispatcher); } } diff --git a/main/src/test/java/org/onap/policy/pap/main/parameters/CommonTestData.java b/main/src/test/java/org/onap/policy/pap/main/parameters/CommonTestData.java index 9d0a1abb..38d8621e 100644 --- a/main/src/test/java/org/onap/policy/pap/main/parameters/CommonTestData.java +++ b/main/src/test/java/org/onap/policy/pap/main/parameters/CommonTestData.java @@ -21,13 +21,16 @@ package org.onap.policy.pap.main.parameters; +import java.util.Base64; import java.util.HashMap; import java.util.Map; import java.util.TreeMap; + import org.onap.policy.common.parameters.ParameterGroup; import org.onap.policy.common.utils.coder.Coder; import org.onap.policy.common.utils.coder.CoderException; import org.onap.policy.common.utils.coder.StandardCoder; +import org.onap.policy.models.provider.PolicyModelsProviderParameters; /** * Class to hold/create all parameters for test cases. @@ -53,27 +56,29 @@ public class CommonTestData { * @param clazz class of object to be created from the map * @return a new object represented by the map */ - public T toObject(Map source, Class clazz) { + public T toObject(final Map source, final Class clazz) { try { return coder.decode(coder.encode(source), clazz); - } catch (CoderException e) { + } catch (final CoderException e) { throw new RuntimeException("cannot create " + clazz.getName() + " from map", e); } } /** * Returns a property map for a PapParameterGroup map for test cases. + * * @param name name of the parameters * * @return a property map suitable for constructing an object */ - public Map getPapParameterGroupMap(String name) { - Map map = new TreeMap<>(); + public Map getPapParameterGroupMap(final String name) { + final Map map = new TreeMap<>(); map.put("name", name); map.put("restServerParameters", getRestServerParametersMap(false)); map.put("pdpParameters", getPdpParametersMap()); + map.put("databaseProviderParameters", getPolicyModelsProviderParametersMap()); return map; } @@ -84,8 +89,8 @@ public class CommonTestData { * @param isEmpty boolean value to represent that object created should be empty or not * @return a property map suitable for constructing an object */ - public Map getRestServerParametersMap(final boolean isEmpty) { - Map map = new TreeMap<>(); + public Map getRestServerParametersMap(final boolean isEmpty) { + final Map map = new TreeMap<>(); map.put("https", REST_SERVER_HTTPS); map.put("aaf", REST_SERVER_AAF); @@ -101,10 +106,11 @@ public class CommonTestData { /** * Returns a property map for a PdpParameters map for test cases. + * * @return a property map suitable for constructing an object */ - public Map getPdpParametersMap() { - Map map = new TreeMap<>(); + public Map getPdpParametersMap() { + final Map map = new TreeMap<>(); map.put("updateParameters", getPdpUpdateParametersMap()); map.put("stateChangeParameters", getPdpStateChangeParametersMap()); @@ -114,26 +120,29 @@ public class CommonTestData { /** * Returns a property map for a PdpUpdateParameters map for test cases. + * * @return a property map suitable for constructing an object */ - public Map getPdpUpdateParametersMap() { + public Map getPdpUpdateParametersMap() { return getPdpRequestParametersMap(); } /** * Returns a property map for a PdpStateChangeParameters map for test cases. + * * @return a property map suitable for constructing an object */ - public Map getPdpStateChangeParametersMap() { + public Map getPdpStateChangeParametersMap() { return getPdpRequestParametersMap(); } /** * Returns a property map for a PdpParameters map for test cases. + * * @return a property map suitable for constructing an object */ - public Map getPdpRequestParametersMap() { - Map map = new HashMap<>(); + public Map getPdpRequestParametersMap() { + final Map map = new HashMap<>(); map.put("maxRetryCount", "1"); map.put("maxWaitMs", "2"); @@ -145,10 +154,27 @@ public class CommonTestData { * * @return a property map suitable for constructing an object */ - public Map getPdpGroupDeploymentParametersMap() { - Map map = new TreeMap<>(); + public Map getPdpGroupDeploymentParametersMap() { + final Map map = new TreeMap<>(); map.put("waitResponseMs", "1"); return map; } + + /** + * Returns a property map for a PolicyModelsProviderParameters map for test cases. + * + * @return a property map suitable for constructing an object + */ + public Map getPolicyModelsProviderParametersMap() { + final Map map = new TreeMap<>(); + map.put("name", PolicyModelsProviderParameters.class.getSimpleName()); + map.put("implementation", REST_SERVER_HTTPS); + map.put("databaseUrl", "jdbc:h2:mem:testdb"); + map.put("databaseUser", "policy"); + map.put("databasePassword", Base64.getEncoder().encodeToString("P01icY".getBytes())); + map.put("persistenceUnit", "PdpGroupTest"); + + return map; + } } diff --git a/main/src/test/resources/parameters/MinimumParameters.json b/main/src/test/resources/parameters/MinimumParameters.json index b35acec5..7e7d3ee7 100644 --- a/main/src/test/resources/parameters/MinimumParameters.json +++ b/main/src/test/resources/parameters/MinimumParameters.json @@ -15,5 +15,13 @@ "maxRetryCount": 1, "maxWaitMs": 1 } + }, + "databaseProviderParameters": { + "name": "PolicyProviderParameterGroup", + "implementation": "org.onap.policy.models.provider.impl.DatabasePolicyModelsProviderImpl", + "databaseUrl": "jdbc:h2:mem:testdb", + "databaseUser": "policy", + "databasePassword": "P01icY", + "persistenceUnit": "PdpGroupTest" } } diff --git a/main/src/test/resources/parameters/PapConfigParameters.json b/main/src/test/resources/parameters/PapConfigParameters.json index a510964f..c967fdf1 100644 --- a/main/src/test/resources/parameters/PapConfigParameters.json +++ b/main/src/test/resources/parameters/PapConfigParameters.json @@ -16,5 +16,13 @@ "maxRetryCount": 1, "maxWaitMs": 1 } + }, + "databaseProviderParameters": { + "name": "PolicyProviderParameterGroup", + "implementation": "org.onap.policy.models.provider.impl.DatabasePolicyModelsProviderImpl", + "databaseUrl": "jdbc:h2:mem:testdb", + "databaseUser": "policy", + "databasePassword": "P01icY", + "persistenceUnit": "PdpGroupTest" } } diff --git a/main/src/test/resources/parameters/PapConfigParameters_InvalidName.json b/main/src/test/resources/parameters/PapConfigParameters_InvalidName.json index 7b53b880..8cb74172 100644 --- a/main/src/test/resources/parameters/PapConfigParameters_InvalidName.json +++ b/main/src/test/resources/parameters/PapConfigParameters_InvalidName.json @@ -15,5 +15,13 @@ "maxRetryCount": 1, "maxWaitMs": 1 } + }, + "databaseProviderParameters": { + "name": "PolicyProviderParameterGroup", + "implementation": "org.onap.policy.models.provider.impl.DatabasePolicyModelsProviderImpl", + "databaseUrl": "jdbc:h2:mem:testdb", + "databaseUser": "policy", + "databasePassword": "P01icY", + "persistenceUnit": "PdpGroupTest" } } -- cgit 1.2.3-korg