[ 
https://issues.apache.org/activemq/browse/SMXCOMP-663?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Gert Vanthienen resolved SMXCOMP-663.
-------------------------------------

    Resolution: Fixed

Fixed in http://svn.apache.org/viewvc?view=revision&revision=828706 by using 
the servicemix-camel bundle context instead on the injected bundle context.
Created SMXCOMP-664 to remember to replace the broken mock-based unit tests 
with pax-exam based tests somewhere.

> Unable to load Camel JBI component in ServiceMix 4 when using plain xml 
> deployment
> ----------------------------------------------------------------------------------
>
>                 Key: SMXCOMP-663
>                 URL: https://issues.apache.org/activemq/browse/SMXCOMP-663
>             Project: ServiceMix Components
>          Issue Type: Bug
>          Components: servicemix-camel
>    Affects Versions: servicemix-camel-2009.01
>            Reporter: Gert Vanthienen
>            Assignee: Gert Vanthienen
>             Fix For: servicemix-camel-2009.02
>
>
> When deploying the simple quartz.xml demo file on ServiceMix 4.1.0-SNAPSHOT, 
> you get :
> {noformat}
> Exception in thread "SpringOsgiExtenderThread-58" 
> org.apache.camel.ResolveEndpointFailedException: Failed to resolve endpoint: 
> jbi://endpoint:http://servicemix.apache.org/examples/camel/receiver/endpoint 
> due to: Could not auto create component: jbi
>       at 
> org.apache.camel.impl.DefaultCamelContext.getEndpoint(DefaultCamelContext.java:433)
>       at 
> org.apache.camel.util.CamelContextHelper.getMandatoryEndpoint(CamelContextHelper.java:52)
>       at 
> org.apache.camel.model.RouteDefinition.resolveEndpoint(RouteDefinition.java:141)
>       at 
> org.apache.camel.impl.DefaultRouteContext.resolveEndpoint(DefaultRouteContext.java:103)
>       at 
> org.apache.camel.impl.DefaultRouteContext.resolveEndpoint(DefaultRouteContext.java:109)
>       at 
> org.apache.camel.model.FromDefinition.resolveEndpoint(FromDefinition.java:72)
>       at 
> org.apache.camel.impl.DefaultRouteContext.getEndpoint(DefaultRouteContext.java:78)
>       at 
> org.apache.camel.model.RouteDefinition.addRoutes(RouteDefinition.java:511)
>       at 
> org.apache.camel.model.RouteDefinition.addRoutes(RouteDefinition.java:129)
>       at 
> org.apache.camel.impl.DefaultCamelContext.startRoute(DefaultCamelContext.java:595)
>       at 
> org.apache.camel.impl.DefaultCamelContext.startRouteDefinitions(DefaultCamelContext.java:1098)
>       at 
> org.apache.camel.impl.DefaultCamelContext.doStartCamel(DefaultCamelContext.java:1016)
>       at 
> org.apache.camel.impl.DefaultCamelContext.doStart(DefaultCamelContext.java:953)
>       at 
> org.apache.camel.spring.SpringCamelContext.maybeDoStart(SpringCamelContext.java:182)
>       at 
> org.apache.camel.spring.SpringCamelContext.doStart(SpringCamelContext.java:177)
>       at org.apache.camel.impl.ServiceSupport.start(ServiceSupport.java:52)
>       at 
> org.apache.camel.impl.DefaultCamelContext.start(DefaultCamelContext.java:850)
>       at 
> org.apache.camel.spring.SpringCamelContext.maybeStart(SpringCamelContext.java:99)
>       at 
> org.apache.camel.spring.SpringCamelContext.onApplicationEvent(SpringCamelContext.java:119)
>       at 
> org.apache.camel.spring.CamelContextFactoryBean.onApplicationEvent(CamelContextFactoryBean.java:510)
>       at 
> org.springframework.context.event.SimpleApplicationEventMulticaster$1.run(SimpleApplicationEventMulticaster.java:78)
>       at 
> org.springframework.core.task.SyncTaskExecutor.execute(SyncTaskExecutor.java:49)
>       at 
> org.springframework.context.event.SimpleApplicationEventMulticaster.multicastEvent(SimpleApplicationEventMulticaster.java:76)
>       at 
> org.springframework.context.support.AbstractApplicationContext.publishEvent(AbstractApplicationContext.java:274)
>       at 
> org.springframework.context.support.AbstractApplicationContext.finishRefresh(AbstractApplicationContext.java:736)
>       at 
> org.springframework.osgi.context.support.AbstractOsgiBundleApplicationContext.finishRefresh(AbstractOsgiBundleApplicationContext.java:235)
>       at 
> org.springframework.osgi.context.support.AbstractDelegatedExecutionApplicationContext$4.run(AbstractDelegatedExecutionApplicationContext.java:358)
>       at 
> org.springframework.osgi.util.internal.PrivilegedUtils.executeWithCustomTCCL(PrivilegedUtils.java:85)
>       at 
> org.springframework.osgi.context.support.AbstractDelegatedExecutionApplicationContext.completeRefresh(AbstractDelegatedExecutionApplicationContext.java:320)
>       at 
> org.springframework.osgi.extender.internal.dependencies.startup.DependencyWaiterApplicationContextExecutor$CompleteRefreshTask.run(DependencyWaiterApplicationContextExecutor.java:136)
>       at java.lang.Thread.run(Thread.java:595)
> Caused by: org.apache.camel.RuntimeCamelException: Could not auto create 
> component: jbi
>       at 
> org.apache.camel.impl.DefaultCamelContext.getComponent(DefaultCamelContext.java:222)
>       at 
> org.apache.camel.impl.DefaultCamelContext.getEndpoint(DefaultCamelContext.java:407)
>       ... 30 more
> Caused by: org.springframework.beans.factory.BeanCreationException: Error 
> creating bean with name 'org.apache.servicemix.camel.osgi.OsgiJbiComponent': 
> Invocation of init method failed; nested exception is 
> java.lang.IllegalStateException: org.apache.servicemix.camel.CamelComponent 
> not found in the OSGi registry
>       at 
> org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1338)
>       at 
> org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:473)
>       at 
> org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory$1.run(AbstractAutowireCapableBeanFactory.java:409)
>       at java.security.AccessController.doPrivileged(Native Method)
>       at 
> org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:380)
>       at 
> org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:300)
>       at 
> org.apache.camel.spring.spi.SpringInjector.newInstance(SpringInjector.java:39)
>       at 
> org.apache.camel.osgi.OsgiComponentResolver.resolveComponent(OsgiComponentResolver.java:59)
>       at 
> org.apache.camel.impl.DefaultCamelContext.getComponent(DefaultCamelContext.java:213)
>       ... 31 more
> Caused by: java.lang.IllegalStateException: 
> org.apache.servicemix.camel.CamelComponent not found in the OSGi registry
>       at 
> org.apache.servicemix.camel.osgi.OsgiJbiComponent.afterPropertiesSet(OsgiJbiComponent.java:42)
>       at 
> org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1369)
>       at 
> org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1335)
>       ... 39 more
> {noformat}

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.

Reply via email to