2  * ============LICENSE_START=======================================================
 
   3  *  Copyright (C) 2021 Nordix Foundation.
 
   4  * ================================================================================
 
   5  * Licensed under the Apache License, Version 2.0 (the "License");
 
   6  * you may not use this file except in compliance with the License.
 
   7  * You may obtain a copy of the License at
 
   9  *      http://www.apache.org/licenses/LICENSE-2.0
 
  11  * Unless required by applicable law or agreed to in writing, software
 
  12  * distributed under the License is distributed on an "AS IS" BASIS,
 
  13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
  14  * See the License for the specific language governing permissions and
 
  15  * limitations under the License.
 
  17  * SPDX-License-Identifier: Apache-2.0
 
  18  * ============LICENSE_END=========================================================
 
  21 package org.onap.policy.clamp.controlloop.participant.policy.main.parameters;
 
  23 import java.util.Arrays;
 
  24 import java.util.List;
 
  26 import java.util.TreeMap;
 
  27 import org.onap.policy.common.endpoints.parameters.TopicParameters;
 
  28 import org.onap.policy.common.utils.coder.Coder;
 
  29 import org.onap.policy.common.utils.coder.CoderException;
 
  30 import org.onap.policy.common.utils.coder.StandardCoder;
 
  31 import org.onap.policy.models.tosca.authorative.concepts.ToscaConceptIdentifier;
 
  34  * Class to hold/create all parameters for test cases.
 
  36 public class CommonTestData {
 
  37     public static final String PARTICIPANT_GROUP_NAME = "ControlLoopParticipantGroup";
 
  38     public static final String DESCRIPTION = "Participant description";
 
  39     public static final long TIME_INTERVAL = 2000;
 
  40     public static final List<TopicParameters> TOPIC_PARAMS = Arrays.asList(getTopicParams());
 
  42     public static final Coder CODER = new StandardCoder();
 
  45      * Get ParticipantPolicyParameters.
 
  47      * @return ParticipantPolicyParameters
 
  49     public ParticipantPolicyParameters getParticipantPolicyParameters() {
 
  51             return CODER.convert(getParticipantPolicyParametersMap(PARTICIPANT_GROUP_NAME),
 
  52                     ParticipantPolicyParameters.class);
 
  53         } catch (final CoderException e) {
 
  54             throw new RuntimeException("cannot create ParticipantPolicyParameters from map", e);
 
  59      * Returns a property map for a ParticipantPolicyParameters map for test cases.
 
  61      * @param name name of the parameters
 
  63      * @return a property map suitable for constructing an object
 
  65     public Map<String, Object> getParticipantPolicyParametersMap(final String name) {
 
  66         final Map<String, Object> map = new TreeMap<>();
 
  68         map.put("name", name);
 
  69         map.put("intermediaryParameters", getIntermediaryParametersMap(false));
 
  70         map.put("policyApiParameters", getPolicyApiParametersMap());
 
  75      * Returns a property map for a policyApiParameters map for test cases.
 
  77      * @return a property map suitable for constructing an object
 
  79     public Map<String, Object> getPolicyApiParametersMap() {
 
  80         final Map<String, Object> map = new TreeMap<>();
 
  81         map.put("clientName", "api");
 
  82         map.put("hostname", "localhost");
 
  83         map.put("port", 6969);
 
  84         map.put("userName", "healthcheck");
 
  85         map.put("password", "zb!XztG34");
 
  86         map.put("https", false);
 
  87         map.put("allowSelfSignedCerts", true);
 
  93      * Returns a property map for a intermediaryParameters map for test cases.
 
  95      * @param isEmpty boolean value to represent that object created should be empty or not
 
  96      * @return a property map suitable for constructing an object
 
  98     public Map<String, Object> getIntermediaryParametersMap(final boolean isEmpty) {
 
  99         final Map<String, Object> map = new TreeMap<>();
 
 101             map.put("name", "Participant parameters");
 
 102             map.put("reportingTimeIntervalMs", TIME_INTERVAL);
 
 103             map.put("description", DESCRIPTION);
 
 104             map.put("participantId", getParticipantId());
 
 105             map.put("participantType", getParticipantId());
 
 106             map.put("clampControlLoopTopics", getTopicParametersMap(false));
 
 113      * Returns a property map for a TopicParameters map for test cases.
 
 115      * @param isEmpty boolean value to represent that object created should be empty or not
 
 116      * @return a property map suitable for constructing an object
 
 118     public Map<String, Object> getTopicParametersMap(final boolean isEmpty) {
 
 119         final Map<String, Object> map = new TreeMap<>();
 
 121             map.put("topicSources", TOPIC_PARAMS);
 
 122             map.put("topicSinks", TOPIC_PARAMS);
 
 128      * Returns topic parameters for test cases.
 
 130      * @return topic parameters
 
 132     public static TopicParameters getTopicParams() {
 
 133         final TopicParameters topicParams = new TopicParameters();
 
 134         topicParams.setTopic("POLICY-CLRUNTIME-PARTICIPANT");
 
 135         topicParams.setTopicCommInfrastructure("dmaap");
 
 136         topicParams.setServers(Arrays.asList("localhost"));
 
 141      * Returns participantId for test cases.
 
 143      * @return participant Id
 
 145     public static ToscaConceptIdentifier getParticipantId() {
 
 146         final ToscaConceptIdentifier participantId = new ToscaConceptIdentifier("org.onap.PM_Policy", "0.0.0");
 
 147         return participantId;
 
 151      * Nulls out a field within a JSON string.
 
 153      * @param json JSON string
 
 154      * @param field field to be nulled out
 
 155      * @return a new JSON string with the field nulled out
 
 157     public String nullifyField(String json, String field) {
 
 158         return json.replace(field + "\"", field + "\":null, \"" + field + "Xxx\"");