]
Oleg Nitz commented on JBAS-4667:
---------------------------------
I wrote a JCA connector for CastorJDO. My ManagedConnection implementation provides
LocalTransaction implementation where LocalTransaction.begin() calls begin() on
Castor's Database object and LocalTransaction.commit() calls Database.commit() and
then sends ConnectionEvent.CONNECTION_CLOSED to ConnectionEventListener. At this point the
transaction is in STATUS_PREPARING state and
CachedConnectionManager.unregisterConnection() does nothing as I described above.
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.0.4.GA, JBossAS-4.2.1.GA
Reporter: Oleg Nitz
Assigned To: Adrian Brock
Fix For: JBossAS-5.0.0.Beta3, JBossAS-4.2.2.GA
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: