org.apache.camel.test.blueprint.CamelBlueprintTestSupport Maven / Gradle / Ivy
/**
* 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.test.blueprint;
import java.io.File;
import java.util.Dictionary;
import java.util.Iterator;
import java.util.Map;
import java.util.Properties;
import java.util.Set;
import org.apache.aries.blueprint.compendium.cm.CmPropertyPlaceholder;
import org.apache.camel.CamelContext;
import org.apache.camel.component.properties.PropertiesComponent;
import org.apache.camel.model.ModelCamelContext;
import org.apache.camel.test.junit4.CamelTestSupport;
import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.osgi.framework.BundleContext;
import org.osgi.service.blueprint.container.BlueprintContainer;
import org.osgi.service.cm.Configuration;
import org.osgi.service.cm.ConfigurationAdmin;
/**
* Base class for OSGi Blueprint unit tests with Camel.
*/
public abstract class CamelBlueprintTestSupport extends CamelTestSupport {
private static ThreadLocal threadLocalBundleContext = new ThreadLocal();
private volatile BundleContext bundleContext;
protected BundleContext createBundleContext() throws Exception {
String symbolicName = getClass().getSimpleName();
BundleContext answer = CamelBlueprintHelper.createBundleContext(symbolicName, getBlueprintDescriptor(),
true, getBundleFilter(), getBundleVersion(), getBundleDirectives());
// must register override properties early in OSGi containers
Properties extra = useOverridePropertiesWithPropertiesComponent();
if (extra != null) {
answer.registerService(PropertiesComponent.OVERRIDE_PROPERTIES, extra, null);
}
// must reuse props as we can do both load from .cfg file and override afterwards
Dictionary props = new Properties();
// load configuration file
String[] file = loadConfigAdminConfigurationFile();
if (file != null && file.length != 2) {
throw new IllegalArgumentException("The returned String[] from loadConfigAdminConfigurationFile must be of length 2, was " + file.length);
}
if (file != null) {
String fileName = file[0];
String pid = file[1];
File load = new File(fileName);
log.debug("Loading properties from OSGi config admin file: {}", load);
org.apache.felix.utils.properties.Properties cfg = new org.apache.felix.utils.properties.Properties(load);
Iterator it = cfg.keySet().iterator();
while (it.hasNext()) {
String key = it.next();
// must force type cast to have code compile with both java6 and 7 with the (org.apache.felix.utils.properties.Properties)
String value = (String) cfg.get(key);
props.put(key, value);
}
ConfigurationAdmin configAdmin = CamelBlueprintHelper.getOsgiService(answer, ConfigurationAdmin.class);
if (configAdmin != null) {
// ensure we update
Configuration config = configAdmin.getConfiguration(pid);
// NOTE: setting bundle location to null is only needed for Camel 2.10.x to avoid ugly ERROR logging by pojosr/blueprint
config.setBundleLocation(null);
log.info("Updating ConfigAdmin {} by overriding properties {}", config, props);
config.update(props);
}
}
// allow end user to override properties
String pid = useOverridePropertiesWithConfigAdmin(props);
if (pid != null) {
ConfigurationAdmin configAdmin = CamelBlueprintHelper.getOsgiService(answer, ConfigurationAdmin.class);
Configuration config = configAdmin.getConfiguration(pid);
if (config == null) {
throw new IllegalArgumentException("Cannot find configuration with pid " + pid + " in OSGi ConfigurationAdmin service.");
}
// NOTE: setting bundle location to null is only needed for Camel 2.10.x to avoid ugly ERROR logging by pojosr/blueprint
config.setBundleLocation(null);
log.info("Updating ConfigAdmin {} by overriding properties {}", config, props);
config.update(props);
}
return answer;
}
@Before
@Override
public void setUp() throws Exception {
String symbolicName = getClass().getSimpleName();
if (isCreateCamelContextPerClass()) {
// test is per class, so only setup once (the first time)
boolean first = threadLocalBundleContext.get() == null;
if (first) {
threadLocalBundleContext.set(createBundleContext());
}
bundleContext = threadLocalBundleContext.get();
} else {
bundleContext = createBundleContext();
}
super.setUp();
// must wait for blueprint container to be published then the namespace parser is complete and we are ready for testing
log.debug("Waiting for BlueprintContainer to be published with symbolicName: {}", symbolicName);
getOsgiService(BlueprintContainer.class, "(osgi.blueprint.container.symbolicname=" + symbolicName + ")");
}
/**
* Override this method to override config admin properties.
*
* @param props properties where you add the properties to override
* @return the PID of the OSGi {@link ConfigurationAdmin} which are defined in the Blueprint XML file.
*/
protected String useOverridePropertiesWithConfigAdmin(Dictionary props) throws Exception {
return null;
}
/**
* Override this method and provide the name of the .cfg configuration file to use for
* Blueprint ConfigAdmin service.
*
* @return the name of the path for the .cfg file to load, and the persistence-id of the property placeholder.
*/
protected String[] loadConfigAdminConfigurationFile() {
return null;
}
@After
@Override
public void tearDown() throws Exception {
super.tearDown();
if (isCreateCamelContextPerClass()) {
// we tear down in after class
return;
}
CamelBlueprintHelper.disposeBundleContext(bundleContext);
}
@AfterClass
public static void tearDownAfterClass() throws Exception {
if (threadLocalBundleContext.get() != null) {
CamelBlueprintHelper.disposeBundleContext(threadLocalBundleContext.get());
threadLocalBundleContext.remove();
}
CamelTestSupport.tearDownAfterClass();
}
/**
* Return the system bundle context
*/
protected BundleContext getBundleContext() {
return bundleContext;
}
/**
* Gets the bundle descriptor from the classpath.
*
* Return the location(s) of the bundle descriptors from the classpath.
* Separate multiple locations by comma, or return a single location.
*
* For example override this method and return OSGI-INF/blueprint/camel-context.xml
*
* @return the location of the bundle descriptor file.
*/
protected String getBlueprintDescriptor() {
return null;
}
/**
* Gets filter expression of bundle descriptors.
* Modify this method if you wish to change default behavior.
*
* @return filter expression for OSGi bundles.
*/
protected String getBundleFilter() {
return CamelBlueprintHelper.BUNDLE_FILTER;
}
/**
* Gets test bundle version.
* Modify this method if you wish to change default behavior.
*
* @return test bundle version
*/
protected String getBundleVersion() {
return CamelBlueprintHelper.BUNDLE_VERSION;
}
/**
* Gets the bundle directives.
* Modify this method if you wish to add some directives.
* @return
*/
protected String getBundleDirectives() {
return null;
}
@Override
protected CamelContext createCamelContext() throws Exception {
CamelContext answer = CamelBlueprintHelper.getOsgiService(bundleContext, CamelContext.class);
// must override context so we use the correct one in testing
context = (ModelCamelContext) answer;
return answer;
}
protected T getOsgiService(Class type) {
return CamelBlueprintHelper.getOsgiService(bundleContext, type);
}
protected T getOsgiService(Class type, long timeout) {
return CamelBlueprintHelper.getOsgiService(bundleContext, type, timeout);
}
protected T getOsgiService(Class type, String filter) {
return CamelBlueprintHelper.getOsgiService(bundleContext, type, filter);
}
protected T getOsgiService(Class type, String filter, long timeout) {
return CamelBlueprintHelper.getOsgiService(bundleContext, type, filter, timeout);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy