/**
* 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.component.kestrel;
import java.util.Arrays;
import org.apache.camel.CamelContext;
import org.apache.camel.test.junit4.CamelTestSupport;
import org.junit.Test;
public class KestrelEndpointTest extends CamelTestSupport {
private static final class TestCase {
String uri;
String[] addresses;
String queue;
Integer waitTimeMs;
Integer concurrentConsumers;
TestCase(String uri, String[] addresses, String queue, Integer waitTimeMs, Integer concurrentConsumers) {
this.uri = uri;
this.addresses = addresses;
this.queue = queue;
this.waitTimeMs = waitTimeMs;
this.concurrentConsumers = concurrentConsumers;
}
}
private static final TestCase[] TEST_CASES = new TestCase[] {
new TestCase("kestrel:///queuename",
null,
"queuename",
null,
null),
new TestCase("kestrel://queuename?concurrentConsumers=44",
null,
"queuename",
null,
44),
new TestCase("kestrel://queuename?waitTimeMs=4567",
null,
"queuename",
4567,
null),
new TestCase("kestrel://localhost/queuename",
new String[] {"localhost"},
"queuename",
null,
null),
new TestCase("kestrel://127.0.0.1:22133,localhost:22134/queuename?waitTimeMs=4567&concurrentConsumers=99",
new String[] {"127.0.0.1:22133", "localhost:22134"},
"queuename",
4567,
99),
new TestCase("kestrel://127.0.0.1:22133/queuename?concurrentConsumers=10&waitTimeMs=4567",
new String[] {"127.0.0.1:22133"},
"queuename",
4567,
10),
new TestCase("kestrel://localhost/queuename?concurrentConsumers=20",
new String[] {"localhost"},
"queuename",
null,
20),
new TestCase("kestrel://localhost,otherhost/queuename?waitTimeMs=4567",
new String[] {"localhost", "otherhost"},
"queuename",
4567,
null),
new TestCase("kestrel://localhost:22133,otherhost/queuename?waitTimeMs=4567&concurrentConsumers=5",
new String[] {"localhost:22133", "otherhost"},
"queuename",
4567,
5),
new TestCase("kestrel://localhost,otherhost:22133/queuename?waitTimeMs=4567",
new String[] {"localhost", "otherhost:22133"},
"queuename",
4567,
null),
};
private KestrelConfiguration baseConfiguration;
private KestrelComponent kestrelComponent;
@Test
public void testEndpoints() throws Exception {
for (TestCase testCase : TEST_CASES) {
KestrelEndpoint endpoint = (KestrelEndpoint)
resolveMandatoryEndpoint(testCase.uri);
assertEquals("getQueue(" + testCase.uri + ")", testCase.queue, endpoint.getQueue());
KestrelConfiguration configuration = endpoint.getConfiguration();
if (testCase.addresses != null) {
assertEquals("getAddresses(" + testCase.uri + ")", Arrays.asList(testCase.addresses), Arrays.asList(configuration.getAddresses()));
} else {
assertEquals("getAddresses(" + testCase.uri + ")", Arrays.asList(baseConfiguration.getAddresses()), Arrays.asList(configuration.getAddresses()));
}
if (testCase.waitTimeMs != null) {
assertEquals("getWaitTimeMs(" + testCase.uri + ")", (Object)testCase.waitTimeMs, configuration.getWaitTimeMs());
} else {
assertEquals("getWaitTimeMs(" + testCase.uri + ")", baseConfiguration.getWaitTimeMs(), configuration.getWaitTimeMs());
}
if (testCase.concurrentConsumers != null) {
assertEquals("getConcurrentConsumers(" + testCase.uri + ")", (Object)testCase.concurrentConsumers, configuration.getConcurrentConsumers());
} else {
assertEquals("getConcurrentConsumers(" + testCase.uri + ")", baseConfiguration.getConcurrentConsumers(), configuration.getConcurrentConsumers());
}
}
}
@Override
protected CamelContext createCamelContext() throws Exception {
baseConfiguration = new KestrelConfiguration();
baseConfiguration.setAddresses(new String[] {"base:12345"});
baseConfiguration.setWaitTimeMs(9999);
baseConfiguration.setConcurrentConsumers(11);
kestrelComponent = new KestrelComponent();
kestrelComponent.setConfiguration(baseConfiguration);
CamelContext camelContext = super.createCamelContext();
camelContext.addComponent("kestrel", kestrelComponent);
return camelContext;
}
}