use of com.adaptris.core.services.metadata.AddMetadataService in project interlok by adaptris.
the class ThreadContextWorkflowTest method testOnMessageWithSendEvents.
@Test
public void testOnMessageWithSendEvents() throws Exception {
MockMessageProducer producer = new MockMessageProducer();
MockMessageProducer eventProd = new MockMessageProducer();
DefaultEventHandler evtHandler = new DefaultEventHandler(eventProd);
MockChannel channel = createChannel(producer, Arrays.asList(new Service[] { new AddMetadataService(Arrays.asList(new MetadataElement[] { new MetadataElement(METADATA_KEY, METADATA_VALUE) })), new PayloadFromTemplateService().withTemplate(PAYLOAD_2) }));
try {
channel.setEventHandler(evtHandler);
ThreadContextWorkflow workflow = (ThreadContextWorkflow) channel.getWorkflowList().get(0);
workflow.setSendEvents(true);
channel.prepare();
AdaptrisMessage msg = AdaptrisMessageFactory.getDefaultInstance().newMessage(PAYLOAD_1);
start(channel);
workflow.onAdaptrisMessage(msg);
assertEquals("Make sure all produced", 1, producer.getMessages().size());
for (Iterator i = producer.getMessages().iterator(); i.hasNext(); ) {
AdaptrisMessage m = (AdaptrisMessage) i.next();
assertEquals(PAYLOAD_2, m.getContent());
assertTrue("Contains correct metadata key", m.headersContainsKey(METADATA_KEY));
assertEquals(METADATA_VALUE, m.getMetadataValue(METADATA_KEY));
}
waitForMessages(eventProd, 1);
assertEquals(1, eventProd.messageCount());
} finally {
stop(channel);
stop(evtHandler);
}
}
use of com.adaptris.core.services.metadata.AddMetadataService in project interlok by adaptris.
the class StandardWorkflowTest method testHandleChannelUnavailable.
@Test
public void testHandleChannelUnavailable() throws Exception {
MockMessageProducer producer = new MockMessageProducer();
final MockChannel channel = createChannel(producer, Arrays.asList(new Service[] { new AddMetadataService(Arrays.asList(new MetadataElement[] { new MetadataElement(METADATA_KEY, METADATA_VALUE) })), new PayloadFromTemplateService().withTemplate(PAYLOAD_2) }));
try {
StandardWorkflow workflow = (StandardWorkflow) channel.getWorkflowList().get(0);
workflow.setChannelUnavailableWaitInterval(new TimeInterval(1200L, TimeUnit.MILLISECONDS));
AdaptrisMessage msg = AdaptrisMessageFactory.getDefaultInstance().newMessage(PAYLOAD_1);
channel.prepare();
start(channel);
channel.toggleAvailability(false);
Timer t = new Timer(true);
t.schedule(new TimerTask() {
@Override
public void run() {
channel.toggleAvailability(true);
}
}, 500);
workflow.onAdaptrisMessage(msg);
assertEquals("Make sure all produced", 1, producer.getMessages().size());
for (Iterator i = producer.getMessages().iterator(); i.hasNext(); ) {
AdaptrisMessage m = (AdaptrisMessage) i.next();
assertEquals(PAYLOAD_2, m.getContent());
assertTrue("Contains correct metadata key", m.containsKey(METADATA_KEY));
assertEquals(METADATA_VALUE, m.getMetadataValue(METADATA_KEY));
}
} finally {
stop(channel);
}
}
use of com.adaptris.core.services.metadata.AddMetadataService in project interlok by adaptris.
the class StandardWorkflowTest method testOnMessageWithInterceptors.
@Test
public void testOnMessageWithInterceptors() throws Exception {
MockWorkflowInterceptor interceptor = new MockWorkflowInterceptor();
MockMessageProducer producer = new MockMessageProducer();
MockChannel channel = createChannel(producer, Arrays.asList(new Service[] { new AddMetadataService(Arrays.asList(new MetadataElement[] { new MetadataElement(METADATA_KEY, METADATA_VALUE) })), new PayloadFromTemplateService().withTemplate(PAYLOAD_2) }));
int count = 10;
try {
StandardWorkflow workflow = (StandardWorkflow) channel.getWorkflowList().get(0);
workflow.addInterceptor(interceptor);
channel.prepare();
start(channel);
for (int i = 0; i < count; i++) {
AdaptrisMessage msg = AdaptrisMessageFactory.getDefaultInstance().newMessage(PAYLOAD_1);
workflow.onAdaptrisMessage(msg);
}
assertEquals("Make sure all produced", count, producer.messageCount());
assertEquals("Make sure all intercepted", count, interceptor.messageCount());
for (AdaptrisMessage m : producer.getMessages()) {
assertEquals(PAYLOAD_2, m.getContent());
assertTrue("Contains correct metadata key", m.containsKey(METADATA_KEY));
assertEquals(METADATA_VALUE, m.getMetadataValue(METADATA_KEY));
}
} finally {
stop(channel);
}
}
use of com.adaptris.core.services.metadata.AddMetadataService in project interlok by adaptris.
the class StandardWorkflowTest method testObtainWorkflowIdWithUniqueId.
@Test
public void testObtainWorkflowIdWithUniqueId() throws Exception {
MockChannel channel = createChannel(new MockMessageProducer(), Arrays.asList(new Service[] { new AddMetadataService(Arrays.asList(new MetadataElement[] { new MetadataElement(METADATA_KEY, METADATA_VALUE) })), new PayloadFromTemplateService().withTemplate(PAYLOAD_2) }));
channel.setUniqueId("Channel");
StandardWorkflow workflow = (StandardWorkflow) channel.getWorkflowList().get(0);
workflow.setUniqueId("Workflow");
channel.prepare();
assertEquals("Workflow@Channel", workflow.obtainWorkflowId());
}
use of com.adaptris.core.services.metadata.AddMetadataService in project interlok by adaptris.
the class StandardWorkflowTest method testOnMessageWithoutEvents.
@Test
public void testOnMessageWithoutEvents() throws Exception {
MockMessageProducer producer = new MockMessageProducer();
MockMessageProducer eventProd = new MockMessageProducer();
DefaultEventHandler evtHandler = new DefaultEventHandler(eventProd);
MockChannel channel = createChannel(producer, Arrays.asList(new Service[] { new AddMetadataService(Arrays.asList(new MetadataElement[] { new MetadataElement(METADATA_KEY, METADATA_VALUE) })), new PayloadFromTemplateService().withTemplate(PAYLOAD_2) }));
try {
channel.setEventHandler(evtHandler);
StandardWorkflow workflow = (StandardWorkflow) channel.getWorkflowList().get(0);
workflow.setSendEvents(false);
channel.prepare();
AdaptrisMessage msg = AdaptrisMessageFactory.getDefaultInstance().newMessage(PAYLOAD_1);
start(channel);
workflow.onAdaptrisMessage(msg);
assertEquals("Make sure all produced", 1, producer.getMessages().size());
for (Iterator i = producer.getMessages().iterator(); i.hasNext(); ) {
AdaptrisMessage m = (AdaptrisMessage) i.next();
assertEquals(PAYLOAD_2, m.getContent());
assertTrue("Contains correct metadata key", m.containsKey(METADATA_KEY));
assertEquals(METADATA_VALUE, m.getMetadataValue(METADATA_KEY));
}
waitForMessages(eventProd, 0);
assertEquals(0, eventProd.messageCount());
} finally {
stop(channel);
stop(evtHandler);
}
}
Aggregations