use of com.adaptris.core.runtime.BaseComponentMBean 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.runtime.BaseComponentMBean in project interlok by adaptris.
the class MessageCountNotificationTest method testNotification_BelowThreshold.
@Test
public void testNotification_BelowThreshold() throws Exception {
MessageCountNotification notif = new MessageCountNotification(getName(), new TimeInterval(200L, TimeUnit.MILLISECONDS));
notif.setMessageCount(2);
StandardWorkflow workflow = createWorkflow(getName() + "_Workflow", notif);
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("Hello World");
submitWithDelay(msg, workflow, 6, 5);
LifecycleHelper.waitQuietly(200);
submitWithDelay(msg, workflow, 1, 0);
LifecycleHelper.waitQuietly(200);
submitWithDelay(msg, workflow, 1, 0);
LifecycleHelper.waitQuietly(200);
submitWithDelay(msg, workflow, 1, 0);
listener.waitForMessages(3);
assertEquals(3, listener.getNotifications().size());
Notification n1 = listener.getNotifications().get(0);
Notification n2 = listener.getNotifications().get(1);
assertTrue(n1.getMessage().startsWith(MessageCountNotification.NOTIF_MESSAGE_ABOVE_THRESHOLD));
assertTrue(n2.getMessage().startsWith(MessageCountNotification.NOTIF_MESSAGE_BELOW_THRESHOLD));
} finally {
stop(adapter);
}
}
use of com.adaptris.core.runtime.BaseComponentMBean in project interlok by adaptris.
the class MessageCountNotificationTest method testNotification_AboveThreshold.
@Test
public void testNotification_AboveThreshold() throws Exception {
MessageCountNotification notif = new MessageCountNotification(getName(), new TimeInterval(200L, TimeUnit.MILLISECONDS));
notif.setMessageCount(1);
StandardWorkflow workflow = createWorkflow(getName() + "_Workflow", notif);
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("Hello World");
submitWithDelay(msg, workflow, 6, 5);
LifecycleHelper.waitQuietly(200);
submitWithDelay(msg, workflow, 1, 5);
listener.waitForMessages(1);
assertEquals(1, listener.getNotifications().size());
Notification notification = listener.getNotifications().get(0);
assertTrue(notification.getMessage().startsWith(MessageCountNotification.NOTIF_MESSAGE_ABOVE_THRESHOLD));
} finally {
stop(adapter);
}
}
use of com.adaptris.core.runtime.BaseComponentMBean in project interlok by adaptris.
the class MessageCountNotificationTest method testNotification_AboveThreshold_MaxExceeded.
@Test
public void testNotification_AboveThreshold_MaxExceeded() throws Exception {
MessageCountNotification notif = new MessageCountNotification(getName(), new TimeInterval(200L, TimeUnit.MILLISECONDS));
notif.setMessageCount(1);
notif.setMaxNotifications(1);
StandardWorkflow workflow = createWorkflow(getName() + "_Workflow", notif);
Adapter adapter = createAdapter(getName(), workflow);
List<BaseComponentMBean> mBeans = createJmxManagers(adapter);
BaseComponentMBean notifier = getFirstImpl(mBeans, InterceptorNotificationMBean.class);
assertNotNull(notifier);
ObjectName notifObjName = notifier.createObjectName();
System.err.println(notifObjName);
SimpleNotificationListener listener = new SimpleNotificationListener();
try {
start(adapter);
register(mBeans);
mBeanServer.addNotificationListener(notifObjName, listener, null, null);
AdaptrisMessage msg = AdaptrisMessageFactory.getDefaultInstance().newMessage("Hello World");
submitWithDelay(msg, workflow, 10, 5);
LifecycleHelper.waitQuietly(200);
submitWithDelay(msg, workflow, 6, 5);
LifecycleHelper.waitQuietly(200);
submitWithDelay(msg, workflow, 1, 0);
listener.waitForMessages(1);
assertEquals(1, listener.getNotifications().size());
Notification notification = listener.getNotifications().get(0);
assertTrue(notification.getMessage().startsWith(MessageCountNotification.NOTIF_MESSAGE_ABOVE_THRESHOLD));
} finally {
stop(adapter);
}
}
use of com.adaptris.core.runtime.BaseComponentMBean in project interlok by adaptris.
the class MessageThresholdNotificationTest method testNotification_SizeThresholdExceeded.
@Test
public void testNotification_SizeThresholdExceeded() throws Exception {
MessageThresholdNotification notif = new MessageThresholdNotification(getName());
notif.setSizeThreshold(1L);
StandardWorkflow workflow = createWorkflow(getName() + "_Workflow", notif);
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("Hello World");
workflow.onAdaptrisMessage(msg);
listener.waitForMessages(1);
assertEquals(1, listener.getNotifications().size());
Notification notification = listener.getNotifications().get(0);
Properties userData = (Properties) notification.getUserData();
assertEquals("11", userData.getProperty(MessageThresholdNotification.KEY_MESSAGE_SIZE));
assertEquals("1", userData.getProperty(MessageThresholdNotification.KEY_MESSAGE_COUNT));
assertEquals("0", userData.getProperty(MessageThresholdNotification.KEY_MESSAGE_ERROR));
} finally {
stop(adapter);
}
}
Aggregations