You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@camel.apache.org by "Adam Ostrožlík (JIRA)" <ji...@apache.org> on 2019/06/25 12:51:00 UTC

[jira] [Created] (CAMEL-13682) Wrong bean injection from OSGI

Adam Ostrožlík created CAMEL-13682:
--------------------------------------

             Summary: Wrong bean injection from OSGI
                 Key: CAMEL-13682
                 URL: https://issues.apache.org/jira/browse/CAMEL-13682
             Project: Camel
          Issue Type: Bug
         Environment: {color:#d4d4d4}Caused by: {color}{color:#ce9178}org.apache.camel.NoSuchBeanException{color}{color:#d4d4d4}: No bean could be found in the registry for: Found {color}{color:#569cd6}2{color}{color:#d4d4d4} beans of type: interface {color}{color:#569cd6}eu.unicorn.basse.ms.audit.api.store.AuditStore{color}{color:#d4d4d4}. Only one bean expected.{color}
{color:#ce9178}    at org.apache.camel.impl.CamelPostProcessorHelper.getInjectionBeanValue(CamelPostProcessorHelper.java:267){color}
{color:#ce9178}    at org.apache.camel.blueprint.handler.CamelNamespaceHandler$CamelInjector.injectFieldBean(CamelNamespaceHandler.java:826){color}
{color:#ce9178}    at org.apache.camel.blueprint.handler.CamelNamespaceHandler$CamelInjector.injectFields(CamelNamespaceHandler.java:800){color}
{color:#ce9178}    at org.apache.camel.blueprint.handler.CamelNamespaceHandler$CamelInjector.afterInit(CamelNamespaceHandler.java:922){color}
{color:#ce9178}    at org.apache.aries.blueprint.container.BeanRecipe.runBeanProcPostInit(BeanRecipe.java:744)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.container.BeanRecipe.internalCreate2(BeanRecipe.java:826)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.container.BeanRecipe.internalCreate(BeanRecipe.java:787)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.di.AbstractRecipe$1.call(AbstractRecipe.java:79)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at java.util.concurrent.FutureTask.run(FutureTask.java:266)[:1.8.0_212]{color}
{color:#ce9178}    at org.apache.aries.blueprint.di.AbstractRecipe.create(AbstractRecipe.java:88)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.di.RefRecipe.internalCreate(RefRecipe.java:62)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.di.AbstractRecipe.create(AbstractRecipe.java:106)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.container.BeanRecipe.setProperty(BeanRecipe.java:931)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.container.BeanRecipe.setProperties(BeanRecipe.java:905)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.container.BeanRecipe.setProperties(BeanRecipe.java:886)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.container.BeanRecipe.internalCreate2(BeanRecipe.java:820)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.container.BeanRecipe.internalCreate(BeanRecipe.java:787)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.di.AbstractRecipe$1.call(AbstractRecipe.java:79)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at java.util.concurrent.FutureTask.run(FutureTask.java:266)[:1.8.0_212]{color}
{color:#ce9178}    at org.apache.aries.blueprint.di.AbstractRecipe.create(AbstractRecipe.java:88)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.container.BlueprintRepository.createInstances(BlueprintRepository.java:247)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.container.BlueprintRepository.createInstance(BlueprintRepository.java:230)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.container.BlueprintRepository.create(BlueprintRepository.java:145)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#ce9178}    at org.apache.aries.blueprint.container.BlueprintContainerImpl.getComponentInstance(BlueprintContainerImpl.java:754)[23:org.apache.aries.blueprint.core:1.4.4]{color}
{color:#d4d4d4}    ... {color}{color:#569cd6}39{color}{color:#d4d4d4} more{color}
            Reporter: Adam Ostrožlík


We issued strange behaviour with our OSGI container setup using services - references and injecting services into out beans using @BeanInject

*bundle1*

 

*<!-- Both beans using same AuditStore interface -->*
*<bean id="auditStore" class="store.AuditStoreImpl">
    <property name="jdbcTemplate" ref="jdbcTemplate"/>
    <tx:transaction method="*" value="Required"/>
</bean>
<bean id="auditStoreOut" class="store.AuditStoreOutImpl">
    <property name="jdbcTemplate" ref="jdbcTemplate"/>
    <tx:transaction method="*" value="Required"/>
</bean>*

*<service auto-export="interfaces" ref="auditStore"/>
<service auto-export="interfaces" ref="auditStoreOut"/>*

*bundle2*

 
{code:java}
<reference id="auditStore" component-name="auditStore" interface="eu.unicorn.basse.ms.audit.api.store.AuditStore"/>

<bean class="SomeBean"/>
{code}
*-> injecting reference info bean*
{code:java}
class SomeBean {
   @BeanInject
   AuditStore auditStore;
}
{code}
**From this point, I would expect that OSGI serves only one specific implementation of interface by specifying component-name attribute but it does not. 

As a workaround we managed to inject the reverence using setter or specifing name in @BeanInject annotation - *@BeanInject("auditStore")*

I do not know if this is normal behaviour. Please, check this.

Camel version 2.16.1



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)