ef399e1c652ca544e701e8249aec7aba4af9fbaa
[cps.git] / cps-ncmp-service / src / test / groovy / org / onap / cps / ncmp / api / impl / event / lcm / LcmEventsServiceSpec.groovy
1 /*
2  * ============LICENSE_START=======================================================
3  * Copyright (C) 2022 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.cps.ncmp.api.impl.event.lcm
22
23 import org.onap.ncmp.cmhandle.event.lcm.LcmEvent
24 import org.springframework.kafka.KafkaException
25 import spock.lang.Specification
26
27 class LcmEventsServiceSpec extends Specification {
28
29     def mockLcmEventsPublisher = Mock(LcmEventsPublisher)
30
31     def objectUnderTest = new LcmEventsService(mockLcmEventsPublisher)
32
33     def 'Create and Publish lcm event where events are #scenario'() {
34         given: 'a cm handle id and Lcm Event'
35             def cmHandleId = 'test-cm-handle-id'
36             def lcmEvent = new LcmEvent(eventId: UUID.randomUUID().toString(), eventCorrelationId: cmHandleId)
37         and: 'notificationsEnabled is #notificationsEnabled and it will be true as default'
38             objectUnderTest.notificationsEnabled = notificationsEnabled
39         when: 'service is called to publish lcm event'
40             objectUnderTest.publishLcmEvent('test-cm-handle-id', lcmEvent)
41         then: 'publisher is called #expectedTimesMethodCalled times'
42             expectedTimesMethodCalled * mockLcmEventsPublisher.publishEvent(_, cmHandleId, lcmEvent)
43         where: 'the following values are used'
44             scenario   | notificationsEnabled || expectedTimesMethodCalled
45             'enabled'  | true                 || 1
46             'disabled' | false                || 0
47     }
48
49     def 'Unable to send message'(){
50         given: 'a cm handle id and Lcm Event and notification enabled'
51             def cmHandleId = 'test-cm-handle-id'
52             def lcmEvent = new LcmEvent(eventId: UUID.randomUUID().toString(), eventCorrelationId: cmHandleId)
53             objectUnderTest.notificationsEnabled = true
54         when: 'publisher set to throw an exception'
55             mockLcmEventsPublisher.publishEvent(*_) >> { throw new KafkaException('publishing failed')}
56         and: 'an event is publised'
57             objectUnderTest.publishLcmEvent(cmHandleId, lcmEvent)
58         then: 'the exception is just logged and not bubbled up'
59             noExceptionThrown()
60     }
61
62 }