我有以下示例路由流,其中我收到 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);
}
但是现在如何在进程响应 bean 执行后断言交换?
或者有没有办法从第一条路由进行测试并满足 JMSReplyTo 的要求,而无需实际运行 EMS 服务器?
由于您已经在编织路由,因此您可以在路由建议中添加对模拟端点的传播,例如:
this.weaveAddLast().to("mock:done");
这只是在"Build & Send Http Request"
路线的末尾添加一个.to("mock:done")
定义。从给定的问题陈述来看,.bean(processResponse);
实际上做了什么,有点不清楚。您还可以将此模拟终结点传播添加到"Build XML Response"
路由,在这种情况下,您需要进一步的路由建议定义。
接下来,您可以让 Camel 通过以下方式注入模拟端点
@EndpointInject(uri = "mock:done")
private MockEndpoint done;
或通过以下方式在测试中手动定义它:
MockEndpoint done = camelContext.getEndpoint("mock:done", MockEndpoint.class);
此模拟终结点可用于定义某些期望,以便您希望该终结点接收一条消息
done.expectedMessageCount(1);
...
// invoke your route here
template.sendBody(...);
...
done.assertIsSatisfied();
您还可以通过以下方向直接访问此端点收到的交换,并对其执行进一步的断言:
Exchange exchange = done.getExchanges().get(0);
...
如果您在 Spring 之上使用 Camel(Boot(,您还可以通读如何在启用 Spring 的情况下测试 Camel