2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017 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.
18 * ============LICENSE_END=========================================================
20 package org.openecomp.policy.controlloop.policy;
22 import static org.junit.Assert.assertFalse;
23 import static org.junit.Assert.assertNotNull;
24 import static org.junit.Assert.assertTrue;
25 import static org.junit.Assert.fail;
28 import java.io.FileInputStream;
29 import java.io.FileNotFoundException;
30 import java.io.IOException;
31 import java.io.InputStream;
32 import java.util.UUID;
34 import org.junit.Test;
35 import org.openecomp.policy.asdc.Resource;
36 import org.openecomp.policy.asdc.ResourceType;
37 import org.openecomp.policy.asdc.Service;
38 import org.openecomp.policy.controlloop.policy.builder.BuilderException;
39 import org.openecomp.policy.controlloop.policy.builder.ControlLoopPolicyBuilder;
40 import org.openecomp.policy.controlloop.policy.builder.Message;
41 import org.openecomp.policy.controlloop.policy.builder.MessageLevel;
42 import org.openecomp.policy.controlloop.policy.builder.Results;
43 import org.yaml.snakeyaml.Yaml;
44 import org.yaml.snakeyaml.constructor.Constructor;
45 import org.yaml.snakeyaml.error.YAMLException;
48 public class ControlLoopPolicyBuilderTest {
51 public void testControlLoop() {
54 // Create a builder for our policy
56 ControlLoopPolicyBuilder builder = ControlLoopPolicyBuilder.Factory.buildControlLoop(UUID.randomUUID().toString(), 2400);
60 Service vSCP = new Service("vSCP");
61 Service vUSP = new Service("vUSP");
62 Service vTrinity = new Service("Trinity");
63 builder = builder.addService(vSCP, vUSP, vTrinity);
64 assertTrue(builder.getControlLoop().getServices().size() == 3);
66 // Test remove services
68 builder = builder.removeService(vSCP);
69 assertTrue(builder.getControlLoop().getServices().size() == 2);
70 builder = builder.removeAllServices();
71 assertTrue(builder.getControlLoop().getServices().size() == 0);
75 Resource vCTS = new Resource("vCTS", ResourceType.VF);
76 Resource vCOM = new Resource("vCTS", ResourceType.VF);
77 Resource vRAR = new Resource("vCTS", ResourceType.VF);
78 builder = builder.addResource(vCTS, vCOM, vRAR);
79 assertTrue(builder.getControlLoop().getResources().size() == 3);
81 // Test remove resources
83 builder = builder.removeResource(vCTS);
84 assertTrue(builder.getControlLoop().getResources().size() == 2);
85 builder = builder.removeAllResources();
86 assertTrue(builder.getControlLoop().getResources().size() == 0);
90 assertFalse(builder.getControlLoop().getAbatement());
91 builder = builder.setAbatement(true);
92 assertTrue(builder.getControlLoop().getAbatement());
93 } catch (BuilderException e) {
99 public void testTimeout() {
102 // Create a builder for our policy
104 ControlLoopPolicyBuilder builder = ControlLoopPolicyBuilder.Factory.buildControlLoop(UUID.randomUUID().toString(), 2400);
108 assertTrue(builder.getControlLoop().getTimeout() == 2400);
109 builder = builder.setTimeout(800);
110 assertTrue(builder.getControlLoop().getTimeout() == 800);
112 // Test calculateTimeout
114 Policy trigger = builder.setTriggerPolicy(
116 "Upon getting the trigger event, restart the VM",
118 new Target(TargetType.VM),
123 @SuppressWarnings("unused")
124 Policy onRestartFailurePolicy = builder.setPolicyForPolicyResult(
126 "If the restart fails, rebuild it",
128 new Target(TargetType.VM),
134 PolicyResult.FAILURE,
135 PolicyResult.FAILURE_RETRIES,
136 PolicyResult.FAILURE_TIMEOUT);
137 assertTrue(builder.calculateTimeout().equals(new Integer(300 + 600)));
139 } catch (BuilderException e) {
140 fail(e.getMessage());
145 public void testTriggerPolicyMethods() {
147 ControlLoopPolicyBuilder builder = ControlLoopPolicyBuilder.Factory.buildControlLoop(UUID.randomUUID().toString(), 2400);
151 assertTrue(builder.isOpenLoop());
153 // Test set initial trigger policy
155 Policy triggerPolicy1 = builder.setTriggerPolicy(
157 "Upon getting the trigger event, restart the VM",
159 new Target(TargetType.VM),
164 assertTrue(builder.isOpenLoop() == false);
165 assertTrue(builder.getControlLoop().getTrigger_policy().equals(triggerPolicy1.getId()));
167 // Set trigger policy to a new policy
169 @SuppressWarnings("unused")
170 Policy triggerPolicy2 = builder.setTriggerPolicy(
172 "Upon getting the trigger event, rebuild the VM",
174 new Target(TargetType.VM),
180 // Test set trigger policy to another existing policy
182 @SuppressWarnings("unused")
183 ControlLoop cl = builder.setTriggerPolicy(triggerPolicy1.getId());
184 assertTrue(builder.getControlLoop().getTrigger_policy().equals(triggerPolicy1.getId()));
186 // Test get trigger policy
188 assertTrue(builder.getTriggerPolicy().equals(triggerPolicy1));
190 } catch (BuilderException e) {
191 fail(e.getMessage());
196 public void testAddRemovePolicies() {
198 ControlLoopPolicyBuilder builder = ControlLoopPolicyBuilder.Factory.buildControlLoop(UUID.randomUUID().toString(), 2400);
199 Policy triggerPolicy = builder.setTriggerPolicy(
201 "Upon getting the trigger event, restart the VM",
203 new Target(TargetType.VM),
209 // Test create a policy and chain it to the results of trigger policy
211 Policy onRestartFailurePolicy1 = builder.setPolicyForPolicyResult(
213 "If the restart fails, rebuild it.",
215 new Target(TargetType.VM),
220 triggerPolicy.getId(),
221 PolicyResult.FAILURE,
222 PolicyResult.FAILURE_RETRIES,
223 PolicyResult.FAILURE_TIMEOUT,
224 PolicyResult.FAILURE_GUARD);
226 assertTrue(builder.getTriggerPolicy().getFailure().equals(onRestartFailurePolicy1.getId()));
227 assertTrue(builder.getTriggerPolicy().getFailure_retries().equals(onRestartFailurePolicy1.getId()));
228 assertTrue(builder.getTriggerPolicy().getFailure_timeout().equals(onRestartFailurePolicy1.getId()));
229 assertTrue(builder.getTriggerPolicy().getFailure_guard().equals(onRestartFailurePolicy1.getId()));
231 // Test remove policy
233 boolean removed = builder.removePolicy(onRestartFailurePolicy1.getId());
235 assertTrue(builder.getTriggerPolicy().getFailure().equals(FinalResult.FINAL_FAILURE.toString()));
236 assertTrue(builder.getTriggerPolicy().getFailure_retries().equals(FinalResult.FINAL_FAILURE_RETRIES.toString()));
237 assertTrue(builder.getTriggerPolicy().getFailure_timeout().equals(FinalResult.FINAL_FAILURE_TIMEOUT.toString()));
238 assertTrue(builder.getTriggerPolicy().getFailure_guard().equals(FinalResult.FINAL_FAILURE_GUARD.toString()));
240 // Create another policy and chain it to the results of trigger policy
242 Policy onRestartFailurePolicy2 = builder.setPolicyForPolicyResult(
244 "If the restart fails, rebuild it.",
246 new Target(TargetType.VM),
251 triggerPolicy.getId(),
252 PolicyResult.FAILURE,
253 PolicyResult.FAILURE_RETRIES,
254 PolicyResult.FAILURE_TIMEOUT);
256 // Test reset policy results
258 triggerPolicy = builder.resetPolicyResults(triggerPolicy.getId());
259 assertTrue(builder.getTriggerPolicy().getFailure().equals(FinalResult.FINAL_FAILURE.toString()));
260 assertTrue(builder.getTriggerPolicy().getFailure_retries().equals(FinalResult.FINAL_FAILURE_RETRIES.toString()));
261 assertTrue(builder.getTriggerPolicy().getFailure_timeout().equals(FinalResult.FINAL_FAILURE_TIMEOUT.toString()));
263 // Test set the policy results to an existing operational policy
265 onRestartFailurePolicy2 = builder.setPolicyForPolicyResult(
266 onRestartFailurePolicy2.getId(),
267 triggerPolicy.getId(),
268 PolicyResult.FAILURE,
269 PolicyResult.FAILURE_RETRIES,
270 PolicyResult.FAILURE_TIMEOUT);
271 assertTrue(builder.getTriggerPolicy().getFailure().equals(onRestartFailurePolicy2.getId()));
272 assertTrue(builder.getTriggerPolicy().getFailure_retries().equals(onRestartFailurePolicy2.getId()));
273 assertTrue(builder.getTriggerPolicy().getFailure_timeout().equals(onRestartFailurePolicy2.getId()));
276 // Test remove all existing operational policies
278 builder = builder.removeAllPolicies();
279 assertTrue(builder.getControlLoop().getTrigger_policy().equals(FinalResult.FINAL_OPENLOOP.toString()));
281 } catch (BuilderException e) {
282 fail(e.getMessage());
287 public void testAddOperationsAccumulateParams() {
289 ControlLoopPolicyBuilder builder = ControlLoopPolicyBuilder.Factory.buildControlLoop(UUID.randomUUID().toString(), 2400);
290 Policy triggerPolicy = builder.setTriggerPolicy(
291 "Restart the eNodeB",
292 "Upon getting the trigger event, restart the eNodeB",
294 new Target(TargetType.PNF),
300 // Add the operationsAccumulateParams
302 triggerPolicy = builder.addOperationsAccumulateParams(triggerPolicy.getId(), new OperationsAccumulateParams("15m", 5));
303 assertNotNull(builder.getTriggerPolicy().getOperationsAccumulateParams());
304 assertTrue(builder.getTriggerPolicy().getOperationsAccumulateParams().getPeriod().equals("15m"));
305 assertTrue(builder.getTriggerPolicy().getOperationsAccumulateParams().getLimit() == 5);
307 } catch (BuilderException e) {
308 fail(e.getMessage());
314 public void testBuildSpecification() {
317 // Create the builder
319 ControlLoopPolicyBuilder builder = ControlLoopPolicyBuilder.Factory.buildControlLoop(UUID.randomUUID().toString(), 800);
321 // Set the first invalid trigger policy
323 Policy policy1 = builder.setTriggerPolicy(
325 "Upon getting the trigger event, restart the VM",
332 Results results = builder.buildSpecification();
334 // Check that ERRORs are in results for invalid policy arguments
336 boolean invalid_actor = false;
337 boolean invalid_recipe = false;
338 boolean invalid_target = false;
339 for (Message m : results.getMessages()) {
340 if (m.getMessage().equals("Policy actor is null") && m.getLevel() == MessageLevel.ERROR) {
341 invalid_actor = true;
343 if (m.getMessage().equals("Policy recipe is invalid") && m.getLevel() == MessageLevel.ERROR) {
344 invalid_recipe = true;
346 if (m.getMessage().equals("Policy target is null") && m.getLevel() == MessageLevel.ERROR) {
347 invalid_target = true;
351 assertTrue(invalid_actor);
352 assertTrue(invalid_recipe);
353 assertTrue(invalid_target);
355 // Remove the invalid policy
357 //@SuppressWarnings("unused")
358 boolean removed = builder.removePolicy(policy1.getId());
360 assertTrue(builder.getTriggerPolicy() == null);
362 // Set a valid trigger policy
364 policy1 = builder.setTriggerPolicy(
366 "If the restart fails, rebuild it.",
368 new Target(TargetType.VM),
374 // Set a second valid trigger policy
376 Policy policy2 = builder.setTriggerPolicy(
378 "Upon getting the trigger event, restart the VM",
380 new Target(TargetType.VM),
386 // Now, we have policy1 unreachable
388 results = builder.buildSpecification();
389 boolean unreachable = false;
390 for (Message m : results.getMessages()) {
391 if (m.getMessage().equals("Policy " + policy1.getId() + " is not reachable.") && m.getLevel() == MessageLevel.WARNING) {
396 assertTrue(unreachable);
398 // Set policy1 for the failure results of policy2
400 policy1 = builder.setPolicyForPolicyResult(
403 PolicyResult.FAILURE,
404 PolicyResult.FAILURE_RETRIES,
405 PolicyResult.FAILURE_TIMEOUT);
406 results = builder.buildSpecification();
407 boolean invalid_timeout = false;
408 for (Message m : results.getMessages()) {
409 if (m.getMessage().equals("controlLoop overall timeout is less than the sum of operational policy timeouts.") && m.getLevel() == MessageLevel.ERROR) {
410 invalid_timeout = true;
414 assertTrue(invalid_timeout);
416 // Remove policy2 (revert controlLoop back to open loop)
418 removed = builder.removePolicy(policy2.getId());
420 // ControlLoop is open loop now, but it still has policies (policy1)
422 results = builder.buildSpecification();
424 for (Message m : results.getMessages()) {
425 if (m.getMessage().equals("Open Loop policy contains policies. The policies will never be invoked.") && m.getLevel() == MessageLevel.WARNING) {
430 assertTrue(unreachable);
432 } catch (BuilderException e) {
433 fail(e.getMessage());
440 this.test("src/test/resources/v1.0.0/policy_Test.yaml");
444 public void testEvilYaml() {
445 try (InputStream is = new FileInputStream(new File("src/test/resources/v1.0.0/test_evil.yaml"))) {
447 // Read the yaml into our Java Object
449 Yaml yaml = new Yaml(new Constructor(ControlLoopPolicy.class));
451 } catch (FileNotFoundException e) {
452 fail(e.getLocalizedMessage());
453 } catch (IOException e) {
454 fail(e.getLocalizedMessage());
455 } catch (YAMLException e) {
462 public void test(String testFile) {
463 try (InputStream is = new FileInputStream(new File(testFile))) {
465 // Read the yaml into our Java Object
467 Yaml yaml = new Yaml(new Constructor(ControlLoopPolicy.class));
468 Object obj = yaml.load(is);
470 assertTrue(obj instanceof ControlLoopPolicy);
471 ControlLoopPolicy policyTobuild = (ControlLoopPolicy) obj;
473 // Now we're going to try to use the builder to build this.
475 ControlLoopPolicyBuilder builder = ControlLoopPolicyBuilder.Factory.buildControlLoop(
476 policyTobuild.getControlLoop().getControlLoopName(),
477 policyTobuild.getControlLoop().getTimeout());
481 if (policyTobuild.getControlLoop().getServices() != null) {
482 builder = builder.addService(policyTobuild.getControlLoop().getServices().toArray(new Service[policyTobuild.getControlLoop().getServices().size()]));
487 if (policyTobuild.getControlLoop().getResources() != null) {
488 builder = builder.addResource(policyTobuild.getControlLoop().getResources().toArray(new Resource[policyTobuild.getControlLoop().getResources().size()]));
491 // Add the policies and be sure to set the trigger policy
493 if (policyTobuild.getPolicies() != null) {
494 for (Policy policy : policyTobuild.getPolicies()) {
495 if (policy.getId() == policyTobuild.getControlLoop().getTrigger_policy()) {
496 builder.setTriggerPolicy(policy.getName(), policy.getDescription(), policy.getActor(), policy.getTarget(), policy.getRecipe(), null, policy.getRetry(), policy.getTimeout());
501 // Question : how to change policy ID and results by using builder ??
503 @SuppressWarnings("unused")
504 Results results = builder.buildSpecification();
506 } catch (FileNotFoundException e) {
507 fail(e.getLocalizedMessage());
508 } catch (IOException e) {
509 fail(e.getLocalizedMessage());
510 } catch (BuilderException e) {
511 fail(e.getLocalizedMessage());