2  * ============LICENSE_START=======================================================
 
   3  *  Copyright (C) 2019 Nordix Foundation.
 
   4  *  Modifications Copyright (C) 2019 Nordix Foundation.
 
   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.apex.testsuites.integration.uservice.executionproperties;
 
  25 import java.io.FileInputStream;
 
  26 import java.io.IOException;
 
  27 import java.util.EnumMap;
 
  29 import java.util.Properties;
 
  31 import org.onap.policy.apex.service.engine.event.ApexEventConsumer;
 
  32 import org.onap.policy.apex.service.engine.event.ApexEventException;
 
  33 import org.onap.policy.apex.service.engine.event.ApexEventReceiver;
 
  34 import org.onap.policy.apex.service.engine.event.ApexEventRuntimeException;
 
  35 import org.onap.policy.apex.service.engine.event.PeeredReference;
 
  36 import org.onap.policy.apex.service.parameters.eventhandler.EventHandlerParameters;
 
  37 import org.onap.policy.apex.service.parameters.eventhandler.EventHandlerPeeredMode;
 
  38 import org.slf4j.Logger;
 
  39 import org.slf4j.LoggerFactory;
 
  42  * Dummy Apex event consumer for testing event properties.
 
  44  * @author Liam Fallon (liam.fallon@est.tech)
 
  46 public class DummyApexEventConsumer implements ApexEventConsumer {
 
  47     // Get a reference to the logger
 
  48     private static final Logger LOGGER = LoggerFactory.getLogger(DummyApexEventConsumer.class);
 
  50     // The event receiver that will receive events from this consumer
 
  51     private ApexEventReceiver eventReceiver;
 
  53     // The name for this consumer
 
  54     private String name = null;
 
  56     // The peer references for this event handler
 
  57     private Map<EventHandlerPeeredMode, PeeredReference> peerReferenceMap = new EnumMap<>(EventHandlerPeeredMode.class);
 
  59     private DummyCarrierTechnologyParameters dummyConsumerProperties = null;
 
  62     public void init(final String consumerName, final EventHandlerParameters consumerParameters,
 
  63                     final ApexEventReceiver incomingEventReceiver) throws ApexEventException {
 
  64         this.eventReceiver = incomingEventReceiver;
 
  65         this.name = consumerName;
 
  67         // Check and get the properties
 
  68         if (!(consumerParameters.getCarrierTechnologyParameters() instanceof DummyCarrierTechnologyParameters)) {
 
  69             String message = "specified consumer properties of type \""
 
  70                             + consumerParameters.getCarrierTechnologyParameters().getClass().getName()
 
  71                             + "\" are not applicable to a dummy consumer";
 
  73             throw new ApexEventException(message);
 
  76         dummyConsumerProperties = (DummyCarrierTechnologyParameters) consumerParameters
 
  77                         .getCarrierTechnologyParameters();
 
  82         new Thread(new RunTestEventSender()).start();
 
  89     public String getName() {
 
  97     public PeeredReference getPeeredReference(final EventHandlerPeeredMode peeredMode) {
 
  98         return peerReferenceMap.get(peeredMode);
 
 105     public void setPeeredReference(final EventHandlerPeeredMode peeredMode, final PeeredReference peeredReference) {
 
 106         peerReferenceMap.put(peeredMode, peeredReference);
 
 113     private class RunTestEventSender implements Runnable {
 
 116             Properties executionProperties = new Properties();
 
 118                 executionProperties.load(new FileInputStream(new File(dummyConsumerProperties.getPropertyFileName())));
 
 119             } catch (IOException e1) {
 
 120                 String message = "reading of executor properties for testing failed from file: "
 
 121                                 + dummyConsumerProperties.getPropertyFileName();
 
 122                 LOGGER.warn(message);
 
 123                 throw new ApexEventRuntimeException(message);
 
 126             RunTestEvent event = new RunTestEvent();
 
 127             event.setTestToRun(dummyConsumerProperties.getTestToRun());
 
 129                 eventReceiver.receiveEvent(executionProperties, event.toJson());
 
 130             } catch (Exception e) {
 
 131                 String message = "event processing for executor properties testing failed: " + e.getMessage();
 
 132                 LOGGER.warn(message, e);
 
 133                 throw new ApexEventRuntimeException(message, e);