/*
* Copyright (c) MuleSoft, Inc. All rights reserved. http://www.mulesoft.com
* The software in this package is published under the terms of the CPAL v1.0
* license, a copy of which has been included with this distribution in the
* LICENSE.txt file.
*/
package org.mule.functional.testmodels.services;
import java.util.concurrent.atomic.AtomicInteger;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class TestComponent implements ITestComponent {
public static final String EXCEPTION_MESSAGE = "Test Service fired an Exception";
protected static final Logger logger = LoggerFactory.getLogger(TestComponent.class);
protected AtomicInteger count = new AtomicInteger(0);
public String receive(String message) throws Exception {
logger.info("Received: " + message + " number: " + inc() + " in thread: " + Thread.currentThread().getName());
return "Received: " + message;
}
public String receiveBytes(byte[] message) throws Exception {
return receive(new String(message));
}
public String throwsException(String message) throws Exception {
throw new TestComponentException(EXCEPTION_MESSAGE);
}
protected int inc() {
return count.incrementAndGet();
}
}