我有以下示例路由流,我收到一条jms消息,构建了一个Web服务请求,然后使用Web服务响应来响应JMSReplyTo:
from("{{jms.input.queue}}).routeId("Receive JMS Message")
.to("direct:start");
from("direct:start").routeId("Build & Send Http Request")
.bean(processRequest)
.to("{{http.endpoint}}")
.to("direct:processResponse");
from("direct:processResponse").routeId("Build XML Response")
.convertBodyTo(String.class)
.bean(processResponse);
我已经成功地对流程进行了单元测试,但是现在我想对路径流程进行单元测试。我从第二条路线开始,而不是在测试过程中运行EMS服务器:
camelContext.getRouteDefinition("Build & Send Http Request").adviceWith(camelContext,
new AdviceWithRouteBuilder() {
@Override
public void configure() throws Exception {
interceptSendToEndpoint("http://*")
.skipSendToOriginalEndpoint()
.setBody("Hello");
}
});
@Test
@DirtiesContext
public void RouteFlowTest() throws Exception{
Map<String,Object> jmsHeaders = new HashMap<>();
jmsHeaders.put("Auth","helloWorld");
jmsHeaders.put("JMSReplyTo","sample");
String jmsBody = "Help Me"
incomingJmsRequestMessage.sendBodyAndHeaders("direct:start", jmsBody, jmsHeaders);
}
但是现在如何在执行processResponse bean之后如何断言交换?
还是有一种方法可以从第一个路由进行测试并满足JMSReplyTo,而无需实际运行EMS服务器?
答案 0 :(得分:0)
由于已经在编织路线,因此可以在路线建议中向模拟端点添加传播,例如:
this.weaveAddLast().to("mock:done");
只会在.to("mock:done")
路由的末尾添加一个"Build & Send Http Request"
定义。从给定的问题陈述中,还不清楚.bean(processResponse);
的实际作用。您还可以将此模拟端点传播添加到"Build XML Response"
路由中,在这种情况下,您需要进一步的路由建议定义。
接下来,您可以让骆驼通过
注入模拟端点@EndpointInject(uri = "mock:done")
private MockEndpoint done;
或通过以下方式在测试中手动定义它:
MockEndpoint done = camelContext.getEndpoint("mock:done", MockEndpoint.class);
此模拟端点可用于define certain expectations,以便您希望该端点收到一条消息
done.expectedMessageCount(1);
...
// invoke your route here
template.sendBody(...);
...
done.assertIsSatisfied();
您还可以直接通过以下方向访问此端点接收的交换,并对其执行进一步的声明:
Exchange exchange = done.getExchanges().get(0);
...
如果您在Spring(引导)顶部使用Camel,则可能还会通读如何test Camel with Spring enabled