Joseph Kampf created CAMEL-9422:
-----------------------------------
Summary: ServiceFactory of Cxf Endpoint is not working
Key: CAMEL-9422
URL: https://issues.apache.org/jira/browse/CAMEL-9422
Project: Camel
Issue Type: Bug
Components: camel-cxf
Environment: karaf 3.0.2
Reporter: Joseph Kampf
I attempted to explicitly set the Service Factory as per the documentation
found at: http://cxf.apache.org/docs/jax-ws-configuration.html.
{code:xml}
<cxf:cxfEndpoint id="cxfBeanFromEndpoint"
address="${esbservices.proxy.baseurl}/path"
serviceClass="MyPortClass"
endpointName="s:completePort" serviceName="s:aria_complete_api"
wsdlURL="MyWsdl.wsdl"
xmlns:s="myNamespace">
<cxf:inInterceptors>
<bean
class="org.apache.cxf.interceptor.LoggingInInterceptor" />
</cxf:inInterceptors>
<cxf:outInterceptors>
<bean
class="org.apache.cxf.interceptor.LoggingOutInterceptor" />
</cxf:outInterceptors>
<cxf:serviceFactory>
<bean
class="org.apache.cxf.jaxws.JaxWsServerFactoryBean" />
</cxf:serviceFactory>
</cxf:cxfEndpoint>
{code}
When I deploy the bundle I get:
{code}
karaf@root()> Exception in thread "SpringOsgiExtenderThread-50"
org.apache.camel.RuntimeCamelException:
org.apache.camel.FailedToCreateRouteException: Failed to create route
aria.esbservices.complete.soap.proxy:
Route(aria.esbservices.complete.soap.proxy)[[From[cxf:bean:a... because of
Failed to resolve endpoint: cxf://bean:cxfBeanFromEndpoint due to: Cannot
lookup: cxfBeanFromEndpoint from registry:
org.apache.camel.spring.spi.ApplicationContextRegistry@51cb33dc with expected
type: class org.apache.camel.component.cxf.CxfEndpoint due: Error creating bean
with name 'cxfBeanFromEndpoint': Error setting property values; nested
exception is org.springframework.beans.NotWritablePropertyException: Invalid
property 'serviceFactory' of bean class
[org.apache.camel.component.cxf.CxfSpringEndpoint]: Bean property
'serviceFactory' is not writable or has an invalid setter method. Does the
parameter type of the setter match the return type of the getter?
at
org.apache.camel.util.ObjectHelper.wrapRuntimeCamelException(ObjectHelper.java:1363)
at
org.apache.camel.spring.SpringCamelContext.onApplicationEvent(SpringCamelContext.java:122)
at
org.apache.camel.spring.CamelContextFactoryBean.onApplicationEvent(CamelContextFactoryBean.java:318)
at
org.springframework.context.event.SimpleApplicationEventMulticaster.multicastEvent(SimpleApplicationEventMulticaster.java:96)
at
org.springframework.context.support.AbstractApplicationContext.publishEvent(AbstractApplicationContext.java:334)
at
org.springframework.context.support.AbstractApplicationContext.finishRefresh(AbstractApplicationContext.java:950)
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:132)
at java.lang.Thread.run(Thread.java:745)
Caused by: org.apache.camel.FailedToCreateRouteException: Failed to create
route aria.esbservices.complete.soap.proxy:
Route(aria.esbservices.complete.soap.proxy)[[From[cxf:bean:a... because of
Failed to resolve endpoint: cxf://bean:cxfBeanFromEndpoint due to: Cannot
lookup: cxfBeanFromEndpoint from registry:
org.apache.camel.spring.spi.ApplicationContextRegistry@51cb33dc with expected
type: class org.apache.camel.component.cxf.CxfEndpoint due: Error creating bean
with name 'cxfBeanFromEndpoint': Error setting property values; nested
exception is org.springframework.beans.NotWritablePropertyException: Invalid
property 'serviceFactory' of bean class
[org.apache.camel.component.cxf.CxfSpringEndpoint]: Bean property
'serviceFactory' is not writable or has an invalid setter method. Does the
parameter type of the setter match the return type of the getter?
at
org.apache.camel.model.RouteDefinition.addRoutes(RouteDefinition.java:180)
at
org.apache.camel.impl.DefaultCamelContext.startRoute(DefaultCamelContext.java:780)
at
org.apache.camel.impl.DefaultCamelContext.startRouteDefinitions(DefaultCamelContext.java:2068)
at
org.apache.camel.impl.DefaultCamelContext.doStartCamel(DefaultCamelContext.java:1816)
at
org.apache.camel.impl.DefaultCamelContext.doStart(DefaultCamelContext.java:1683)
at org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
at
org.apache.camel.impl.DefaultCamelContext.start(DefaultCamelContext.java:1651)
at
org.apache.camel.spring.SpringCamelContext.maybeStart(SpringCamelContext.java:254)
at
org.apache.camel.spring.SpringCamelContext.onApplicationEvent(SpringCamelContext.java:120)
... 10 more
Caused by: org.apache.camel.ResolveEndpointFailedException: Failed to resolve
endpoint: cxf://bean:cxfBeanFromEndpoint due to: Cannot lookup:
cxfBeanFromEndpoint from registry:
org.apache.camel.spring.spi.ApplicationContextRegistry@51cb33dc with expected
type: class org.apache.camel.component.cxf.CxfEndpoint due: Error creating bean
with name 'cxfBeanFromEndpoint': Error setting property values; nested
exception is org.springframework.beans.NotWritablePropertyException: Invalid
property 'serviceFactory' of bean class
[org.apache.camel.component.cxf.CxfSpringEndpoint]: Bean property
'serviceFactory' is not writable or has an invalid setter method. Does the
parameter type of the setter match the return type of the getter?
at
org.apache.camel.impl.DefaultCamelContext.getEndpoint(DefaultCamelContext.java:534)
at
org.apache.camel.util.CamelContextHelper.getMandatoryEndpoint(CamelContextHelper.java:71)
at
org.apache.camel.model.RouteDefinition.resolveEndpoint(RouteDefinition.java:190)
at
org.apache.camel.impl.DefaultRouteContext.resolveEndpoint(DefaultRouteContext.java:106)
at
org.apache.camel.impl.DefaultRouteContext.resolveEndpoint(DefaultRouteContext.java:112)
at
org.apache.camel.model.FromDefinition.resolveEndpoint(FromDefinition.java:72)
at
org.apache.camel.impl.DefaultRouteContext.getEndpoint(DefaultRouteContext.java:88)
at
org.apache.camel.model.RouteDefinition.addRoutes(RouteDefinition.java:888)
at
org.apache.camel.model.RouteDefinition.addRoutes(RouteDefinition.java:175)
... 18 more
Caused by: org.apache.camel.NoSuchBeanException: Cannot lookup:
cxfBeanFromEndpoint from registry:
org.apache.camel.spring.spi.ApplicationContextRegistry@51cb33dc with expected
type: class org.apache.camel.component.cxf.CxfEndpoint due: Error creating bean
with name 'cxfBeanFromEndpoint': Error setting property values; nested
exception is org.springframework.beans.NotWritablePropertyException: Invalid
property 'serviceFactory' of bean class
[org.apache.camel.component.cxf.CxfSpringEndpoint]: Bean property
'serviceFactory' is not writable or has an invalid setter method. Does the
parameter type of the setter match the return type of the getter?
at
org.apache.camel.impl.CompositeRegistry.lookupByNameAndType(CompositeRegistry.java:62)
at
org.apache.camel.impl.PropertyPlaceholderDelegateRegistry.lookupByNameAndType(PropertyPlaceholderDelegateRegistry.java:63)
at
org.apache.camel.util.CamelContextHelper.lookup(CamelContextHelper.java:129)
at
org.apache.camel.util.CamelContextHelper.mandatoryLookup(CamelContextHelper.java:149)
at
org.apache.camel.component.cxf.CxfComponent.createEndpoint(CxfComponent.java:70)
at
org.apache.camel.impl.DefaultComponent.createEndpoint(DefaultComponent.java:123)
at
org.apache.camel.impl.DefaultCamelContext.getEndpoint(DefaultCamelContext.java:514)
... 26 more
Caused by: org.springframework.beans.factory.BeanCreationException: Error
creating bean with name 'cxfBeanFromEndpoint': Error setting property values;
nested exception is org.springframework.beans.NotWritablePropertyException:
Invalid property 'serviceFactory' of bean class
[org.apache.camel.component.cxf.CxfSpringEndpoint]: Bean property
'serviceFactory' is not writable or has an invalid setter method. Does the
parameter type of the setter match the return type of the getter?
at
org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:1455)
at
org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1160)
at
org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)
at
org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:458)
at
org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:312)
at
org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:195)
at
org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:1123)
at
org.apache.camel.spring.spi.ApplicationContextRegistry.lookupByNameAndType(ApplicationContextRegistry.java:47)
at
org.apache.camel.impl.CompositeRegistry.lookupByNameAndType(CompositeRegistry.java:56)
... 32 more
Caused by: org.springframework.beans.NotWritablePropertyException: Invalid
property 'serviceFactory' of bean class
[org.apache.camel.component.cxf.CxfSpringEndpoint]: Bean property
'serviceFactory' is not writable or has an invalid setter method. Does the
parameter type of the setter match the return type of the getter?
at
org.springframework.beans.BeanWrapperImpl.setPropertyValue(BeanWrapperImpl.java:1044)
at
org.springframework.beans.BeanWrapperImpl.setPropertyValue(BeanWrapperImpl.java:904)
at
org.springframework.beans.AbstractPropertyAccessor.setPropertyValues(AbstractPropertyAccessor.java:75)
at
org.springframework.beans.AbstractPropertyAccessor.setPropertyValues(AbstractPropertyAccessor.java:57)
at
org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:1452)
... 40 more
{code}
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)