48.9. 示例
在下面的路径中,我们使用 SEDA 队列来向这个 async 队列发送请求,以便能够向另一个线程发送 fire-and-forget 消息,并将此线程中的恒定回复返回至原始调用者。
我们发送 Hello World 消息,并期望回复是 OK。
@Test
public void testSendAsync() throws Exception {
MockEndpoint mock = getMockEndpoint("mock:result");
mock.expectedBodiesReceived("Hello World");
// START SNIPPET: e2
Object out = template.requestBody("direct:start", "Hello World");
assertEquals("OK", out);
// END SNIPPET: e2
assertMockEndpointsSatisfied();
}
@Override
protected RouteBuilder createRouteBuilder() throws Exception {
return new RouteBuilder() {
// START SNIPPET: e1
public void configure() throws Exception {
from("direct:start")
// send it to the seda queue that is async
.to("seda:next")
// return a constant response
.transform(constant("OK"));
from("seda:next").to("mock:result");
}
// END SNIPPET: e1
};
}
"Hello World"消息将从另一个线程的 SEDA 队列中使用,以进行进一步处理。由于这是一个单元测试,因此它将发送到 模拟 端点,在单元测试中我们可以进行断言。