[jboss-dev] Problem parsing ejb-jar.xml file

Alexey Loubyansky alex at jboss.com
Fri Nov 17 17:12:59 EST 2006


The change is that the deployment descriptors are actually now validated 
against the DTDs.
I was going to write some validating tool in the coming days that would 
go through the DDs in the testsuite, validate them and find the invalid 
ones.

Richard Achmatowicz wrote:
> Dear All
> 
> I am encountering a parsing problem when trying to deploy a jar 
> containing some EJBs. The deployments is part of a test case in the AS 
> testsuite, which has been there for some time. It appears as though the 
> offending file parses correctly under Eclipse (thanks, Clebert).
> 
> Have there been changes which may account for this problem?
> 
> output from AS console:
> -----------------------
> 10:55:20,140 ERROR [EjbParsingDeployer] Error during deployment: 
> jar:file:/home/rachmatowicz/jms-trunk/testsuite/output/lib/jmsra.jar!/
> org.jboss.deployers.spi.DeploymentException: Error parsing meta data 
> META-INF/ejb-jar.xml
>         at 
> org.jboss.deployers.spi.DeploymentException.rethrowAsDeploymentException(DeploymentException.java:49)
>         at 
> org.jboss.deployers.plugins.deployers.helpers.ObjectModelFactoryDeployer.parse(ObjectModelFactoryDeployer.java:87)        
> at 
> org.jboss.deployers.plugins.deployers.helpers.AbstractParsingDeployer.parse(AbstractParsingDeployer.java:145)
>         at 
> org.jboss.deployers.plugins.deployers.helpers.AbstractParsingDeployer.createMetaData(AbstractParsingDeployer.java:112)
>         at 
> org.jboss.deployers.plugins.deployers.helpers.AbstractParsingDeployer.createMetaData(AbstractParsingDeployer.java:88)
>         at 
> org.jboss.deployment.EjbParsingDeployer.deploy(EjbParsingDeployer.java:95)
>         at 
> org.jboss.deployers.plugins.deployer.AbstractSimpleDeployer.commitDeploy(AbstractSimpleDeployer.java:52)
>         at 
> org.jboss.deployers.plugins.deployer.DeployerWrapper.commitDeploy(DeployerWrapper.java:145)
>         at 
> org.jboss.deployers.plugins.deployment.MainDeployerImpl.commitDeploy(MainDeployerImpl.java:440)
>         at 
> org.jboss.deployers.plugins.deployment.MainDeployerImpl.process(MainDeployerImpl.java:381)
>         at org.jboss.deployment.MainDeployer.deploy(MainDeployer.java:795)
>         at org.jboss.deployment.MainDeployer.redeploy(MainDeployer.java:570)
>         at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>         at 
> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
>         at 
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
>         at java.lang.reflect.Method.invoke(Method.java:585)
>         at 
> org.jboss.mx.interceptor.ReflectedDispatcher.invoke(ReflectedDispatcher.java:157)
>         at org.jboss.mx.server.Invocation.dispatch(Invocation.java:96)
>         at org.jboss.mx.server.Invocation.invoke(Invocation.java:88)
>         at 
> org.jboss.mx.server.AbstractMBeanInvoker.invoke(AbstractMBeanInvoker.java:264)
>         at 
> org.jboss.mx.server.MBeanServerImpl.invoke(MBeanServerImpl.java:668)
>         at sun.reflect.GeneratedMethodAccessor117.invoke(Unknown Source)
>         at 
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
>         at java.lang.reflect.Method.invoke(Method.java:585)
>         at 
> org.jboss.jmx.connector.invoker.InvokerAdaptorService.invoke(InvokerAdaptorService.java:266)
>         at sun.reflect.GeneratedMethodAccessor115.invoke(Unknown Source)
>         at 
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
>         at java.lang.reflect.Method.invoke(Method.java:585)
>         at 
> org.jboss.mx.interceptor.ReflectedDispatcher.invoke(ReflectedDispatcher.java:157)
>         at org.jboss.mx.server.Invocation.dispatch(Invocation.java:96)
>         at 
> org.jboss.mx.interceptor.AbstractInterceptor.invoke(AbstractInterceptor.java:138)
>         at org.jboss.mx.server.Invocation.invoke(Invocation.java:90)
>         at 
> org.jboss.mx.interceptor.ModelMBeanOperationInterceptor.invoke(ModelMBeanOperationInterceptor.java:140)
>         at org.jboss.mx.server.Invocation.invoke(Invocation.java:90)
>         at 
> org.jboss.mx.server.AbstractMBeanInvoker.invoke(AbstractMBeanInvoker.java:264)
>         at 
> org.jboss.mx.server.MBeanServerImpl.invoke(MBeanServerImpl.java:668)
>         at 
> org.jboss.invocation.jrmp.server.JRMPProxyFactory.invoke(JRMPProxyFactory.java:179)
>         at sun.reflect.GeneratedMethodAccessor114.invoke(Unknown Source)
>         at 
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
>         at java.lang.reflect.Method.invoke(Method.java:585)
>         at 
> org.jboss.mx.interceptor.ReflectedDispatcher.invoke(ReflectedDispatcher.java:157)
>         at org.jboss.mx.server.Invocation.dispatch(Invocation.java:96)
>         at org.jboss.mx.server.Invocation.invoke(Invocation.java:88)
>         at 
> org.jboss.mx.server.AbstractMBeanInvoker.invoke(AbstractMBeanInvoker.java:264)
>         at 
> org.jboss.mx.server.MBeanServerImpl.invoke(MBeanServerImpl.java:668)
>         at 
> org.jboss.invocation.jrmp.server.JRMPInvoker$MBeanServerAction.invoke(JRMPInvoker.java:816)
>         at 
> org.jboss.invocation.jrmp.server.JRMPInvoker.invoke(JRMPInvoker.java:417)
>         at sun.reflect.GeneratedMethodAccessor113.invoke(Unknown Source)
>         at 
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
>         at java.lang.reflect.Method.invoke(Method.java:585)
>         at 
> sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:294)
>         at sun.rmi.transport.Transport$1.run(Transport.java:153)
>         at java.security.AccessController.doPrivileged(Native Method)
>         at sun.rmi.transport.Transport.serviceCall(Transport.java:149)
>         at 
> sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:466)
>         at 
> sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:707)
>         at java.lang.Thread.run(Thread.java:595)
> Caused by: org.jboss.xb.binding.JBossXBException: Failed to parse 
> source: 
> jar:file:/home/rachmatowicz/jms-trunk/testsuite/output/lib/jmsra.jar!/META-INF/ejb-jar.xml at 44,18
>         at 
> org.jboss.xb.binding.parser.sax.SaxJBossXBParser.parse(SaxJBossXBParser.java:164)
>         at 
> org.jboss.xb.binding.UnmarshallerImpl.unmarshal(UnmarshallerImpl.java:180)
>         at 
> org.jboss.deployers.plugins.deployers.helpers.ObjectModelFactoryDeployer.parse(ObjectModelFactoryDeployer.java:83)        
> ... 55 more
> Caused by: org.xml.sax.SAXException: The content of element type 
> "session" must match 
> "(description?,display-name?,small-icon?,large-icon?,ejb-name,home?,remote?,local-home?,local?,ejb-class,session-type,transaction-type,env-entry*,ejb-ref*,ejb-local-ref*,security-role-ref*,security-identity?,resource-ref*,resource-env-ref*)". 
> @ 
> jar:file:/home/rachmatowicz/jms-trunk/testsuite/output/lib/jmsra.jar!/META-INF/ejb-jar.xml[44,18]
>         at 
> org.jboss.xb.binding.parser.sax.SaxJBossXBParser$MetaDataErrorHandler.error(SaxJBossXBParser.java:348)
>         at org.apache.xerces.util.ErrorHandlerWrapper.error(Unknown Source)
>         at org.apache.xerces.impl.XMLErrorReporter.reportError(Unknown 
> Source)
>         at org.apache.xerces.impl.XMLErrorReporter.reportError(Unknown 
> Source)
>         at 
> org.apache.xerces.impl.dtd.XMLDTDValidator.handleEndElement(Unknown Source)
>         at org.apache.xerces.impl.dtd.XMLDTDValidator.endElement(Unknown 
> Source)
>         at 
> org.apache.xerces.impl.XMLNSDocumentScannerImpl.scanEndElement(Unknown 
> Source)
>         at 
> org.apache.xerces.impl.XMLDocumentFragmentScannerImpl$FragmentContentDispatcher.dispatch(Unknown 
> Source)
>         at 
> org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanDocument(Unknown 
> Source)
>         at org.apache.xerces.parsers.XML11Configuration.parse(Unknown 
> Source)
>         at org.apache.xerces.parsers.XML11Configuration.parse(Unknown 
> Source)
>         at org.apache.xerces.parsers.XMLParser.parse(Unknown Source)
>         at org.apache.xerces.parsers.AbstractSAXParser.parse(Unknown Source)
>         at 
> org.apache.xerces.jaxp.SAXParserImpl$JAXPSAXParser.parse(Unknown Source)
>         at 
> org.jboss.xb.binding.parser.sax.SaxJBossXBParser.parse(SaxJBossXBParser.java:160)
>         ... 57 more
> 
> the ejb-jar.xml file:
> ---------------------
> <?xml version="1.0" encoding="utf-8"?>
> 
> <!DOCTYPE ejb-jar PUBLIC "-//Sun Microsystems, Inc.//DTD Enterprise 
> JavaBeans 2.0//EN" "http://java.sun.com/j2ee/dtds/ejb-ja\r_2_0.dtd">
> 
> <ejb-jar>
>      <description>Queue Publisher</description>
>      <display-name>PublisherBean</display-name>
>      <enterprise-beans>
>        <session>
>           <ejb-name>JMSSession</ejb-name>
>           <home>org.jboss.test.jmsra.bean.JMSSessionHome</home>
>           <remote>org.jboss.test.jmsra.bean.JMSSession</remote>
>           <ejb-class>org.jboss.test.jmsra.bean.JMSSessionBean</ejb-class>
>           <session-type>Stateless</session-type>
>           <transaction-type>Container</transaction-type>
>        </session>
>        <session>
>          <display-name>Publisher</display-name>
>          <ejb-name>QueuePublisher</ejb-name>
>          <home>org.jboss.test.jmsra.bean.PublisherHome</home>
>          <remote>org.jboss.test.jmsra.bean.Publisher</remote>
>          <ejb-class>org.jboss.test.jmsra.bean.PublisherBean</ejb-class>
>          <session-type>Stateless</session-type>
>          <transaction-type>Container</transaction-type>
>          <resource-ref>
>             <description>A Queue ConnectionFactory</description>
>             <res-ref-name>jms/MyQueueConnection</res-ref-name>
>             <res-type>javax.jms.QueueConnectionFactory</res-type>
>             <res-auth>Container</res-auth>
>          </resource-ref>
>          <resource-ref>
>             <description>A Queue </description>
>             <res-ref-name>jms/QueueName</res-ref-name>
>             <res-type>javax.jms.Queue</res-type>
>             <res-auth>Container</res-auth>
>          </resource-ref>
>           <ejb-ref>
>            <ejb-ref-name>ejb/PublisherCMP</ejb-ref-name>
>            <ejb-ref-type>Entity</ejb-ref-type>
>            <home>org.jboss.test.jmsra.bean.PublisherCMPHome</home>
>            <remote>org.jboss.test.jmsra.bean.PublisherCMP</remote>
>            <ejb-link>PublisherCMP</ejb-link>
>          </ejb-ref>
>        </session>
>        <session>
>          <display-name>TopicPublisher</display-name>
>          <ejb-name>TopicPublisher</ejb-name>
>          <home>org.jboss.test.jmsra.bean.PublisherHome</home>
>          <remote>org.jboss.test.jmsra.bean.Publisher</remote>
>          <ejb-class>org.jboss.test.jmsra.bean.TopicPublisherBean</ejb-class>
>          <session-type>Stateless</session-type>
>          <transaction-type>Container</transaction-type>
>          <resource-ref>
>             <description>A Topic ConnectionFactory</description>
>             <res-ref-name>jms/MyTopicConnection</res-ref-name>
>             <res-type>javax.jms.TopicConnectionFactory</res-type>
>             <res-auth>Container</res-auth>
>          </resource-ref>
>          <resource-ref>
>             <description>A Topic </description>
>             <res-ref-name>jms/TopicName</res-ref-name>
>             <res-type>javax.jms.Topic</res-type>
>             <res-auth>Container</res-auth>
>          </resource-ref>
>           <ejb-ref>
>            <ejb-ref-name>ejb/PublisherCMP</ejb-ref-name>
>            <ejb-ref-type>Entity</ejb-ref-type>
>            <home>org.jboss.test.jmsra.bean.PublisherCMPHome</home>
>            <remote>org.jboss.test.jmsra.bean.PublisherCMP</remote>
>            <ejb-link>PublisherCMP</ejb-link>
>          </ejb-ref>
>        </session>
>        <session>
>          <display-name>QueueRec</display-name>
>          <ejb-name>QueueRec</ejb-name>
>          <home>org.jboss.test.jmsra.bean.QueueRecHome</home>
>          <remote>org.jboss.test.jmsra.bean.QueueRec</remote>
>          <ejb-class>org.jboss.test.jmsra.bean.QueueRecBean</ejb-class>
>          <session-type>Stateless</session-type>
>          <transaction-type>Container</transaction-type>
>          <resource-ref>
>             <description>A Queue ConnectionFactory</description>
>             <res-ref-name>jms/MyQueueConnection</res-ref-name>
>             <res-type>javax.jms.QueueConnectionFactory</res-type>
>             <res-auth>Container</res-auth>
>          </resource-ref>
>          <resource-ref>
>             <description>A Queue </description>
>             <res-ref-name>jms/QueueName</res-ref-name>
>             <res-type>javax.jms.Queue</res-type>
>             <res-auth>Container</res-auth>
>          </resource-ref>
>        </session>
>        <entity>
>          <display-name>Publisher Entity</display-name>
>          <ejb-name>PublisherCMP</ejb-name>
>          <home>org.jboss.test.jmsra.bean.PublisherCMPHome</home>
>          <remote>org.jboss.test.jmsra.bean.PublisherCMP</remote>
>          <ejb-class>org.jboss.test.jmsra.bean.PublisherCMPBean</ejb-class>
>          <persistence-type>Container</persistence-type>
>          <prim-key-class>java.lang.Integer</prim-key-class>
>          <reentrant>True</reentrant>
>          <cmp-version>1.x</cmp-version>
>          <cmp-field>
>            <description>Nr</description>
>            <field-name>nr</field-name>
>          </cmp-field>
>          <primkey-field>nr</primkey-field>
>        </entity>
>        <message-driven>
>         <ejb-name>TopicAdapter</ejb-name>
>         <ejb-class>org.jboss.test.jmsra.bean.TopicAdapter</ejb-class>
>         <message-selector></message-selector>
>         <transaction-type>Container</transaction-type>
>         <message-driven-destination>
>             <destination-type>javax.jms.Topic</destination-type>
>             <subscription-durability>NonDurable</subscription-durability>
>         </message-driven-destination>
>         <resource-ref>
>             <description>A Queue ConnectionFactory</description>
>             <res-ref-name>jms/MyQueueConnection</res-ref-name>
>             <res-type>javax.jms.QueueConnectionFactory</res-type>
>             <res-auth>Container</res-auth>
>         </resource-ref>
>         <resource-ref>
>             <description>A Queue </description>
>             <res-ref-name>jms/QueueName</res-ref-name>
>             <res-type>javax.jms.Queue</res-type>
>             <res-auth>Container</res-auth>
>         </resource-ref>
>       </message-driven>
>      </enterprise-beans>
>      <assembly-descriptor>
>        <container-transaction>
>          <method>
>            <ejb-name>TopicAdapter</ejb-name>
>            <method-name>*</method-name>
>          </method>
>          <trans-attribute>Required</trans-attribute>
>        </container-transaction>
>      </assembly-descriptor>
>    </ejb-jar>
> 
> 
> 
> 
> ------------------------------------------------------------------------
> 
> _______________________________________________
> jboss-development mailing list
> jboss-development at lists.jboss.org
> https://lists.jboss.org/mailman/listinfo/jboss-development



More information about the jboss-development mailing list