[JBoss Web Services Development] - Recent changes on CXF integration
by Alessio Soldano
Alessio Soldano [http://community.jboss.org/people/alessio.soldano%40jboss.com] created the discussion
"Recent changes on CXF integration"
To view the discussion, visit: http://community.jboss.org/message/535401#535401
--------------------------------------------------------------
Folks,
due to the requirements for https://jira.jboss.org/jira/browse/JBWS-2971 https://jira.jboss.org/jira/browse/JBWS-2971 , I had to review a bit the current cxf stack integration.
Basically, we used to depend on CXFServlet triggering the Bus creation and have the servlet's loadBus method overwritten to also load our additional beans from jboss-cxf.xml.
This recently turned up to be a problem as the CXF Bus creation needs to happen at deploy time for some kind of operation to be possible; JBWS-2971 is an example, but more generally, depending on a servlet only for the bus creation is wrong (think about JMS endpoints, https://jira.jboss.org/jira/browse/JBWS-2987 https://jira.jboss.org/jira/browse/JBWS-2987).
So, first of all I added a deployment aspect in the jbws-cxf stack for eagerly parsing the cxf.xml and our (provided or generated) jboss-cxf.xml into a Bus during deployment ( https://jira.jboss.org/jira/browse/JBWS-2974 https://jira.jboss.org/jira/browse/JBWS-2974). The Bus is then attached to the endpoint and the CXFServletExt checks it's already available before trying creating it.
An interesting question now is whether we want this to be the default behaviour or not. Currently there's a system property for choosing when to load the bus, the default is lazy behaviour (load in servlet). Anyway, a decision on this might also be related to how we properly review and fix the jms integration with cxf stack ( https://jira.jboss.org/jira/browse/JBWS-2987 https://jira.jboss.org/jira/browse/JBWS-2987).
Besides this, it's probably interesting to note that for fixing JBWS-2971 I started using another integration hook, ie. the Spring NamespaceHandlerSupport configuration. As you know, we're generating the jboss-cxf.xml file at deploy time and basically leveraging the spring configuration of CXF (in order to allow both stack agnostic deployments and cxf specific deployments to work seamlessly).
CXF has spring.handler configuration files that map namespaces for elements in the spring xml to default beans. We're now using a custom mapping for the jaxws.endpoint elements, which in the end allows us to overwrite the CXF org.apache.cxf.jaxws.EndpointImpl giving us control over the endpoint start/stop/publish/etc. while still delegating to the CXF one for the core processing.
Generally speaking, customizing the spring namespace handler configuration for loading different bean parsers is a powerful integration hook, to be considered in addition to the already used setup of CXF Configurer in the Bus.
--------------------------------------------------------------
Reply to this message by going to Community
[http://community.jboss.org/message/535401#535401]
Start a new discussion in JBoss Web Services Development at Community
[http://community.jboss.org/choose-container!input.jspa?contentType=1&cont...]
14 years, 9 months
[EJB 3.0 Development] - Wrong JNDI context returned from EJB
by Richard Opalka
Richard Opalka [http://community.jboss.org/people/richard.opalka%40jboss.com] created the discussion
"Wrong JNDI context returned from EJB"
To view the discussion, visit: http://community.jboss.org/message/535366#535366
--------------------------------------------------------------
Hi EJB team,
This is related to issue: https://jira.jboss.org/jira/browse/JBAS-7888 https://jira.jboss.org/jira/browse/JBAS-7888
I'm analyzing this failure:
http://jbossws.jboss.org:8180/hudson/job/AS-TESTS-AS-6.0.1/113/testReport/ http://jbossws.jboss.org:8180/hudson/job/AS-TESTS-AS-6.0.1/113/testReport/
To reproduce the problem, just type:
cd jbossas/trunk/testsuite
./build.sh clean main
./build.sh -Dtest=org.jboss.test.ws.jaxws.ejb3Integration.injection.InjectionTestCase one-test
I found it started to fail since:
http://jbossws.jboss.org:8180/hudson/job/AS-6.0.1/109/ http://jbossws.jboss.org:8180/hudson/job/AS-6.0.1/109/
I think it might be related to:
https://jira.jboss.org/jira/browse/JBAS-7854 https://jira.jboss.org/jira/browse/JBAS-7854
Here are my investigations:
Our archive structure is:
jbossas/trunk/testsuite/output/lib]>jar -tvf jaxws-injection.ear
0 Fri Apr 02 12:20:46 CEST 2010 META-INF/
102 Fri Apr 02 12:20:44 CEST 2010 META-INF/MANIFEST.MF
602 Fri Apr 02 12:20:46 CEST 2010 META-INF/application.xml
7367 Fri Apr 02 12:20:46 CEST 2010 jaxws-injection-ejb3.jar
9000 Fri Apr 02 12:20:46 CEST 2010 jaxws-injection-pojo.war
2323 Fri Apr 02 13:54:46 CEST 2010 jaxws-injection.jar
Relevant JNDI trees are (from JMX console):
java:comp namespace of the component jboss.j2ee:ear=jaxws-injection.ear,jar=jaxws-injection.jar,name=BeanImpl,service=EJB3 :
+- EJBContext (class: javax.ejb.EJBContext)
+- TransactionSynchronizationRegistry[link -> java:TransactionSynchronizationRegistry] (class: javax.naming.LinkRef)
+- UserTransaction (class: org.jboss.ejb3.tx.UserTransactionImpl)
+- env (class: org.jnp.interfaces.NamingContext)
+- ORB[link -> java:/JBossCorbaORB] (class: javax.naming.LinkRef)
java:comp namespace of the component jboss.j2ee:ear=jaxws-injection.ear,jar=jaxws-injection-ejb3.jar,name=EJB3Bean,service=EJB3 :
+- EJBContext (class: javax.ejb.EJBContext)
+- TransactionSynchronizationRegistry[link -> java:TransactionSynchronizationRegistry] (class: javax.naming.LinkRef)
+- UserTransaction (class: org.jboss.ejb3.tx.UserTransactionImpl)
+- env (class: org.jnp.interfaces.NamingContext)
| +- org.jboss.test.ws.jaxws.ejb3Integration.injection.webservice.AbstractEndpointImpl (class: org.jnp.interfaces.NamingContext)
| | +- testBean2[link -> jaxws-injection/BeanImpl/local-org.jboss.test.ws.jaxws.ejb3Integration.injection.shared.BeanIface] (class: javax.naming.LinkRef)
| | +- bean[link -> jaxws-injection/BeanImpl/local-org.jboss.test.ws.jaxws.ejb3Integration.injection.shared.BeanIface] (class: javax.naming.LinkRef)
| +- boolean1 (class: java.lang.Boolean)
+- ORB[link -> java:/JBossCorbaORB] (class: javax.naming.LinkRef)
In our JBossWS AS Integration layer we're lookuping the JNDI context as:
public Context getJNDIContext(final Endpoint ep) throws NamingException
{
final EJBContainer ejb3Container = (EJBContainer)getEjb3Container("jboss.j2ee:ear=jaxws-injection.ear,jar=jaxws-injection-ejb3.jar,name=EJB3Bean,service=EJB3");
return (Context)ejb3Container.getEnc().lookup("java:env/");
}
This call used to return proper JNDI tree associated with
jboss.j2ee:ear=jaxws-injection.ear,jar=jaxws-injection-ejb3.jar,name=EJB3Bean,service=EJB3.
Unfortunately these days in AS trunk it returns the JNDI tree associated with
jboss.j2ee:ear=jaxws-injection.ear,jar=jaxws-injection.jar,name=BeanImpl,service=EJB3
IMHO this is a bug in EJB code base.
--------------------------------------------------------------
Reply to this message by going to Community
[http://community.jboss.org/message/535366#535366]
Start a new discussion in EJB 3.0 Development at Community
[http://community.jboss.org/choose-container!input.jspa?contentType=1&cont...]
14 years, 9 months