2 * ============LICENSE_START=======================================================
3 * Copyright (C) 2021 Nordix Foundation.
4 * Modifications Copyright (C) 2021 AT&T Intellectual Property. All rights reserved.
5 * ================================================================================
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
10 * http://www.apache.org/licenses/LICENSE-2.0
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
18 * SPDX-License-Identifier: Apache-2.0
19 * ============LICENSE_END=========================================================
22 package org.onap.policy.clamp.controlloop.runtime.supervision.comm;
24 import static org.assertj.core.api.Assertions.assertThatCode;
25 import static org.assertj.core.api.Assertions.assertThatThrownBy;
26 import static org.mockito.ArgumentMatchers.anyString;
27 import static org.mockito.Mockito.mock;
28 import static org.mockito.Mockito.verify;
30 import java.time.Instant;
31 import java.util.Collections;
32 import java.util.List;
33 import java.util.UUID;
34 import org.junit.jupiter.api.AfterAll;
35 import org.junit.jupiter.api.BeforeAll;
36 import org.junit.jupiter.api.Test;
37 import org.mockito.Mockito;
38 import org.onap.policy.clamp.controlloop.models.controlloop.concepts.ControlLoop;
39 import org.onap.policy.clamp.controlloop.models.controlloop.concepts.ControlLoopState;
40 import org.onap.policy.clamp.controlloop.models.controlloop.persistence.provider.ClElementStatisticsProvider;
41 import org.onap.policy.clamp.controlloop.models.controlloop.persistence.provider.ControlLoopProvider;
42 import org.onap.policy.clamp.controlloop.models.controlloop.persistence.provider.ParticipantProvider;
43 import org.onap.policy.clamp.controlloop.models.controlloop.persistence.provider.ParticipantStatisticsProvider;
44 import org.onap.policy.clamp.controlloop.models.controlloop.persistence.provider.ServiceTemplateProvider;
45 import org.onap.policy.clamp.controlloop.models.messages.dmaap.participant.ParticipantDeregister;
46 import org.onap.policy.clamp.controlloop.models.messages.dmaap.participant.ParticipantDeregisterAck;
47 import org.onap.policy.clamp.controlloop.models.messages.dmaap.participant.ParticipantRegisterAck;
48 import org.onap.policy.clamp.controlloop.models.messages.dmaap.participant.ParticipantUpdateAck;
49 import org.onap.policy.clamp.controlloop.runtime.main.parameters.ClRuntimeParameterGroup;
50 import org.onap.policy.clamp.controlloop.runtime.monitoring.MonitoringProvider;
51 import org.onap.policy.clamp.controlloop.runtime.supervision.SupervisionHandler;
52 import org.onap.policy.clamp.controlloop.runtime.util.CommonTestData;
53 import org.onap.policy.clamp.controlloop.runtime.util.rest.CommonRestController;
54 import org.onap.policy.common.endpoints.event.comm.Topic.CommInfrastructure;
55 import org.onap.policy.common.endpoints.event.comm.TopicSink;
56 import org.onap.policy.models.base.PfModelException;
57 import org.onap.policy.models.tosca.authorative.concepts.ToscaConceptIdentifier;
59 class SupervisionMessagesTest extends CommonRestController {
61 private static final String NOT_ACTIVE = "Not Active!";
62 private static final Object lockit = new Object();
63 private static final CommInfrastructure INFRA = CommInfrastructure.NOOP;
64 private static final String TOPIC = "my-topic";
65 private static SupervisionHandler supervisionHandler;
66 private static ControlLoopProvider clProvider;
69 * setup Db Provider Parameters.
71 * @throws PfModelException if an error occurs
74 public static void setupDbProviderParameters() throws PfModelException {
75 ClRuntimeParameterGroup controlLoopParameters = CommonTestData.geParameterGroup("instantproviderdb");
77 clProvider = new ControlLoopProvider(controlLoopParameters.getDatabaseProviderParameters());
79 var participantStatisticsProvider =
80 new ParticipantStatisticsProvider(controlLoopParameters.getDatabaseProviderParameters());
81 var clElementStatisticsProvider =
82 new ClElementStatisticsProvider(controlLoopParameters.getDatabaseProviderParameters());
83 var monitoringProvider =
84 new MonitoringProvider(participantStatisticsProvider, clElementStatisticsProvider, clProvider);
85 var participantProvider = new ParticipantProvider(controlLoopParameters.getDatabaseProviderParameters());
86 var serviceTemplateProvider = Mockito.mock(ServiceTemplateProvider.class);
87 var controlLoopUpdatePublisher = Mockito.mock(ControlLoopUpdatePublisher.class);
88 var controlLoopStateChangePublisher = Mockito.mock(ControlLoopStateChangePublisher.class);
89 var participantRegisterAckPublisher = Mockito.mock(ParticipantRegisterAckPublisher.class);
90 var participantDeregisterAckPublisher = Mockito.mock(ParticipantDeregisterAckPublisher.class);
91 var participantUpdatePublisher = Mockito.mock(ParticipantUpdatePublisher.class);
92 supervisionHandler = new SupervisionHandler(clProvider, participantProvider, monitoringProvider,
93 serviceTemplateProvider, controlLoopUpdatePublisher, controlLoopStateChangePublisher,
94 participantRegisterAckPublisher, participantDeregisterAckPublisher, participantUpdatePublisher);
98 public static void closeDbProvider() throws PfModelException {
103 void testSendParticipantRegisterAck() throws Exception {
104 final ParticipantRegisterAck participantRegisterAckMsg = new ParticipantRegisterAck();
105 participantRegisterAckMsg.setMessage("ParticipantRegisterAck message");
106 participantRegisterAckMsg.setResponseTo(UUID.randomUUID());
107 participantRegisterAckMsg.setResult(true);
109 synchronized (lockit) {
110 ParticipantRegisterAckPublisher clRegisterAckPublisher = new ParticipantRegisterAckPublisher();
111 clRegisterAckPublisher.active(Collections.singletonList(Mockito.mock(TopicSink.class)));
112 assertThatCode(() -> clRegisterAckPublisher.send(participantRegisterAckMsg)).doesNotThrowAnyException();
117 void testReceiveParticipantDeregister() throws Exception {
118 final ParticipantDeregister participantDeregisterMsg = new ParticipantDeregister();
119 participantDeregisterMsg.setParticipantId(getParticipantId());
120 participantDeregisterMsg.setTimestamp(Instant.now());
121 participantDeregisterMsg.setParticipantType(getParticipantType());
123 synchronized (lockit) {
124 ParticipantDeregisterListener participantDeregisterListener =
125 new ParticipantDeregisterListener(supervisionHandler);
127 () -> participantDeregisterListener.onTopicEvent(INFRA, TOPIC, null, participantDeregisterMsg))
128 .doesNotThrowAnyException();
133 void testSendParticipantDeregisterAck() throws Exception {
134 final ParticipantDeregisterAck participantDeregisterAckMsg = new ParticipantDeregisterAck();
135 participantDeregisterAckMsg.setMessage("ParticipantDeregisterAck message");
136 participantDeregisterAckMsg.setResponseTo(UUID.randomUUID());
137 participantDeregisterAckMsg.setResult(true);
139 synchronized (lockit) {
140 ParticipantDeregisterAckPublisher clDeregisterAckPublisher = new ParticipantDeregisterAckPublisher();
141 clDeregisterAckPublisher.active(Collections.singletonList(Mockito.mock(TopicSink.class)));
142 assertThatCode(() -> clDeregisterAckPublisher.send(participantDeregisterAckMsg)).doesNotThrowAnyException();
147 void testReceiveParticipantUpdateAckMessage() throws Exception {
148 final ParticipantUpdateAck participantUpdateAckMsg = new ParticipantUpdateAck();
149 participantUpdateAckMsg.setMessage("ParticipantUpdateAck message");
150 participantUpdateAckMsg.setResponseTo(UUID.randomUUID());
151 participantUpdateAckMsg.setResult(true);
152 participantUpdateAckMsg.setParticipantId(getParticipantId());
153 participantUpdateAckMsg.setParticipantType(getParticipantType());
155 synchronized (lockit) {
156 ParticipantUpdateAckListener participantUpdateAckListener =
157 new ParticipantUpdateAckListener(supervisionHandler);
158 assertThatCode(() -> participantUpdateAckListener.onTopicEvent(INFRA, TOPIC, null, participantUpdateAckMsg))
159 .doesNotThrowAnyException();
164 void testSendControlLoopStateChangePublisherNotActive() {
165 var publisher = new ControlLoopStateChangePublisher();
166 assertThatThrownBy(() -> publisher.send(getControlLoop(), 0)).hasMessage(NOT_ACTIVE);
170 void testSendControlLoopStateChangePublisher() {
171 var publisher = new ControlLoopStateChangePublisher();
172 var topicSink = mock(TopicSink.class);
173 publisher.active(List.of(topicSink));
174 publisher.send(getControlLoop(), 0);
175 verify(topicSink).send(anyString());
178 private ControlLoop getControlLoop() {
179 var controlLoop = new ControlLoop();
180 controlLoop.setName("NAME");
181 controlLoop.setVersion("0.0.1");
182 controlLoop.setState(ControlLoopState.UNINITIALISED);
186 private ToscaConceptIdentifier getParticipantId() {
187 return new ToscaConceptIdentifier("org.onap.PM_Policy", "1.0.0");
190 private ToscaConceptIdentifier getParticipantType() {
191 return new ToscaConceptIdentifier("org.onap.policy.controlloop.PolicyControlLoopParticipant", "2.3.1");