2 * ============LICENSE_START=======================================================
3 * Copyright (C) 2019-2021,2023 Nordix Foundation.
4 * Modifications Copyright (C) 2020 Bell Canada. All rights reserved.
5 * Modifications Copyright (C) 2021 AT&T Intellectual Property. All rights reserved.
6 * ================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
19 * SPDX-License-Identifier: Apache-2.0
20 * ============LICENSE_END=========================================================
23 package org.onap.policy.models.provider.impl;
25 import static org.assertj.core.api.Assertions.assertThatCode;
26 import static org.junit.Assert.assertEquals;
27 import static org.junit.Assert.assertNotNull;
29 import java.net.URISyntaxException;
30 import java.util.LinkedHashMap;
31 import java.util.List;
34 import java.util.concurrent.CountDownLatch;
35 import java.util.concurrent.TimeUnit;
36 import lombok.NonNull;
37 import org.junit.After;
38 import org.junit.Before;
39 import org.junit.Test;
40 import org.onap.policy.common.utils.coder.CoderException;
41 import org.onap.policy.common.utils.coder.StandardCoder;
42 import org.onap.policy.common.utils.coder.YamlJsonTranslator;
43 import org.onap.policy.common.utils.resources.ResourceUtils;
44 import org.onap.policy.models.base.PfModelException;
45 import org.onap.policy.models.provider.PolicyModelsProvider;
46 import org.onap.policy.models.provider.PolicyModelsProviderFactory;
47 import org.onap.policy.models.provider.PolicyModelsProviderParameters;
48 import org.onap.policy.models.tosca.authorative.concepts.ToscaEntityFilter;
49 import org.onap.policy.models.tosca.authorative.concepts.ToscaPolicy;
50 import org.onap.policy.models.tosca.authorative.concepts.ToscaPolicyType;
51 import org.onap.policy.models.tosca.authorative.concepts.ToscaServiceTemplate;
52 import org.onap.policy.models.tosca.authorative.concepts.ToscaTypedEntityFilter;
53 import org.slf4j.Logger;
54 import org.slf4j.LoggerFactory;
57 * Test persistence of monitoring policies to and from the database.
59 * @author Liam Fallon (liam.fallon@est.tech)
61 public class PolicyToscaPersistenceTest {
62 private static final Logger LOGGER = LoggerFactory.getLogger(PolicyToscaPersistenceTest.class);
64 private YamlJsonTranslator yamlJsonTranslator = new YamlJsonTranslator();
65 private StandardCoder standardCoder = new StandardCoder();
67 private PolicyModelsProvider databaseProvider;
70 * Initialize provider.
72 * @throws PfModelException on exceptions in the tests
73 * @throws CoderException on JSON encoding and decoding errors
76 public void setupParameters() throws Exception {
77 // H2, use "org.mariadb.jdbc.Driver" and "jdbc:mariadb://localhost:3306/policy" for locally installed MariaDB
79 PolicyModelsProviderParameters parameters = new PolicyModelsProviderParameters();
81 if (System.getProperty("USE-MARIADB") != null) {
82 parameters.setDatabaseDriver("org.mariadb.jdbc.Driver");
83 parameters.setDatabaseUrl("jdbc:mariadb://localhost:3306/policy");
84 parameters.setDatabaseType("org.hibernate.dialect.MariaDBDialect");
86 parameters.setDatabaseDriver("org.h2.Driver");
87 parameters.setDatabaseUrl("jdbc:h2:mem:PolicyToscaPersistenceTest");
88 parameters.setDatabaseType("org.hibernate.dialect.H2Dialect");
91 parameters.setDatabaseUser("policy");
92 parameters.setDatabasePassword("P01icY");
93 parameters.setPersistenceUnit("ToscaConceptTest");
96 databaseProvider = new PolicyModelsProviderFactory().createPolicyModelsProvider(parameters);
102 public void teardown() throws Exception {
103 databaseProvider.close();
107 public void testToscaPolicyPersistence() throws Exception {
108 Set<String> policyResources = ResourceUtils.getDirectoryContents("policies");
110 for (String policyResource : policyResources) {
111 if (!policyResource.contains("\\.tosca\\.")) {
115 String policyString = ResourceUtils.getResourceAsString(policyResource);
117 if (policyResource.endsWith("yaml")) {
118 testPolicyPersistence(yamlJsonTranslator.fromYaml(policyString, ToscaServiceTemplate.class));
120 testPolicyPersistence(standardCoder.decode(policyString, ToscaServiceTemplate.class));
126 public void testHpaPolicyTypeGet() throws PfModelException {
127 long getStartTime = System.currentTimeMillis();
128 ToscaServiceTemplate hpaServiceTemplate =
129 databaseProvider.getPolicyTypes("onap.policies.optimization.resource.HpaPolicy", "1.0.0");
130 LOGGER.trace("HPA policy normal get time (ms): {}", System.currentTimeMillis() - getStartTime);
132 assertEquals(3, hpaServiceTemplate.getPolicyTypesAsMap().size());
133 assertEquals(5, hpaServiceTemplate.getDataTypesAsMap().size());
135 getStartTime = System.currentTimeMillis();
136 ToscaEntityFilter<ToscaPolicyType> hpaFilter = ToscaEntityFilter.<ToscaPolicyType>builder()
137 .name("onap.policies.optimization.resource.HpaPolicy").version("1.0.0").build();
138 hpaServiceTemplate = databaseProvider.getFilteredPolicyTypes(hpaFilter);
139 LOGGER.trace("HPA policy filter name version get time (ms): {}", System.currentTimeMillis() - getStartTime);
141 assertEquals(3, hpaServiceTemplate.getPolicyTypesAsMap().size());
142 assertEquals(5, hpaServiceTemplate.getDataTypesAsMap().size());
144 getStartTime = System.currentTimeMillis();
145 hpaFilter = ToscaEntityFilter.<ToscaPolicyType>builder().name("onap.policies.optimization.resource.HpaPolicy")
147 hpaServiceTemplate = databaseProvider.getFilteredPolicyTypes(hpaFilter);
148 LOGGER.trace("HPA policy filter name only get time (ms): {}", System.currentTimeMillis() - getStartTime);
150 assertEquals(3, hpaServiceTemplate.getPolicyTypesAsMap().size());
151 assertEquals(5, hpaServiceTemplate.getDataTypesAsMap().size());
155 public void testNamingPolicyGet() throws PfModelException {
156 String policyYamlString = ResourceUtils.getResourceAsString("policies/sdnc.policy.naming.input.tosca.yaml");
157 ToscaServiceTemplate serviceTemplate =
158 yamlJsonTranslator.fromYaml(policyYamlString, ToscaServiceTemplate.class);
160 long createStartTime = System.currentTimeMillis();
161 databaseProvider.createPolicies(serviceTemplate);
162 LOGGER.trace("Naming policy create time (ms): {}", System.currentTimeMillis() - createStartTime);
164 long getStartTime = System.currentTimeMillis();
165 ToscaServiceTemplate namingServiceTemplate =
166 databaseProvider.getPolicies("SDNC_Policy.ONAP_NF_NAMING_TIMESTAMP", "1.0.0");
167 LOGGER.trace("Naming policy normal get time (ms): {}", System.currentTimeMillis() - getStartTime);
169 assertEquals(1, namingServiceTemplate.getToscaTopologyTemplate().getPoliciesAsMap().size());
170 assertEquals(1, namingServiceTemplate.getPolicyTypesAsMap().size());
171 assertEquals(3, namingServiceTemplate.getDataTypesAsMap().size());
173 getStartTime = System.currentTimeMillis();
174 ToscaTypedEntityFilter<ToscaPolicy> filter = ToscaTypedEntityFilter.<ToscaPolicy>builder()
175 .name("SDNC_Policy.ONAP_NF_NAMING_TIMESTAMP").version("1.0.0").build();
176 namingServiceTemplate = databaseProvider.getFilteredPolicies(filter);
177 LOGGER.trace("Naming policy filtered get time (ms): {}", System.currentTimeMillis() - getStartTime);
179 assertEquals(1, namingServiceTemplate.getToscaTopologyTemplate().getPoliciesAsMap().size());
180 assertEquals(1, namingServiceTemplate.getPolicyTypesAsMap().size());
181 assertEquals(3, namingServiceTemplate.getDataTypesAsMap().size());
183 getStartTime = System.currentTimeMillis();
184 filter = ToscaTypedEntityFilter.<ToscaPolicy>builder().name("SDNC_Policy.ONAP_NF_NAMING_TIMESTAMP").build();
185 namingServiceTemplate = databaseProvider.getFilteredPolicies(filter);
186 LOGGER.trace("Naming policy filtered name only get time (ms): {}", System.currentTimeMillis() - getStartTime);
188 assertEquals(1, namingServiceTemplate.getToscaTopologyTemplate().getPoliciesAsMap().size());
189 assertEquals(1, namingServiceTemplate.getPolicyTypesAsMap().size());
190 assertEquals(3, namingServiceTemplate.getDataTypesAsMap().size());
192 long deleteStartTime = System.currentTimeMillis();
193 ToscaServiceTemplate deletedServiceTemplate =
194 databaseProvider.deletePolicy("SDNC_Policy.ONAP_NF_NAMING_TIMESTAMP", "1.0.0");
195 LOGGER.trace("Naming policy delete time (ms): {}", System.currentTimeMillis() - deleteStartTime);
197 assertEquals(1, deletedServiceTemplate.getToscaTopologyTemplate().getPoliciesAsMap().size());
201 public void testNamingPolicyVersions() throws PfModelException {
202 String policyYamlString = ResourceUtils.getResourceAsString("policies/sdnc.policy.naming.input.tosca.yaml");
203 ToscaServiceTemplate serviceTemplate =
204 yamlJsonTranslator.fromYaml(policyYamlString, ToscaServiceTemplate.class);
206 // Create policy types and data types
207 List<Map<String, ToscaPolicy>> policyMapList = serviceTemplate.getToscaTopologyTemplate().getPolicies();
208 databaseProvider.createPolicies(serviceTemplate);
210 // Clear the policy map list so we start from afresh with versions
211 ToscaPolicy namingPolicy = policyMapList.get(0).values().iterator().next();
212 policyMapList.clear();
214 // Create 21 more versions of the policy
215 for (int i = 2; i < 22; i++) {
216 ToscaPolicy clonedNamingPolicy = new ToscaPolicy(namingPolicy);
217 clonedNamingPolicy.setVersion(i + ".0.0");
218 Map<String, ToscaPolicy> policyMap = new LinkedHashMap<>(1);
219 policyMap.put(clonedNamingPolicy.getName(), clonedNamingPolicy);
220 policyMapList.add(policyMap);
223 databaseProvider.createPolicies(serviceTemplate);
225 for (int i = 1; i < 22; i++) {
226 ToscaServiceTemplate namingServiceTemplate =
227 databaseProvider.getPolicies("SDNC_Policy.ONAP_NF_NAMING_TIMESTAMP", i + ".0.0");
228 assertEquals(i + ".0.0", namingServiceTemplate.getToscaTopologyTemplate().getPolicies().get(0).values()
229 .iterator().next().getVersion());
231 ToscaTypedEntityFilter<ToscaPolicy> policyFilter = ToscaTypedEntityFilter.<ToscaPolicy>builder()
232 .name("SDNC_Policy.ONAP_NF_NAMING_TIMESTAMP").version(i + ".0.0").build();
233 namingServiceTemplate = databaseProvider.getFilteredPolicies(policyFilter);
234 assertEquals(i + ".0.0", namingServiceTemplate.getToscaTopologyTemplate().getPolicies().get(0).values()
235 .iterator().next().getVersion());
238 ToscaTypedEntityFilter<ToscaPolicy> policyFilter = ToscaTypedEntityFilter.<ToscaPolicy>builder()
239 .name("SDNC_Policy.ONAP_NF_NAMING_TIMESTAMP").version(ToscaTypedEntityFilter.LATEST_VERSION).build();
240 ToscaServiceTemplate namingServiceTemplate = databaseProvider.getFilteredPolicies(policyFilter);
241 assertEquals("21.0.0", namingServiceTemplate.getToscaTopologyTemplate().getPolicies().get(0).values().iterator()
242 .next().getVersion());
244 for (int i = 1; i < 22; i++) {
245 ToscaServiceTemplate deletedServiceTemplate =
246 databaseProvider.deletePolicy("SDNC_Policy.ONAP_NF_NAMING_TIMESTAMP", i + ".0.0");
247 assertEquals(1, deletedServiceTemplate.getToscaTopologyTemplate().getPoliciesAsMap().size());
252 * Check persistence of a policy.
254 * @param serviceTemplate the service template containing the policy
255 * @throws Exception any exception thrown
257 public void testPolicyPersistence(@NonNull final ToscaServiceTemplate serviceTemplate) throws Exception {
258 assertNotNull(serviceTemplate);
260 CountDownLatch threadCountDownLatch = new CountDownLatch(10);
262 for (int i = 0; i < 10; i++) {
266 assertThatCode(() -> databaseProvider.createPolicies(serviceTemplate)).doesNotThrowAnyException();
267 assertThatCode(() -> databaseProvider.updatePolicies(serviceTemplate)).doesNotThrowAnyException();
268 threadCountDownLatch.countDown();
273 threadCountDownLatch.await(10, TimeUnit.SECONDS);
275 for (Map<String, ToscaPolicy> policyMap : serviceTemplate.getToscaTopologyTemplate().getPolicies()) {
276 for (ToscaPolicy policy : policyMap.values()) {
277 ToscaServiceTemplate gotToscaServiceTemplate =
278 databaseProvider.getPolicies(policy.getName(), policy.getVersion());
280 assertEquals(policy.getType(), gotToscaServiceTemplate.getToscaTopologyTemplate().getPolicies().get(0)
281 .get(policy.getName()).getType());
283 gotToscaServiceTemplate =
284 databaseProvider.getFilteredPolicies(ToscaTypedEntityFilter.<ToscaPolicy>builder().build());
286 assertEquals(policy.getType(),
287 getToscaPolicyFromMapList(gotToscaServiceTemplate.getToscaTopologyTemplate().getPolicies(),
288 policy.getName()).getType());
290 gotToscaServiceTemplate = databaseProvider.getFilteredPolicies(ToscaTypedEntityFilter
291 .<ToscaPolicy>builder().name(policy.getName()).version(policy.getVersion()).build());
293 assertEquals(policy.getType(), gotToscaServiceTemplate.getToscaTopologyTemplate().getPolicies().get(0)
294 .get(policy.getName()).getType());
299 private ToscaPolicy getToscaPolicyFromMapList(List<Map<String, ToscaPolicy>> toscaPolicyMapList,
301 ToscaPolicy toscaPolicy = new ToscaPolicy();
302 for (Map<String, ToscaPolicy> policyMap : toscaPolicyMapList) {
303 toscaPolicy = policyMap.get(policyName);
304 if (toscaPolicy != null) {
311 private void createPolicyTypes() throws CoderException, PfModelException, URISyntaxException {
312 Set<String> policyTypeResources = ResourceUtils.getDirectoryContents("policytypes");
314 for (String policyTypeResource : policyTypeResources) {
315 String policyTypeYamlString = ResourceUtils.getResourceAsString(policyTypeResource);
316 ToscaServiceTemplate toscaServiceTemplatePolicyType =
317 yamlJsonTranslator.fromYaml(policyTypeYamlString, ToscaServiceTemplate.class);
319 assertNotNull(toscaServiceTemplatePolicyType);
320 databaseProvider.createPolicyTypes(toscaServiceTemplatePolicyType);