You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@camel.apache.org by ni...@apache.org on 2010/11/05 04:20:51 UTC

svn commit: r1031417 - in /camel/trunk: camel-core/src/main/java/org/apache/camel/impl/ camel-core/src/test/java/org/apache/camel/component/file/ components/camel-blueprint/src/main/java/org/apache/camel/blueprint/ components/camel-blueprint/src/main/j...

Author: ningjiang
Date: Fri Nov  5 03:20:50 2010
New Revision: 1031417

URL: http://svn.apache.org/viewvc?rev=1031417&view=rev
Log:
Revert the change that I just committed by accident

Modified:
    camel/trunk/camel-core/src/main/java/org/apache/camel/impl/CamelPostProcessorHelper.java
    camel/trunk/camel-core/src/main/java/org/apache/camel/impl/CompositeRegistry.java   (props changed)
    camel/trunk/camel-core/src/test/java/org/apache/camel/component/file/FileConsumerDeleteAndMoveFailedTest.java   (props changed)
    camel/trunk/components/camel-blueprint/src/main/java/org/apache/camel/blueprint/CamelContextFactoryBean.java
    camel/trunk/components/camel-blueprint/src/main/java/org/apache/camel/blueprint/handler/CamelNamespaceHandler.java
    camel/trunk/components/camel-cxf/src/main/resources/META-INF/cxf/camel/cxf-extension-camel.xml   (props changed)
    camel/trunk/components/camel-hawtdb/src/test/java/org/apache/camel/component/hawtdb/HawtDBAggregateDiscardOnTimeoutTest.java
    camel/trunk/components/camel-jms/pom.xml
    camel/trunk/components/camel-jpa/src/test/java/org/apache/camel/component/jpa/AbstractJpaMethodTest.java
    camel/trunk/components/camel-jpa/src/test/java/org/apache/camel/component/jpa/JpaUseMergeTest.java
    camel/trunk/components/camel-ldap/src/test/java/org/apache/camel/component/ldap/LdapRouteTest.java
    camel/trunk/components/camel-protobuf/src/test/java/org/apache/camel/dataformat/protobuf/ProtobufMarshalAndUnmarshalSpringTest.java   (props changed)
    camel/trunk/components/camel-protobuf/src/test/java/org/apache/camel/dataformat/protobuf/ProtobufMarshalAndUnmarshallTest.java   (props changed)
    camel/trunk/components/camel-spring-javaconfig/pom.xml
    camel/trunk/components/camel-spring/src/main/java/org/apache/camel/spring/CamelBeanPostProcessor.java
    camel/trunk/components/camel-web/src/main/java/org/apache/camel/web/resources/CamelContextResource.java
    camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppConsumer.java
    camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppGroupChatProducer.java
    camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppPrivateChatProducer.java
    camel/trunk/examples/camel-example-cxf-proxy/src/main/resources/META-INF/spring/camel-config.xml   (props changed)
    camel/trunk/parent/pom.xml
    camel/trunk/platforms/karaf/features/src/main/resources/features-spring2.xml   (props changed)
    camel/trunk/platforms/karaf/features/src/main/resources/features.xml   (props changed)
    camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/blueprint/OSGiBlueprintTestSupport.java
    camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/cxf/CxfProxyExampleTest.java
    camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/spring/xslt/XsltRouteTest.java

Modified: camel/trunk/camel-core/src/main/java/org/apache/camel/impl/CamelPostProcessorHelper.java
URL: http://svn.apache.org/viewvc/camel/trunk/camel-core/src/main/java/org/apache/camel/impl/CamelPostProcessorHelper.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/camel-core/src/main/java/org/apache/camel/impl/CamelPostProcessorHelper.java (original)
+++ camel/trunk/camel-core/src/main/java/org/apache/camel/impl/CamelPostProcessorHelper.java Fri Nov  5 03:20:50 2010
@@ -44,9 +44,8 @@ import org.apache.commons.logging.LogFac
 
 /**
  * A helper class for Camel based injector or post processing hooks which can be reused by
- * both the <a href="http://camel.apache.org/spring.html">Spring</a>,
- * <a href="http://camel.apache.org/guice.html">Guice</a> and
- * <a href="http://camel.apache.org/blueprint.html">Blueprint</a>support.
+ * both the <a href="http://camel.apache.org/spring.html">Spring</a>
+ * and <a href="http://camel.apache.org/guice.html">Guice</a> support.
  *
  * @version $Revision$
  */

