use of com.adaptris.core.StandardWorkflow in project interlok by adaptris.
the class SlowMessageNotificationTest method testNotification_SlowMessage_Success.
@Test
public void testNotification_SlowMessage_Success() throws Exception {
SlowMessageNotification notif = new SlowMessageNotification(getName(), new TimeInterval(100L, TimeUnit.MILLISECONDS), new TimeInterval(1L, TimeUnit.MINUTES));
StandardWorkflow workflow = createWorkflow(getName() + "_Workflow", notif);
workflow.getServiceCollection().add(new WaitService(new TimeInterval(1L, TimeUnit.SECONDS)));
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("true", userData.getProperty(SlowMessageNotification.KEY_MESSAGE_SUCCESS));
} finally {
stop(adapter);
}
}
use of com.adaptris.core.StandardWorkflow in project interlok by adaptris.
the class MessageNotificationCase method createWorkflow.
protected StandardWorkflow createWorkflow(String uid, WorkflowInterceptor... interceptors) throws CoreException {
StandardWorkflow wf = new StandardWorkflow();
wf.setUniqueId(uid);
for (WorkflowInterceptor wi : interceptors) {
wf.addInterceptor(wi);
}
return wf;
}
use of com.adaptris.core.StandardWorkflow in project interlok by adaptris.
the class FailedMessageRetrierCase method testRegisteredWorkflowIds.
@Test
public void testRegisteredWorkflowIds() throws Exception {
FailedMessageRetrier retrier = create();
StandardWorkflow wf1 = createWorkflow();
StandardWorkflow wf2 = createWorkflow();
retrier.addWorkflow(wf1);
retrier.addWorkflow(wf2);
assertEquals(2, retrier.registeredWorkflowIds().size());
assertTrue(retrier.registeredWorkflowIds().contains(wf1.obtainWorkflowId()));
assertTrue(retrier.registeredWorkflowIds().contains(wf2.obtainWorkflowId()));
}
use of com.adaptris.core.StandardWorkflow in project interlok by adaptris.
the class ExampleErrorHandlerCase method createWorkflow.
protected StandardWorkflow createWorkflow(MockMessageConsumer consumer, ProcessingExceptionHandler errorHandler, Service... services) {
StandardWorkflow workflow = new StandardWorkflow();
workflow.setMessageErrorHandler(errorHandler);
workflow.setConsumer(consumer);
workflow.getServiceCollection().addAll(Arrays.asList(services));
return workflow;
}
use of com.adaptris.core.StandardWorkflow in project interlok by adaptris.
the class DefaultFailedMessageRetrierJmxTest method testMBean_Retry_File.
@Test
public void testMBean_Retry_File() throws Exception {
Adapter adapter = createAdapter(getName());
Channel c = createChannel(getName());
StandardWorkflow wf = createWorkflow(getName());
MockMessageProducer mock = new MockMessageProducer();
wf.setProducer(mock);
c.getWorkflowList().add(wf);
adapter.getChannelList().add(c);
DefaultFailedMessageRetrier retrier = new DefaultFailedMessageRetrier();
adapter.setFailedMessageRetrier(retrier);
AdaptrisMessage msg = AdaptrisMessageFactory.getDefaultInstance().newMessage();
msg.addMetadata(Workflow.WORKFLOW_ID_KEY, getName() + "@" + getName());
File fileToRetry = writeFile(msg, new MimeEncoder());
AdapterManager adapterManager = new AdapterManager(adapter);
try {
adapterManager.registerMBean();
adapterManager.requestStart();
ObjectName retrierObjName = createRetrierObjectName(adapterManager);
DefaultFailedMessageRetrierJmxMBean jmxBean = JMX.newMBeanProxy(mBeanServer, retrierObjName, DefaultFailedMessageRetrierJmxMBean.class);
assertTrue(jmxBean.retryMessage(fileToRetry));
waitForMessages(mock, 1);
assertEquals(1, mock.messageCount());
} finally {
adapterManager.requestClose();
adapterManager.unregisterMBean();
}
}
Aggregations