db31d0f01f7faa6ee9f7bffa132ddb1e20aa5a7f
[policy/clamp.git] /
1 /*-
2  * ============LICENSE_START=======================================================
3  * Copyright (C) 2021-2024 Nordix Foundation.
4  * ================================================================================
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  *      http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  * SPDX-License-Identifier: Apache-2.0
18  * ============LICENSE_END=========================================================
19  */
20
21 package org.onap.policy.clamp.models.acm.messages.kafka.participant;
22
23 import static org.assertj.core.api.Assertions.assertThatThrownBy;
24 import static org.junit.jupiter.api.Assertions.assertEquals;
25 import static org.junit.jupiter.api.Assertions.assertFalse;
26 import static org.junit.jupiter.api.Assertions.assertTrue;
27 import static org.onap.policy.clamp.models.acm.messages.kafka.participant.ParticipantMessageUtils.assertSerializable;
28
29 import java.time.Instant;
30 import java.util.UUID;
31 import org.junit.jupiter.api.Test;
32 import org.onap.policy.clamp.models.acm.utils.CommonTestData;
33 import org.onap.policy.common.utils.coder.CoderException;
34
35 class ParticipantMessageTest {
36     private ParticipantMessage message;
37
38     @Test
39     void testCopyConstructor() throws CoderException {
40         assertThatThrownBy(() -> new ParticipantMessage((ParticipantMessage) null))
41                 .isInstanceOf(NullPointerException.class);
42
43         // verify with null values
44         message = new ParticipantMessage(ParticipantMessageType.PARTICIPANT_STATE_CHANGE);
45         var newmsg = new ParticipantMessage(message);
46         newmsg.setMessageId(message.getMessageId());
47         newmsg.setTimestamp(message.getTimestamp());
48         assertEquals(message.toString(), newmsg.toString());
49
50         // verify with all values
51         message = makeMessage();
52         newmsg = new ParticipantMessage(message);
53         newmsg.setMessageId(message.getMessageId());
54         newmsg.setTimestamp(message.getTimestamp());
55         assertEquals(message.toString(), newmsg.toString());
56
57         assertSerializable(message, ParticipantMessage.class);
58     }
59
60     @Test
61     void testAppliesTo_NullParticipantId() {
62         message = makeMessage();
63
64         assertThatThrownBy(() -> message.appliesTo(UUID.randomUUID(), null)).isInstanceOf(NullPointerException.class);
65         assertThatThrownBy(() -> message.appliesTo(null, UUID.randomUUID())).isInstanceOf(NullPointerException.class);
66     }
67
68     @Test
69     void testAppliesTo_ParticipantIdMatches() {
70         message = makeMessage();
71
72         // ParticipantId matches
73         assertTrue(message.appliesTo(CommonTestData.getParticipantId(), CommonTestData.getReplicaId()));
74         assertFalse(message.appliesTo(CommonTestData.getRndParticipantId(), CommonTestData.getReplicaId()));
75     }
76
77     @Test
78     void testAppliesTo_ParticipantIdNoMatch() {
79         message = makeMessage();
80         assertFalse(message.appliesTo(CommonTestData.getRndParticipantId(), CommonTestData.getReplicaId()));
81         assertTrue(message.appliesTo(CommonTestData.getParticipantId(), CommonTestData.getReplicaId()));
82     }
83
84     private ParticipantMessage makeMessage() {
85         var msg = new ParticipantMessage(ParticipantMessageType.PARTICIPANT_STATE_CHANGE);
86
87         msg.setParticipantId(CommonTestData.getParticipantId());
88         msg.setMessageId(UUID.randomUUID());
89         msg.setTimestamp(Instant.ofEpochMilli(3000));
90
91         return msg;
92     }
93 }