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)