6aed6cdf7d9eb817f7fe02e98587b9ca80b9a11b
[policy/common.git] /
1 /*
2  * ============LICENSE_START=======================================================
3  * policy-endpoints
4  * ================================================================================
5  * Copyright (C) 2022, 2024 Nordix Foundation.
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.common.endpoints.event.comm.bus;
22
23 import static org.junit.jupiter.api.Assertions.assertEquals;
24 import static org.junit.jupiter.api.Assertions.assertFalse;
25 import static org.junit.jupiter.api.Assertions.assertTrue;
26 import static org.onap.policy.common.endpoints.properties.PolicyEndPointProperties.PROPERTY_KAFKA_SINK_TOPICS;
27 import static org.onap.policy.common.endpoints.properties.PolicyEndPointProperties.PROPERTY_TOPIC_EFFECTIVE_TOPIC_SUFFIX;
28
29 import java.util.Deque;
30 import java.util.LinkedList;
31 import java.util.List;
32 import java.util.Properties;
33 import org.junit.jupiter.api.AfterEach;
34 import org.junit.jupiter.api.BeforeEach;
35 import org.junit.jupiter.api.Test;
36 import org.onap.policy.common.endpoints.event.comm.bus.internal.BusTopicParams;
37
38 class KafkaTopicSinkFactoryTest extends KafkaTopicFactoryTestBase<KafkaTopicSink> {
39
40     private SinkFactory factory;
41     public static final String KAFKA_SERVER = "localhost:9092";
42
43     /**
44      * Creates the object to be tested.
45      */
46     @BeforeEach
47     @Override
48     public void setUp() {
49         super.setUp();
50
51         factory = new SinkFactory();
52     }
53
54     @AfterEach
55     public void tearDown() {
56         factory.destroy();
57     }
58
59     @Test
60     @Override
61     void testBuildBusTopicParams() {
62         super.testBuildBusTopicParams();
63         super.testBuildBusTopicParams_Ex();
64     }
65
66     @Test
67     @Override
68     void testBuildListOfStringString() {
69         super.testBuildListOfStringString();
70
71         // check parameters that were used
72         BusTopicParams params = getLastParams();
73         assertFalse(params.isAllowSelfSignedCerts());
74     }
75
76     @Test
77     @Override
78     void testBuildProperties() {
79         List<KafkaTopicSink> topics = buildTopics(makePropBuilder().makeTopic(MY_TOPIC).build());
80         assertEquals(1, topics.size());
81         assertEquals(MY_TOPIC, topics.get(0).getTopic());
82         assertEquals(MY_EFFECTIVE_TOPIC, topics.get(0).getEffectiveTopic());
83
84         BusTopicParams params = getLastParams();
85         assertTrue(params.isManaged());
86         assertFalse(params.isUseHttps());
87         assertEquals(List.of(KAFKA_SERVER), params.getServers());
88         assertEquals(MY_TOPIC, params.getTopic());
89         assertEquals(MY_EFFECTIVE_TOPIC, params.getEffectiveTopic());
90         assertEquals(MY_PARTITION, params.getPartitionId());
91
92         List<KafkaTopicSink> topics2 = buildTopics(makePropBuilder().makeTopic(TOPIC3)
93             .removeTopicProperty(PROPERTY_TOPIC_EFFECTIVE_TOPIC_SUFFIX).build());
94         assertEquals(1, topics2.size());
95         assertEquals(TOPIC3, topics2.get(0).getTopic());
96         assertEquals(topics2.get(0).getTopic(), topics2.get(0).getEffectiveTopic());
97
98         initFactory();
99
100         assertEquals(1, buildTopics(makePropBuilder().makeTopic(MY_TOPIC).build()).size());
101     }
102
103     @Test
104     @Override
105     void testDestroyString_testGet_testInventory() {
106         super.testDestroyString_testGet_testInventory();
107         super.testDestroyString_Ex();
108     }
109
110     @Test
111     @Override
112     void testDestroy() {
113         super.testDestroy();
114     }
115
116     @Test
117     void testGet() {
118         super.testGet_Ex();
119     }
120
121     @Test
122     void testToString() {
123         assertTrue(factory.toString().startsWith("IndexedKafkaTopicSinkFactory ["));
124     }
125
126     @Override
127     protected void initFactory() {
128         if (factory != null) {
129             factory.destroy();
130         }
131
132         factory = new SinkFactory();
133     }
134
135     @Override
136     protected List<KafkaTopicSink> buildTopics(Properties properties) {
137         return factory.build(properties);
138     }
139
140     @Override
141     protected KafkaTopicSink buildTopic(BusTopicParams params) {
142         return factory.build(params);
143     }
144
145     @Override
146     protected KafkaTopicSink buildTopic(List<String> servers, String topic) {
147         return factory.build(servers, topic);
148     }
149
150     @Override
151     protected void destroyFactory() {
152         factory.destroy();
153     }
154
155     @Override
156     protected void destroyTopic(String topic) {
157         factory.destroy(topic);
158     }
159
160     @Override
161     protected List<KafkaTopicSink> getInventory() {
162         return factory.inventory();
163     }
164
165     @Override
166     protected KafkaTopicSink getTopic(String topic) {
167         return factory.get(topic);
168     }
169
170     @Override
171     protected BusTopicParams getLastParams() {
172         return factory.params.getLast();
173     }
174
175     @Override
176     protected TopicPropertyBuilder makePropBuilder() {
177         return new KafkaTopicPropertyBuilder(PROPERTY_KAFKA_SINK_TOPICS);
178     }
179
180     /**
181      * Factory that records the parameters of all the sinks it creates.
182      */
183     private static class SinkFactory extends IndexedKafkaTopicSinkFactory {
184         private Deque<BusTopicParams> params = new LinkedList<>();
185
186         @Override
187         protected KafkaTopicSink makeSink(BusTopicParams busTopicParams) {
188             params.add(busTopicParams);
189             return super.makeSink(busTopicParams);
190         }
191     }
192 }