use of com.adaptris.core.services.metadata.PayloadFromTemplateService in project interlok by adaptris.
the class LargeMessageWorkflowTest method testRuntimeException.
@Override
@Test
public void testRuntimeException() throws Exception {
MockMessageProducer producer = new MockMessageProducer() {
@Override
protected void doProduce(AdaptrisMessage msg, String endpoint) throws ProduceException {
throw new RuntimeException();
}
};
;
MockMessageProducer meh = 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) }));
try {
LargeMessageWorkflow workflow = (LargeMessageWorkflow) channel.getWorkflowList().get(0);
channel.setMessageErrorHandler(new StandardProcessingExceptionHandler(new ServiceList(new ArrayList<Service>(Arrays.asList(new Service[] { new StandaloneProducer(meh) })))));
channel.prepare();
AdaptrisMessage msg = AdaptrisMessageFactory.getDefaultInstance().newMessage(PAYLOAD_1);
start(channel);
workflow.onAdaptrisMessage(msg);
assertEquals("Make none produced", 0, producer.getMessages().size());
assertEquals(1, meh.getMessages().size());
for (AdaptrisMessage m : meh.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.PayloadFromTemplateService in project interlok by adaptris.
the class StandardWorkflowTest 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);
StandardWorkflow workflow = (StandardWorkflow) 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.containsKey(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.PayloadFromTemplateService in project interlok by adaptris.
the class StandardWorkflowTest method testObtainWorkflowIdWithNoChannelId.
@Test
public void testObtainWorkflowIdWithNoChannelId() 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) }));
StandardWorkflow workflow = (StandardWorkflow) channel.getWorkflowList().get(0);
channel.setUniqueId(null);
channel.prepare();
StringBuffer result = new StringBuffer(workflow.getConsumer().getClass().getName());
result.append("@");
result.append(workflow.getProducer().getClass().getName());
result.append("@");
// As part of INTERLOK-3329 Destinations aren't mandatory, which means at this point we
// will just have a random-char-sequence
// result.append(workflow.getConsumer().getDestination().getDestination());
// result.append("-null");
// result.append("-null");
// assertEquals(result.toString(), workflow.obtainWorkflowId());
assertTrue(workflow.obtainWorkflowId().startsWith(result.toString()));
}
use of com.adaptris.core.services.metadata.PayloadFromTemplateService in project interlok by adaptris.
the class StandardWorkflowTest method testObtainWorkflowIdWithNoUniqueId.
@Test
public void testObtainWorkflowIdWithNoUniqueId() 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(null);
channel.prepare();
assertTrue(workflow.obtainWorkflowId().endsWith("Channel"));
}
use of com.adaptris.core.services.metadata.PayloadFromTemplateService in project interlok by adaptris.
the class StandardWorkflowTest method testHandleChannelUnavailableForever.
@Test
public void testHandleChannelUnavailableForever() 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) }));
MockMessageProducer meh = new MockMessageProducer();
try {
StandardWorkflow workflow = (StandardWorkflow) channel.getWorkflowList().get(0);
workflow.setMessageErrorHandler(new StandardProcessingExceptionHandler(new ServiceList(new ArrayList<Service>(Arrays.asList(new Service[] { new StandaloneProducer(meh) })))));
workflow.setChannelUnavailableWaitInterval(new TimeInterval(100L, TimeUnit.MILLISECONDS));
AdaptrisMessage msg = AdaptrisMessageFactory.getDefaultInstance().newMessage(PAYLOAD_1);
channel.prepare();
start(channel);
channel.toggleAvailability(false);
workflow.onAdaptrisMessage(msg);
assertEquals("Make none produced", 0, producer.getMessages().size());
assertEquals(1, meh.getMessages().size());
for (Iterator i = meh.getMessages().iterator(); i.hasNext(); ) {
AdaptrisMessage m = (AdaptrisMessage) i.next();
assertEquals(PAYLOAD_1, m.getContent());
assertFalse("Does not contains correct metadata key", m.containsKey(METADATA_KEY));
}
} finally {
stop(channel);
}
}
Aggregations