blob: 3b0e4f55f2138a812d6337d89f8aaa25c1260646 [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.camel.processor;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import org.apache.camel.ContextTestSupport;
import org.apache.camel.Header;
import org.apache.camel.builder.RouteBuilder;
import static org.apache.camel.language.simple.SimpleLanguage.simple;
/**
* @version
*/
public class RecipeientListWithSimpleExpressionTest extends ContextTestSupport {
@Override
public boolean isUseRouteBuilder() {
return false;
}
@Override
protected void setUp() throws Exception {
disableJMX();
super.setUp();
}
public void testRecipientList() throws Exception {
context.addRoutes(new RouteBuilder() {
@Override
public void configure() throws Exception {
from("direct:start")
.recipientList(simple("mock:${in.header.queue}"));
}
});
context.start();
for (int i = 0; i < 10; i++) {
getMockEndpoint("mock:" + i).expectedMessageCount(50);
}
// use concurrent producers to send a lot of messages
ExecutorService executors = Executors.newFixedThreadPool(10);
for (int i = 0; i < 50; i++) {
executors.execute(new Runnable() {
public void run() {
for (int i = 0; i < 10; i++) {
template.sendBodyAndHeader("direct:start", "Hello " + i, "queue", i);
try {
Thread.sleep(5);
} catch (Exception e) {
// ignore
}
}
}
});
}
assertMockEndpointsSatisfied();
executors.shutdownNow();
}
public static class MyBeanRouter {
@org.apache.camel.RecipientList
public String route(@Header("queue") String queue) {
return "mock:" + queue;
}
}
public void testStatic() throws Exception {
context.addRoutes(new RouteBuilder() {
@Override
public void configure() throws Exception {
from("direct:0").to("mock:0");
from("direct:1").to("mock:1");
from("direct:2").to("mock:2");
from("direct:3").to("mock:3");
from("direct:4").to("mock:4");
from("direct:5").to("mock:5");
from("direct:6").to("mock:6");
from("direct:7").to("mock:7");
from("direct:8").to("mock:8");
from("direct:9").to("mock:9");
}
});
context.start();
for (int i = 0; i < 10; i++) {
getMockEndpoint("mock:" + i).expectedMessageCount(50);
}
// use concurrent producers to send a lot of messages
ExecutorService executors = Executors.newFixedThreadPool(10);
for (int i = 0; i < 50; i++) {
executors.execute(new Runnable() {
public void run() {
for (int i = 0; i < 10; i++) {
template.sendBodyAndHeader("direct:" + i, "Hello " + i, "queue", i);
try {
Thread.sleep(5);
} catch (Exception e) {
// ignore
}
}
}
});
}
assertMockEndpointsSatisfied();
executors.shutdownNow();
}
}