use of com.adaptris.core.AdaptrisMessage in project interlok by adaptris.
the class MessageMetricsInterceptorTest method testProduceAfterNewTimeSlice.
@Test
public void testProduceAfterNewTimeSlice() throws Exception {
ProducingStatisticManager producingStatisticManager = new ProducingStatisticManager();
producingStatisticManager.setMarshaller(mockMarshaller);
producingStatisticManager.setProducer(mockStandaloneProducer);
metricsInterceptor.setStatisticManager(producingStatisticManager);
LifecycleHelper.init(metricsInterceptor);
LifecycleHelper.start(metricsInterceptor);
AdaptrisMessage message = DefaultMessageFactory.getDefaultInstance().newMessage();
// A minus time will expire the time slice immediately after the first message
metricsInterceptor.setTimesliceDuration(new TimeInterval(-1L, TimeUnit.SECONDS));
assertEquals(0, metricsInterceptor.getStats().size());
submitMessage(message);
assertEquals(1, metricsInterceptor.getStats().size());
submitMessage(message);
verify(mockMarshaller).marshal(any());
verify(mockStandaloneProducer).produce(any());
}
use of com.adaptris.core.AdaptrisMessage in project interlok by adaptris.
the class MetadataTotalsInterceptorTest method testNoProduceBeforeNewTimeSlice.
@Test
public void testNoProduceBeforeNewTimeSlice() throws Exception {
ProducingStatisticManager producingStatisticManager = new ProducingStatisticManager();
producingStatisticManager.setMarshaller(mockMarshaller);
producingStatisticManager.setProducer(mockStandaloneProducer);
metricsInterceptor.setStatisticManager(producingStatisticManager);
LifecycleHelper.init(metricsInterceptor);
LifecycleHelper.start(metricsInterceptor);
AdaptrisMessage message = DefaultMessageFactory.getDefaultInstance().newMessage();
// A minus time will expire the time slice immediately after the first message
metricsInterceptor.setTimesliceDuration(new TimeInterval(-1L, TimeUnit.SECONDS));
assertEquals(0, metricsInterceptor.getStats().size());
submitMessage(message);
assertEquals(1, metricsInterceptor.getStats().size());
verify(mockMarshaller, times(0)).marshal(any());
verify(mockStandaloneProducer, times(0)).produce(any());
}
use of com.adaptris.core.AdaptrisMessage in project interlok by adaptris.
the class SlowMessageNotificationTest method testNotification_SentAsPartOfCleanup.
@Test
public void testNotification_SentAsPartOfCleanup() throws Exception {
SlowMessageNotification notif = new SlowMessageNotification(getName(), new TimeInterval(100L, TimeUnit.MILLISECONDS), new TimeInterval(200L, TimeUnit.MILLISECONDS));
StandardWorkflow workflow = createWorkflow(getName() + "_Workflow", notif);
workflow.getServiceCollection().add(new WaitService(new TimeInterval(500L, TimeUnit.MILLISECONDS)));
Adapter adapter = createAdapter(getName(), workflow);
List<BaseComponentMBean> mBeans = createJmxManagers(adapter);
BaseComponentMBean notifier = getFirstImpl(mBeans, InterceptorNotificationMBean.class);
assertNotNull(notifier);
ObjectName notifObjName = notifier.createObjectName();
SimpleNotificationListener listener = new SimpleNotificationListener();
try {
start(adapter);
register(mBeans);
mBeanServer.addNotificationListener(notifObjName, listener, null, null);
AdaptrisMessage msg = AdaptrisMessageFactory.getDefaultInstance().newMessage();
workflow.onAdaptrisMessage(msg);
listener.waitForMessages(1);
assertEquals(1, listener.getNotifications().size());
Notification notification = listener.getNotifications().get(0);
Properties userData = (Properties) notification.getUserData();
assertEquals(msg.getUniqueId(), userData.getProperty(SlowMessageNotification.KEY_MESSAGE_ID));
assertEquals("-1", userData.getProperty(SlowMessageNotification.KEY_MESSAGE_DURATION));
assertEquals("-1", userData.getProperty(SlowMessageNotification.KEY_MESSAGE_END));
assertEquals("false", userData.getProperty(SlowMessageNotification.KEY_MESSAGE_SUCCESS));
} finally {
stop(adapter);
}
}
use of com.adaptris.core.AdaptrisMessage in project interlok by adaptris.
the class SlowMessageNotificationTest method testNotification_SlowMessage_Failure.
@Test
public void testNotification_SlowMessage_Failure() throws Exception {
SlowMessageNotification notif = new SlowMessageNotification(getName(), new TimeInterval(100L, TimeUnit.MILLISECONDS));
StandardWorkflow workflow = createWorkflow(getName() + "_Workflow", notif);
workflow.getServiceCollection().add(new WaitService(new TimeInterval(500L, TimeUnit.MILLISECONDS)));
workflow.getServiceCollection().add(new AlwaysFailService());
Adapter adapter = createAdapter(getName(), workflow);
List<BaseComponentMBean> mBeans = createJmxManagers(adapter);
BaseComponentMBean notifier = getFirstImpl(mBeans, InterceptorNotificationMBean.class);
assertNotNull(notifier);
ObjectName notifObjName = notifier.createObjectName();
SimpleNotificationListener listener = new SimpleNotificationListener();
try {
start(adapter);
register(mBeans);
mBeanServer.addNotificationListener(notifObjName, listener, null, null);
AdaptrisMessage msg = AdaptrisMessageFactory.getDefaultInstance().newMessage();
workflow.onAdaptrisMessage(msg);
listener.waitForMessages(1);
assertEquals(1, listener.getNotifications().size());
Notification notification = listener.getNotifications().get(0);
Properties userData = (Properties) notification.getUserData();
assertEquals(msg.getUniqueId(), userData.getProperty(SlowMessageNotification.KEY_MESSAGE_ID));
assertEquals("false", userData.getProperty(SlowMessageNotification.KEY_MESSAGE_SUCCESS));
} finally {
stop(adapter);
}
}
use of com.adaptris.core.AdaptrisMessage in project interlok by adaptris.
the class PooledConnectionHelper method executeTest.
public static void executeTest(List<Service> serviceList, final int iterations, final MessageCreator creator) throws Exception {
MyExceptionHandler handler = new MyExceptionHandler();
List<Thread> threads = new ArrayList<>();
for (final Service s : serviceList) {
Thread t = new Thread(new Runnable() {
@Override
public void run() {
try {
for (int j = 0; j < iterations; j++) {
final AdaptrisMessage msg = creator.createMsgForPooledConnectionTest();
s.doService(msg);
TimeUnit.MILLISECONDS.sleep(DEFAULT_PAUSE.toMilliseconds());
}
} catch (Exception e) {
Thread.currentThread().getUncaughtExceptionHandler().uncaughtException(Thread.currentThread(), e);
}
}
});
t.setUncaughtExceptionHandler(handler);
threads.add(t);
t.start();
}
for (Thread t : threads) {
if (t.isAlive())
t.join();
}
if (handler.hasError()) {
throw handler.lastCaughtException();
}
}
Aggregations