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
9 * http://www.apache.org/licenses/LICENSE-2.0
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.
17 * SPDX-License-Identifier: Apache-2.0
18 * ============LICENSE_END=========================================================
21 package org.onap.cps.ncmp.api.impl.event.lcm
23 import org.onap.ncmp.cmhandle.event.lcm.LcmEvent
24 import org.springframework.kafka.KafkaException
25 import spock.lang.Specification
27 class LcmEventsServiceSpec extends Specification {
29 def mockLcmEventsPublisher = Mock(LcmEventsPublisher)
31 def objectUnderTest = new LcmEventsService(mockLcmEventsPublisher)
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
46 'disabled' | false || 0
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'