Propchange: camel/trunk/camel-core/src/main/java/org/apache/camel/impl/CompositeRegistry.java
            ('svn:mergeinfo' removed)

Propchange: camel/trunk/camel-core/src/test/java/org/apache/camel/component/file/FileConsumerDeleteAndMoveFailedTest.java
            ('svn:mergeinfo' removed)

Modified: camel/trunk/components/camel-blueprint/src/main/java/org/apache/camel/blueprint/CamelContextFactoryBean.java
URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-blueprint/src/main/java/org/apache/camel/blueprint/CamelContextFactoryBean.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/components/camel-blueprint/src/main/java/org/apache/camel/blueprint/CamelContextFactoryBean.java (original)
+++ camel/trunk/components/camel-blueprint/src/main/java/org/apache/camel/blueprint/CamelContextFactoryBean.java Fri Nov  5 03:20:50 2010
@@ -98,7 +98,7 @@ public class CamelContextFactoryBean ext
     @XmlElement(name = "jmxAgent", type = CamelJMXAgentDefinition.class, required = false)
     private CamelJMXAgentDefinition camelJMXAgent;
     @XmlElements({
-        @XmlElement(name = "beanPostProcessor", type = CamelBeanPostProcessor.class, required = false),
+//        @XmlElement(name = "beanPostProcessor", type = CamelBeanPostProcessor.class, required = false),
         @XmlElement(name = "template", type = CamelProducerTemplateFactoryBean.class, required = false),
         @XmlElement(name = "consumerTemplate", type = CamelConsumerTemplateFactoryBean.class, required = false),
         @XmlElement(name = "proxy", type = CamelProxyFactoryDefinition.class, required = false),
@@ -178,7 +178,6 @@ public class CamelContextFactoryBean ext
     }
 
     @Override
-    // TODO this method is need for looking up the customer configure component
     protected <S> S getBeanForType(Class<S> clazz) {
         return null;
     }

Modified: camel/trunk/components/camel-blueprint/src/main/java/org/apache/camel/blueprint/handler/CamelNamespaceHandler.java
URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-blueprint/src/main/java/org/apache/camel/blueprint/handler/CamelNamespaceHandler.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/components/camel-blueprint/src/main/java/org/apache/camel/blueprint/handler/CamelNamespaceHandler.java (original)
+++ camel/trunk/components/camel-blueprint/src/main/java/org/apache/camel/blueprint/handler/CamelNamespaceHandler.java Fri Nov  5 03:20:50 2010
@@ -40,7 +40,6 @@ import org.apache.aries.blueprint.mutabl
 import org.apache.aries.blueprint.mutable.MutablePassThroughMetadata;
 import org.apache.aries.blueprint.mutable.MutableReferenceMetadata;
 import org.apache.camel.blueprint.BlueprintCamelContext;
-import org.apache.camel.blueprint.CamelBeanPostProcessor;
 import org.apache.camel.blueprint.CamelContextFactoryBean;
 import org.apache.camel.core.xml.AbstractCamelContextFactoryBean;
 import org.apache.camel.impl.DefaultCamelContextNameStrategy;
@@ -142,8 +141,6 @@ public class CamelNamespaceHandler imple
                 ptm = (PassThroughMetadata) context.getComponentDefinitionRegistry().getComponentDefinition("blueprintBundleContext");
                 ccfb.setBundleContext((BundleContext) ptm.getObject());
                 ccfb.setImplicitId(implicitId);
-                // setup the BeanPostProcessor
-                createBeansReference(context, contextId, ccfb.getBeans());
                 ccfb.afterPropertiesSet();
             } catch (Exception e) {
                 throw new ComponentDefinitionException("Unable to initialize camel context factory", e);
@@ -267,16 +264,6 @@ public class CamelNamespaceHandler imple
         return null;
     }
 
