[jboss-jira] [JBoss JIRA] Created: (JBAS-5049) NoInitialContextException on deployment of EAR that contains MDB and persistence.xml

Alan Feng (JIRA) jira-events at lists.jboss.org
Tue Dec 4 14:26:11 EST 2007


NoInitialContextException on deployment of EAR that contains MDB and persistence.xml
------------------------------------------------------------------------------------

                 Key: JBAS-5049
                 URL: http://jira.jboss.com/jira/browse/JBAS-5049
             Project: JBoss Application Server
          Issue Type: Bug
      Security Level: Public (Everyone can see)
          Components: Deployment services, EJB3
    Affects Versions: JBossAS-4.2.2.GA
         Environment: Windows XP SP2, JDK1.5.0_09, JBoss AS-4.2.2.GA, SEAM 2.0.0.GA
            Reporter: Alan Feng
         Assigned To: Dimitris Andreadis


When deploy an EAR that contains EJB3 MDB, you may receive NoInitialContextException on the deployment of other EJB3 elements. In my particular case, I have a persistence.xml file that configures the EntityManager. The deployment of this persistence.xml throws the NoInitialContextException. Depending on the contents of the EAR, it may be other deployment unit that is throwing this exception.

Tracing into the deployment code shows that the problem is with the latest code change in the org.jboss.ejb3.EJBContainer class. This class has method named getInitialContext(). In the previous release it returns a newly constructed InitialConext object. In the 4.2.2.GA, it returns the shared static InitialContext object from the InitialContextFactory class. The MDB deployer class org.jboss.ejb3.mdb.MessagingContainer.getJMSProviderAdapter() method calls this method to obtain a InitialContext object and closes this InitialContext object after using it. This results in that the shared InitialContext object been closed prematurely as it is used later on to deploy other EJB3 units, such as the persistence.xml file in my case.

Suggested fix: 
Change the org.jboss.ejb3.mdb.MessagingContainer.getJMSProviderAdapter() method as follows:
Change the line (around line # 586):
      Context context = getInitialContext();
to:
      Context context = initialContextProperties == null ? new InitialContext() : new InitialContext(initialContextProperties);

The above suggested change is copied from the previous implementation of the EJBContainer.getInitialContext() method.

-- 
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators: http://jira.jboss.com/jira/secure/Administrators.jspa
-
For more information on JIRA, see: http://www.atlassian.com/software/jira

        



More information about the jboss-jira mailing list