Fix return building on policy get
[policy/models.git] / models-interactions / model-actors / actorServiceProvider / src / test / java / org / onap / policy / controlloop / actorserviceprovider / parameters / TopicPairParamsTest.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * ONAP
4  * ================================================================================
5  * Copyright (C) 2020 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
10  *
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  *
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=========================================================
19  */
20
21 package org.onap.policy.controlloop.actorserviceprovider.parameters;
22
23 import static org.assertj.core.api.Assertions.assertThat;
24 import static org.junit.Assert.assertEquals;
25 import static org.junit.Assert.assertFalse;
26 import static org.junit.Assert.assertTrue;
27
28 import java.util.function.Function;
29 import org.junit.Before;
30 import org.junit.Test;
31 import org.onap.policy.common.parameters.ValidationResult;
32 import org.onap.policy.controlloop.actorserviceprovider.parameters.TopicPairParams.TopicPairParamsBuilder;
33
34 public class TopicPairParamsTest {
35
36     private static final String CONTAINER = "my-container";
37     private static final String TARGET = "my-target";
38     private static final String SOURCE = "my-source";
39     private static final int TIMEOUT = 10;
40
41     private TopicPairParams params;
42
43     @Before
44     public void setUp() {
45         params = TopicPairParams.builder().target(TARGET).source(SOURCE).timeoutSec(TIMEOUT).build();
46     }
47
48     @Test
49     public void testValidate() {
50         testValidateField("target", "null", bldr -> bldr.target(null));
51         testValidateField("source", "null", bldr -> bldr.source(null));
52         testValidateField("timeoutSec", "minimum", bldr -> bldr.timeoutSec(-1));
53
54         // check edge cases
55         assertFalse(params.toBuilder().timeoutSec(0).build().validate(CONTAINER).isValid());
56         assertTrue(params.toBuilder().timeoutSec(1).build().validate(CONTAINER).isValid());
57
58         // some default values should be valid
59         assertTrue(TopicPairParams.builder().target(TARGET).source(SOURCE).build().validate(CONTAINER).isValid());
60     }
61
62     @Test
63     public void testBuilder_testToBuilder() {
64         assertEquals(TARGET, params.getTarget());
65         assertEquals(SOURCE, params.getSource());
66         assertEquals(TIMEOUT, params.getTimeoutSec());
67
68         assertEquals(params, params.toBuilder().build());
69     }
70
71     private void testValidateField(String fieldName, String expected,
72                     Function<TopicPairParamsBuilder, TopicPairParamsBuilder> makeInvalid) {
73
74         // original params should be valid
75         ValidationResult result = params.validate(CONTAINER);
76         assertTrue(fieldName, result.isValid());
77
78         // make invalid params
79         result = makeInvalid.apply(params.toBuilder()).build().validate(CONTAINER);
80         assertFalse(fieldName, result.isValid());
81         assertThat(result.getResult()).contains(fieldName).contains(expected);
82     }
83 }