-    private void createBeansReference(ParserContext context, String contextId, List beans) {
-        // need to check the beanPostProcessor first
-        MutableBeanMetadata metadata = context.createMetadata(MutableBeanMetadata.class);
-        metadata.setProcessor(true);
-        metadata.setId(contextId + ".beanPostProcessor");
-        metadata.setRuntimeClass(CamelBeanPostProcessor.class);
-        LOG.info("**** create the beanPostProcessor");
-        context.getComponentDefinitionRegistry().registerComponentDefinition(metadata);
-    }
-
     private void findInputComponents(List<FromDefinition> defs, Set<String> components, Set<String> languages, Set<String> dataformats) {
         if (defs != null) {
             for (FromDefinition def : defs) {

Propchange: camel/trunk/components/camel-cxf/src/main/resources/META-INF/cxf/camel/cxf-extension-camel.xml
            ('svn:mergeinfo' removed)

Modified: camel/trunk/components/camel-hawtdb/src/test/java/org/apache/camel/component/hawtdb/HawtDBAggregateDiscardOnTimeoutTest.java
URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-hawtdb/src/test/java/org/apache/camel/component/hawtdb/HawtDBAggregateDiscardOnTimeoutTest.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/components/camel-hawtdb/src/test/java/org/apache/camel/component/hawtdb/HawtDBAggregateDiscardOnTimeoutTest.java (original)
+++ camel/trunk/components/camel-hawtdb/src/test/java/org/apache/camel/component/hawtdb/HawtDBAggregateDiscardOnTimeoutTest.java Fri Nov  5 03:20:50 2010
@@ -17,6 +17,7 @@
 package org.apache.camel.component.hawtdb;
 
 import java.util.concurrent.TimeUnit;
+import java.util.concurrent.atomic.AtomicInteger;
 
 import org.apache.camel.Exchange;
 import org.apache.camel.builder.RouteBuilder;
@@ -26,7 +27,8 @@ import org.apache.camel.test.junit4.Came
 import org.junit.Test;
 
 public class HawtDBAggregateDiscardOnTimeoutTest extends CamelTestSupport {
-   
+
+    private static AtomicInteger counter = new AtomicInteger(0);
     private HawtDBAggregationRepository repo;
 
     @Override

Modified: camel/trunk/components/camel-jms/pom.xml
URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-jms/pom.xml?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/components/camel-jms/pom.xml (original)
+++ camel/trunk/components/camel-jms/pom.xml Fri Nov  5 03:20:50 2010
@@ -42,11 +42,6 @@
     </dependency>
     <dependency>
       <groupId>org.apache.camel</groupId>
-      <artifactId>camel-core-xml</artifactId>
-      <scope>provided</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.camel</groupId>
       <artifactId>camel-spring</artifactId>
     </dependency>
     <dependency>

Modified: camel/trunk/components/camel-jpa/src/test/java/org/apache/camel/component/jpa/AbstractJpaMethodTest.java
URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-jpa/src/test/java/org/apache/camel/component/jpa/AbstractJpaMethodTest.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/components/camel-jpa/src/test/java/org/apache/camel/component/jpa/AbstractJpaMethodTest.java (original)
+++ camel/trunk/components/camel-jpa/src/test/java/org/apache/camel/component/jpa/AbstractJpaMethodTest.java Fri Nov  5 03:20:50 2010
@@ -62,6 +62,7 @@ public abstract class AbstractJpaMethodT
         stopServices(consumer, template, camelContext);
     }
     
+    @SuppressWarnings("unchecked")
     @Test
     public void produceNewEntity() throws Exception {
         setUp("jpa://" + Customer.class.getName() + "?usePersist=" + (usePersist() ? "true" : "false"));
@@ -88,6 +89,7 @@ public abstract class AbstractJpaMethodT
         assertEquals(receivedCustomer.getAddress().getId(), persistedCustomer.getAddress().getId());
     }
 
+    @SuppressWarnings("unchecked")
     @Test
     public void produceNewEntitiesFromList() throws Exception {
         setUp("jpa://" + List.class.getName() + "?usePersist=" + (usePersist() ? "true" : "false"));
@@ -158,6 +160,7 @@ public abstract class AbstractJpaMethodT
         assertEntitiesInDatabase(0, Address.class.getName());
     }
     
+    @SuppressWarnings("unchecked")
     protected void setUp(String endpointUri) throws Exception {
         template = camelContext.createProducerTemplate();
         startServices(template, camelContext);
@@ -178,6 +181,7 @@ public abstract class AbstractJpaMethodT
         assertEntitiesInDatabase(0, Address.class.getName());
     }
     
+    @SuppressWarnings("unchecked")
     protected void save(final Customer customer) {
         transactionStrategy.execute(new JpaCallback() {
             public Object doInJpa(EntityManager entityManager) throws PersistenceException {
@@ -191,6 +195,7 @@ public abstract class AbstractJpaMethodT
         assertEntitiesInDatabase(1, Address.class.getName());
     }
     
+    @SuppressWarnings("unchecked")
     protected void assertEntitiesInDatabase(int count, String entity) {
         List results = jpaTemplate.find("select o from " + entity + " o");
         assertEquals(count, results.size());

Modified: camel/trunk/components/camel-jpa/src/test/java/org/apache/camel/component/jpa/JpaUseMergeTest.java
URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-jpa/src/test/java/org/apache/camel/component/jpa/JpaUseMergeTest.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/components/camel-jpa/src/test/java/org/apache/camel/component/jpa/JpaUseMergeTest.java (original)
+++ camel/trunk/components/camel-jpa/src/test/java/org/apache/camel/component/jpa/JpaUseMergeTest.java Fri Nov  5 03:20:50 2010
@@ -37,6 +37,7 @@ public class JpaUseMergeTest extends Abs
         return false;
     }
 
+    @SuppressWarnings("unchecked")
     @Test
     public void produceExistingEntity() throws Exception {
         setUp("jpa://" + Customer.class.getName() + "?usePersist=false");

Modified: camel/trunk/components/camel-ldap/src/test/java/org/apache/camel/component/ldap/LdapRouteTest.java
URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-ldap/src/test/java/org/apache/camel/component/ldap/LdapRouteTest.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/components/camel-ldap/src/test/java/org/apache/camel/component/ldap/LdapRouteTest.java (original)
+++ camel/trunk/components/camel-ldap/src/test/java/org/apache/camel/component/ldap/LdapRouteTest.java Fri Nov  5 03:20:50 2010
@@ -49,7 +49,6 @@ public class LdapRouteTest extends Abstr
     private ProducerTemplate template;
     private int port;
 
-    @SuppressWarnings("unchecked")
     @ApplyLdifFiles("org/apache/camel/component/ldap/LdapRouteTest.ldif")
     @Test
     public void testLdapRoute() throws Exception {

Propchange: camel/trunk/components/camel-protobuf/src/test/java/org/apache/camel/dataformat/protobuf/ProtobufMarshalAndUnmarshalSpringTest.java
            ('svn:mergeinfo' removed)

Propchange: camel/trunk/components/camel-protobuf/src/test/java/org/apache/camel/dataformat/protobuf/ProtobufMarshalAndUnmarshallTest.java
            ('svn:mergeinfo' removed)

Modified: camel/trunk/components/camel-spring-javaconfig/pom.xml
URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-spring-javaconfig/pom.xml?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/components/camel-spring-javaconfig/pom.xml (original)
+++ camel/trunk/components/camel-spring-javaconfig/pom.xml Fri Nov  5 03:20:50 2010
@@ -58,11 +58,6 @@
     </dependency>
     <dependency>
       <groupId>org.apache.camel</groupId>
-      <artifactId>camel-core-xml</artifactId>
-      <scope>provided</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.camel</groupId>
       <artifactId>camel-spring</artifactId>
       <exclusions>
         <exclusion>

Modified: camel/trunk/components/camel-spring/src/main/java/org/apache/camel/spring/CamelBeanPostProcessor.java
URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-spring/src/main/java/org/apache/camel/spring/CamelBeanPostProcessor.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/components/camel-spring/src/main/java/org/apache/camel/spring/CamelBeanPostProcessor.java (original)
+++ camel/trunk/components/camel-spring/src/main/java/org/apache/camel/spring/CamelBeanPostProcessor.java Fri Nov  5 03:20:50 2010
@@ -32,7 +32,6 @@ import org.apache.camel.Endpoint;
 import org.apache.camel.EndpointInject;
 import org.apache.camel.Produce;
 import org.apache.camel.Service;
-import org.apache.camel.core.xml.AbstractCamelBeanPostProcessor;
 import org.apache.camel.core.xml.CamelJMXAgentDefinition;
 import org.apache.camel.impl.CamelPostProcessorHelper;
 import org.apache.camel.impl.DefaultEndpoint;
@@ -66,13 +65,19 @@ import org.springframework.context.Appli
  */
 @XmlRootElement(name = "beanPostProcessor")
 @XmlAccessorType(XmlAccessType.FIELD)
-public class CamelBeanPostProcessor extends AbstractCamelBeanPostProcessor implements BeanPostProcessor, ApplicationContextAware {
+public class CamelBeanPostProcessor implements BeanPostProcessor, ApplicationContextAware {
     private static final transient Log LOG = LogFactory.getLog(CamelBeanPostProcessor.class);
     @XmlTransient
     Set<String> prototypeBeans = new LinkedHashSet<String>();
     @XmlTransient
+    private CamelContext camelContext;
+    @XmlTransient
     private ApplicationContext applicationContext;
-    
+    @XmlTransient
+    private CamelPostProcessorHelper postProcessor;
+    @XmlTransient
+    private String camelId;
+
     public CamelBeanPostProcessor() {
     }
 
@@ -86,8 +91,8 @@ public class CamelBeanPostProcessor exte
             return bean;
         }
 
-        if (getCamelContext() == null && applicationContext.containsBean(getCamelId())) {
-            setCamelContext((CamelContext) applicationContext.getBean(getCamelId()));
+        if (camelContext == null && applicationContext.containsBean(camelId)) {
+            setCamelContext((CamelContext) applicationContext.getBean(camelId));
         }
 
         injectFields(bean, beanName);
@@ -95,10 +100,10 @@ public class CamelBeanPostProcessor exte
 
         if (bean instanceof CamelContextAware && canSetCamelContext(bean, beanName)) {
             CamelContextAware contextAware = (CamelContextAware)bean;
-            if (getCamelContext() == null) {
+            if (camelContext == null) {
                 LOG.warn("No CamelContext defined yet so cannot inject into: " + bean);
             } else {
-                contextAware.setCamelContext(getCamelContext());
+                contextAware.setCamelContext(camelContext);
             }
         }
 
@@ -129,11 +134,92 @@ public class CamelBeanPostProcessor exte
     public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
         this.applicationContext = applicationContext;
     }
-   
+
+    public CamelContext getCamelContext() {
+        return camelContext;
+    }
+
+    public void setCamelContext(CamelContext camelContext) {
+        this.camelContext = camelContext;
+        postProcessor = new CamelPostProcessorHelper(camelContext) {
+            @Override
+            protected RuntimeException createProxyInstantiationRuntimeException(Class<?> type, Endpoint endpoint, Exception e) {
+                return new BeanInstantiationException(type, "Could not instantiate proxy of type " + type.getName() + " on endpoint " + endpoint, e);
+            }
+
+            protected boolean isSingleton(Object bean, String beanName) {
+                // no application context has been injected which means the bean
+                // has not been enlisted in Spring application context
+                if (applicationContext == null || beanName == null) {
+                    return super.isSingleton(bean, beanName);
+                } else {
+                    return applicationContext.isSingleton(beanName);
+                }
+            }
+
+            protected void startService(Service service, Object bean, String beanName) throws Exception {
+                if (isSingleton(bean, beanName)) {
+                    getCamelContext().addService(service);
+                } else {
+                    // only start service and do not add it to CamelContext
+                    ServiceHelper.startService(service);
+                    if (prototypeBeans.add(beanName)) {
+                        // do not spam the log with WARN so do this only once per bean name
+                        LOG.warn("The bean with id [" + beanName + "] is prototype scoped and cannot stop the injected service when bean is destroyed: "
+                                + service + ". You may want to stop the service manually from the bean.");
+                    }
+                }
+            }
+        };
+    }
+
+    public String getCamelId() {
+        return camelId;
+    }
+
+    public void setCamelId(String camelId) {
+        this.camelId = camelId;
+    }
+
     // Implementation methods
     // -------------------------------------------------------------------------
 
-   
+    /**
+     * Can we post process the given bean?
+     *
+     * @param bean the bean
+     * @param beanName the bean name
+     * @return true to process it
+     */
+    protected boolean canPostProcessBean(Object bean, String beanName) {
+        // the JMXAgent is a bit strange and causes Spring issues if we let it being
+        // post processed by this one. It does not need it anyway so we are good to go.
+        if (bean instanceof CamelJMXAgentDefinition) {
+            return false;
+        }
+
+        // all other beans can of course be processed
+        return true;
+    }
+    
+    
+    protected boolean canSetCamelContext(Object bean, String beanName) {
+        boolean answer = true;
+        if (bean instanceof CamelContextAware) {
+            CamelContextAware camelContextAware = (CamelContextAware) bean;
+            CamelContext context = camelContextAware.getCamelContext();
+            if (context != null) {
+                if (LOG.isTraceEnabled()) {
+                    LOG.trace("The camel context of " + beanName + " is set, so we skip inject the camel context of it.");
+                }
+                answer = false;
+            }
+        } else {
+            answer = false;
+        }
+        return answer;
+    }
+
     /**
      * A strategy method to allow implementations to perform some custom JBI
      * based injection of the POJO
@@ -144,12 +230,12 @@ public class CamelBeanPostProcessor exte
         ReflectionUtils.doWithFields(bean.getClass(), new ReflectionUtils.FieldCallback() {
             public void doWith(Field field) throws IllegalArgumentException, IllegalAccessException {
                 EndpointInject endpointInject = field.getAnnotation(EndpointInject.class);
-                if (endpointInject != null && getPostProcessor().matchContext(endpointInject.context())) {
+                if (endpointInject != null && postProcessor.matchContext(endpointInject.context())) {
                     injectField(field, endpointInject.uri(), endpointInject.ref(), bean, beanName);
                 }
 
                 Produce produce = field.getAnnotation(Produce.class);
-                if (produce != null && getPostProcessor().matchContext(produce.context())) {
+                if (produce != null && postProcessor.matchContext(produce.context())) {
                     injectField(field, produce.uri(), produce.ref(), bean, beanName);
                 }
             }
@@ -171,12 +257,12 @@ public class CamelBeanPostProcessor exte
 
     protected void setterInjection(Method method, Object bean, String beanName) {
         EndpointInject endpointInject = method.getAnnotation(EndpointInject.class);
-        if (endpointInject != null && getPostProcessor().matchContext(endpointInject.context())) {
+        if (endpointInject != null && postProcessor.matchContext(endpointInject.context())) {
             setterInjection(method, bean, beanName, endpointInject.uri(), endpointInject.ref());
         }
 
         Produce produce = method.getAnnotation(Produce.class);
-        if (produce != null && getPostProcessor().matchContext(produce.context())) {
+        if (produce != null && postProcessor.matchContext(produce.context())) {
             setterInjection(method, bean, beanName, produce.uri(), produce.ref());
         }
     }
@@ -194,40 +280,9 @@ public class CamelBeanPostProcessor exte
         }
     }
 
-    @Override
-    public CamelPostProcessorHelper createCamelPostProcessorHelper(CamelContext camelContext) {        
-        return new CamelPostProcessorHelper(camelContext) {
-            @Override
-            protected RuntimeException createProxyInstantiationRuntimeException(Class<?> type, Endpoint endpoint, Exception e) {
-                return new BeanInstantiationException(type, "Could not instantiate proxy of type " + type.getName() + " on endpoint " + endpoint, e);
-            }
-
-            protected boolean isSingleton(Object bean, String beanName) {
-                // no application context has been injected which means the bean
-                // has not been enlisted in Spring application context
-                if (applicationContext == null || beanName == null) {
-                    return super.isSingleton(bean, beanName);
-                } else {
-                    return applicationContext.isSingleton(beanName);
-                }
-            }
-
-            protected void startService(Service service, Object bean, String beanName) throws Exception {
-                if (isSingleton(bean, beanName)) {
-                    getCamelContext().addService(service);
-                } else {
-                    // only start service and do not add it to CamelContext
-                    ServiceHelper.startService(service);
-                    if (prototypeBeans.add(beanName)) {
-                        // do not spam the log with WARN so do this only once per bean name
-                        LOG.warn("The bean with id [" + beanName + "] is prototype scoped and cannot stop the injected service when bean is destroyed: "
-                                + service + ". You may want to stop the service manually from the bean.");
-                    }
-                }
-            }
-        };
+    public CamelPostProcessorHelper getPostProcessor() {
+        ObjectHelper.notNull(postProcessor, "postProcessor");
+        return postProcessor;
     }
-    
-    
 
 }

Modified: camel/trunk/components/camel-web/src/main/java/org/apache/camel/web/resources/CamelContextResource.java
URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-web/src/main/java/org/apache/camel/web/resources/CamelContextResource.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/components/camel-web/src/main/java/org/apache/camel/web/resources/CamelContextResource.java (original)
+++ camel/trunk/components/camel-web/src/main/java/org/apache/camel/web/resources/CamelContextResource.java Fri Nov  5 03:20:50 2010
@@ -24,8 +24,8 @@ import javax.ws.rs.Path;
 import javax.ws.rs.Produces;
 import javax.ws.rs.core.MediaType;
 
-import com.sun.jersey.api.core.InjectParam;
 import com.sun.jersey.api.view.ImplicitProduces;
+import com.sun.jersey.spi.inject.Inject;
 import com.sun.jersey.spi.resource.Singleton;
 import org.apache.camel.CamelContext;
 import org.apache.camel.ProducerTemplate;
@@ -46,7 +46,7 @@ public class CamelContextResource {
     private CamelContext camelContext;
     private ProducerTemplate template;
 
-    public CamelContextResource(@InjectParam CamelContext camelContext) throws Exception {
+    public CamelContextResource(@Inject CamelContext camelContext) throws Exception {
         this.camelContext = camelContext;
         this.template = camelContext.createProducerTemplate();
         template.start();

Modified: camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppConsumer.java
URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppConsumer.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppConsumer.java (original)
+++ camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppConsumer.java Fri Nov  5 03:20:50 2010
@@ -103,9 +103,7 @@ public class XmppConsumer extends Defaul
             muc.leave();
             muc = null;
         }
-        if (connection != null && connection.isConnected()) {
-            connection.disconnect();
-        }
+        //the endpoint will clean up the connection
     }
 
     public void chatCreated(Chat chat, boolean createdLocally) {

Modified: camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppGroupChatProducer.java
URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppGroupChatProducer.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppGroupChatProducer.java (original)
+++ camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppGroupChatProducer.java Fri Nov  5 03:20:50 2010
@@ -99,9 +99,6 @@ public class XmppGroupChatProducer exten
             chat.leave();
             chat = null;
         }
-        if (connection != null && connection.isConnected()) {
-            connection.disconnect();
-        }
         super.doStop();
     }
 

Modified: camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppPrivateChatProducer.java
URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppPrivateChatProducer.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppPrivateChatProducer.java (original)
+++ camel/trunk/components/camel-xmpp/src/main/java/org/apache/camel/component/xmpp/XmppPrivateChatProducer.java Fri Nov  5 03:20:50 2010
@@ -51,6 +51,10 @@ public class XmppPrivateChatProducer ext
 
     public void process(Exchange exchange) {
         try {
+            if (connection == null) {
+                connection = endpoint.createConnection();
+            }
+
             // make sure we are connected
             if (!connection.isConnected()) {
                 if (LOG.isDebugEnabled()) {
@@ -104,22 +108,6 @@ public class XmppPrivateChatProducer ext
                     + " to: " + XmppEndpoint.getConnectionMessage(connection), exchange, e);
         }
     }
-    
-    @Override
-    protected void doStart() throws Exception {
-        if (connection == null) {
-            connection = endpoint.createConnection();
-        }
-        super.doStart();
-    }
-
-    @Override
-    protected void doStop() throws Exception {
-        if (connection != null && connection.isConnected()) {
-            connection.disconnect();
-        }
-        super.doStop();
-    }
 
     // Properties
     // -------------------------------------------------------------------------

Propchange: camel/trunk/examples/camel-example-cxf-proxy/src/main/resources/META-INF/spring/camel-config.xml
            ('svn:mergeinfo' removed)

Modified: camel/trunk/parent/pom.xml
URL: http://svn.apache.org/viewvc/camel/trunk/parent/pom.xml?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/parent/pom.xml (original)
+++ camel/trunk/parent/pom.xml Fri Nov  5 03:20:50 2010
@@ -150,7 +150,7 @@
     <camel.osgi.import.defaults>
       org.springframework.*;version="[2.5,4)",
       org.apache.commons.logging.*;version="[1.1,2)",
-      org.apache.cxf.*;version="[2.2.11,2.4)",
+      org.apache.cxf.*;version="[2.3.0,2.4)",
       org.apache.qpid.*;version="[0.5,0.6)",
       org.apache.abdera.*;version="[0.4,0.5)",
       org.apache.commons.httpclient.*;version="[3.1,4.0)",

Propchange: camel/trunk/platforms/karaf/features/src/main/resources/features-spring2.xml
            ('svn:mergeinfo' removed)

Propchange: camel/trunk/platforms/karaf/features/src/main/resources/features.xml
            ('svn:mergeinfo' removed)

Modified: camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/blueprint/OSGiBlueprintTestSupport.java
URL: http://svn.apache.org/viewvc/camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/blueprint/OSGiBlueprintTestSupport.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/blueprint/OSGiBlueprintTestSupport.java (original)
+++ camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/blueprint/OSGiBlueprintTestSupport.java Fri Nov  5 03:20:50 2010
@@ -125,7 +125,7 @@ public class OSGiBlueprintTestSupport ex
             // install the spring dm profile
             profile("spring.dm").version("1.2.0"),
             // this is how you set the default log level when using pax logging (logProfile)
-            org.ops4j.pax.exam.CoreOptions.systemProperty("org.ops4j.pax.logging.DefaultServiceLog.level").value("INFO"),
+            org.ops4j.pax.exam.CoreOptions.systemProperty("org.ops4j.pax.logging.DefaultServiceLog.level").value("TRACE"),
 
             // install blueprint requirements
             mavenBundle("org.apache.felix", "org.apache.felix.configadmin"),

Modified: camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/cxf/CxfProxyExampleTest.java
URL: http://svn.apache.org/viewvc/camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/cxf/CxfProxyExampleTest.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/cxf/CxfProxyExampleTest.java (original)
+++ camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/cxf/CxfProxyExampleTest.java Fri Nov  5 03:20:50 2010
@@ -36,6 +36,7 @@ import static org.ops4j.pax.exam.contain
 import static org.ops4j.pax.exam.container.def.PaxRunnerOptions.workingDirectory;
 
 @RunWith(JUnit4TestRunner.class)
+@Ignore
 public class CxfProxyExampleTest extends OSGiIntegrationSpringTestSupport {
 
     protected static ReportIncidentEndpoint createCXFClient() {
@@ -72,6 +73,9 @@ public class CxfProxyExampleTest extends
         return new OsgiBundleXmlApplicationContext(new String[]{"org/apache/camel/itest/osgi/cxf/camel-config.xml"});
     }
 
+    // TODO: CxfConsumer should use OSGi http service (no embedded Jetty)
+    // TODO: Make this test work with OSGi
+
     @Configuration
     public static Option[] configure() {
         Option[] options = options(

Modified: camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/spring/xslt/XsltRouteTest.java
URL: http://svn.apache.org/viewvc/camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/spring/xslt/XsltRouteTest.java?rev=1031417&r1=1031416&r2=1031417&view=diff
==============================================================================
--- camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/spring/xslt/XsltRouteTest.java (original)
+++ camel/trunk/tests/camel-itest-osgi/src/test/java/org/apache/camel/itest/osgi/spring/xslt/XsltRouteTest.java Fri Nov  5 03:20:50 2010
@@ -19,13 +19,13 @@ package org.apache.camel.itest.osgi.spri
 import org.apache.camel.builder.RouteBuilder;
 import org.apache.camel.component.mock.MockEndpoint;
 import org.apache.camel.itest.osgi.OSGiIntegrationTestSupport;
+import org.junit.Ignore;
 import org.junit.Test;
 import org.junit.runner.RunWith;
-import org.ops4j.pax.exam.Option;
-import org.ops4j.pax.exam.junit.Configuration;
 import org.ops4j.pax.exam.junit.JUnit4TestRunner;
 
 @RunWith(JUnit4TestRunner.class)
+@Ignore("TODO: fix me")
 public class XsltRouteTest extends OSGiIntegrationTestSupport {
 
     @Test
@@ -51,26 +51,5 @@ public class XsltRouteTest extends OSGiI
             }
         };
     }
-    
-    @Configuration
-    public static Option[] configure() throws Exception {
-        Option[] options = options(
-            // install the spring dm profile            
-            profile("spring.dm").version("1.2.0"),    
-            // this is how you set the default log level when using pax logging (logProfile)
-            org.ops4j.pax.exam.CoreOptions.systemProperty("org.ops4j.pax.logging.DefaultServiceLog.level").value("INFO"),
-            
-            
-            // using the features to install the camel components             
-            scanFeatures(getCamelKarafFeatureUrl(),                         
-                          "camel-core", "camel-spring", "camel-test"),
-            
-            workingDirectory("target/paxrunner/"),
-
-            equinox(),
-            felix());
-        
-        return options;
-    }
 
 }