[jboss-jira] [JBoss JIRA] Created: (JBAS-4667) Wrong logic in CachedConnectionManager.getCloseConnectionSynchronization()

Oleg Nitz (JIRA) jira-events at lists.jboss.org
Tue Sep 4 11:45:11 EDT 2007


Wrong logic in CachedConnectionManager.getCloseConnectionSynchronization()
--------------------------------------------------------------------------

                 Key: JBAS-4667
                 URL: http://jira.jboss.com/jira/browse/JBAS-4667
             Project: JBoss Application Server
          Issue Type: Bug
      Security Level: Public (Everyone can see)
          Components: JCA service
    Affects Versions: JBossAS-4.2.1.GA, JBossAS-4.0.4.GA
            Reporter: Oleg Nitz


If the tx is not active (for example it has STATUS_PREPARING), then the method always returns null, even if the associated CloseConnectionSynchronization exists.
This results in wrong warnings about non-closed connections, since when the close() is called for a connector, in CachedConnectionManager.unregisterConnection() a null value is returned from getCloseConnectionSynchronization() and the connector remains in the list of non-closed resources for the transaction.
I think this bug was introduced here: http://jira.jboss.com/jira/browse/JBAS-31#action_12310798
I propose the following solution:

--- CachedConnectionManager.java.orig	2005-11-22 02:10:41.000000000 +0200
+++ CachedConnectionManager.java	2007-09-04 18:42:48.000000000 +0300
@@ -544,13 +544,13 @@
       try
       {
          Transaction tx = tm.getTransaction();
-         if (TxUtils.isActive(tx))
+         if (tx != null)
          {
             TransactionSynchronizer.lock(tx);
             try
             {
                CloseConnectionSynchronization cas = (CloseConnectionSynchronization) TransactionSynchronizer.getCCMSynchronization(tx);
-               if (cas == null && createIfNotFound)
+               if (cas == null && createIfNotFound && TxUtils.isActive(tx))
                {
                   cas = new CloseConnectionSynchronization();
                   TransactionSynchronizer.registerCCMSynchronization(tx, cas);


-- 
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