use of com.adaptris.core.StandardWorkflow in project interlok by adaptris.
the class WorkflowManagerTest method testConstructor_WithInterceptor_RuntimeInfoFactoryRegistered.
@Test
public void testConstructor_WithInterceptor_RuntimeInfoFactoryRegistered() throws Exception {
String adapterName = this.getClass().getSimpleName() + "." + getName();
Adapter adapter = createAdapter(adapterName);
AdapterManager adapterManager = new AdapterManager(adapter);
Channel channel = createChannel("c1");
ChannelManager channelManager = new ChannelManager(channel, adapterManager);
StandardWorkflow workflow = createWorkflow("w1");
workflow.setDisableDefaultMessageCount(true);
workflow.getInterceptors().add(new MessageMetricsInterceptor());
WorkflowManager workflowManager = new WorkflowManager(workflow, channelManager);
assertEquals(1, workflowManager.getChildRuntimeInfoComponents().size());
}
use of com.adaptris.core.StandardWorkflow in project interlok by adaptris.
the class WorkflowManagerTest method testMessageCounter_Disabled.
@Test
public void testMessageCounter_Disabled() throws Exception {
String adapterName = this.getClass().getSimpleName() + "." + getName();
Adapter adapter = createAdapter(adapterName);
AdapterManager adapterManager = new AdapterManager(adapter);
Channel channel = createChannel("c1");
ChannelManager channelManager = new ChannelManager(channel, adapterManager);
StandardWorkflow workflow = createWorkflow("w1");
workflow.setDisableDefaultMessageCount(true);
new WorkflowManager(workflow, channelManager);
assertEquals(0, workflow.getInterceptors().size());
}
use of com.adaptris.core.StandardWorkflow in project interlok by adaptris.
the class StandardHttpProducerTest method testRequest_Get_ExpectHeader.
// HttpURLConnection doesn't support the Expect: 102-Processing
// So this should throw a Produce Exception
@Test
public void testRequest_Get_ExpectHeader() throws Exception {
MockMessageProducer mock = new MockMessageProducer();
HttpConnection jc = HttpHelper.createConnection();
JettyMessageConsumer mc = createConsumer(HttpHelper.URL_TO_POST_TO);
mc.setSendProcessingInterval(new TimeInterval(100L, TimeUnit.MILLISECONDS));
ServiceList services = new ServiceList();
services.add(new PayloadFromTemplateService().withTemplate(TEXT));
services.add(new WaitService(new TimeInterval(2L, TimeUnit.SECONDS)));
services.add(new StandaloneProducer(new StandardResponseProducer(HttpStatus.OK_200)));
Channel c = createChannel(jc, createWorkflow(mc, mock, services));
StandardWorkflow workflow = (StandardWorkflow) c.getWorkflowList().get(0);
workflow.getServiceCollection().add(new StandaloneProducer(new StandardResponseProducer(HttpStatus.OK_200)));
StandardHttpProducer stdHttp = new StandardHttpProducer().withURL(HttpHelper.createURL(c));
;
stdHttp.setMethodProvider(new ConfiguredRequestMethodProvider(RequestMethodProvider.RequestMethod.GET));
stdHttp.setRequestHeaderProvider(new ConfiguredRequestHeaders().withHeaders(new KeyValuePair(HttpConstants.EXPECT, "102-Processing")));
StandaloneRequestor producer = new StandaloneRequestor(stdHttp);
AdaptrisMessage msg = new DefaultMessageFactory().newMessage(ALT_TEXT);
try {
start(c);
start(producer);
producer.doService(msg);
fail();
} catch (ProduceException | ServiceException e) {
assertTrue(e.getMessage().contains("Failed to send payload, got 102"));
} finally {
stop(c);
stop(producer);
}
}
use of com.adaptris.core.StandardWorkflow in project interlok by adaptris.
the class StandardHttpProducerTest method testRequest_Post_ZeroBytes_ReplyToMetadata.
@Test
public void testRequest_Post_ZeroBytes_ReplyToMetadata() throws Exception {
MockMessageProducer mock = new MockMessageProducer();
HttpConnection jc = HttpHelper.createConnection();
JettyMessageConsumer mc = createConsumer(HttpHelper.URL_TO_POST_TO);
Channel c = createChannel(jc, createWorkflow(mc, mock, new ServiceList()));
StandardWorkflow workflow = (StandardWorkflow) c.getWorkflowList().get(0);
PayloadFromTemplateService pms = new PayloadFromTemplateService().withTemplate(TEXT);
workflow.getServiceCollection().add(pms);
workflow.getServiceCollection().add(new StandaloneProducer(new StandardResponseProducer(HttpStatus.OK_200)));
StandardHttpProducer stdHttp = new StandardHttpProducer().withURL(HttpHelper.createURL(c));
stdHttp.setMethodProvider(new ConfiguredRequestMethodProvider(RequestMethodProvider.RequestMethod.POST));
stdHttp.setResponseBody(new MetadataStreamOutputParameter(getName()));
StandaloneRequestor producer = new StandaloneRequestor(stdHttp);
AdaptrisMessage msg = new DefaultMessageFactory().newMessage();
try {
start(c);
start(producer);
producer.doService(msg);
waitForMessages(mock, 1);
} finally {
HttpHelper.stopChannelAndRelease(c);
stop(producer);
}
assertEquals(1, mock.messageCount());
AdaptrisMessage m2 = mock.getMessages().get(0);
assertNotSame(TEXT, msg.getContent());
assertEquals(0, msg.getSize());
assertTrue(msg.headersContainsKey(getName()));
assertEquals(TEXT, msg.getMetadataValue(getName()));
}
use of com.adaptris.core.StandardWorkflow in project interlok by adaptris.
the class StandardHttpProducerTest method testRequest_TraceMethod_AlwaysSendPayload.
@Test
public void testRequest_TraceMethod_AlwaysSendPayload() throws Exception {
MockMessageProducer mock = new MockMessageProducer();
HttpConnection jc = HttpHelper.createConnection();
JettyMessageConsumer mc = createConsumer(HttpHelper.URL_TO_POST_TO);
Channel c = createChannel(jc, createWorkflow(mc, mock, new ServiceList()));
StandardWorkflow workflow = (StandardWorkflow) c.getWorkflowList().get(0);
workflow.getServiceCollection().add(new StandaloneProducer(new StandardResponseProducer(HttpStatus.OK_200)));
StandardHttpProducer stdHttp = new StandardHttpProducer().withURL(HttpHelper.createURL(c));
;
stdHttp.setMethodProvider(new ConfiguredRequestMethodProvider(RequestMethodProvider.RequestMethod.TRACE));
stdHttp.setAlwaysSendPayload(true);
StandaloneRequestor producer = new StandaloneRequestor(stdHttp);
AdaptrisMessage msg = new DefaultMessageFactory().newMessage(ALT_TEXT);
try {
start(c);
start(producer);
producer.doService(msg);
waitForMessages(mock, 1);
} finally {
stop(c);
stop(producer);
}
assertEquals(1, mock.messageCount());
AdaptrisMessage m2 = mock.getMessages().get(0);
assertEquals("TRACE", m2.getMetadataValue(CoreConstants.HTTP_METHOD));
assertEquals(0, m2.getSize());
}
Aggregations