Resource-based PlatformTransactionManager implementations defensively catch Throwable in doBegin in order to reliably close resource in case of OutOfMemoryError
Issue: SPR-10755
(cherry picked from commit 2e4eb9f
)
This commit is contained in:
parent
8feeec4a60
commit
c1dc4e2c75
|
@ -236,7 +236,7 @@ public class DataSourceTransactionManager extends AbstractPlatformTransactionMan
|
|||
}
|
||||
}
|
||||
|
||||
catch (Exception ex) {
|
||||
catch (Throwable ex) {
|
||||
DataSourceUtils.releaseConnection(con, this.dataSource);
|
||||
throw new CannotCreateTransactionException("Could not open JDBC Connection for transaction", ex);
|
||||
}
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright 2002-2012 the original author or authors.
|
||||
* Copyright 2002-2013 the original author or authors.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
|
@ -191,7 +191,7 @@ public class JmsTransactionManager extends AbstractPlatformTransactionManager
|
|||
TransactionSynchronizationManager.bindResource(
|
||||
getConnectionFactory(), txObject.getResourceHolder());
|
||||
}
|
||||
catch (JMSException ex) {
|
||||
catch (Throwable ex) {
|
||||
if (con != null) {
|
||||
try {
|
||||
con.close();
|
||||
|
|
|
@ -497,7 +497,7 @@ public class HibernateTransactionManager extends AbstractPlatformTransactionMana
|
|||
txObject.getSessionHolder().setSynchronizedWithTransaction(true);
|
||||
}
|
||||
|
||||
catch (Exception ex) {
|
||||
catch (Throwable ex) {
|
||||
if (txObject.isNewSession()) {
|
||||
try {
|
||||
if (session.getTransaction().isActive()) {
|
||||
|
|
|
@ -580,7 +580,7 @@ public class HibernateTransactionManager extends AbstractPlatformTransactionMana
|
|||
txObject.getSessionHolder().setSynchronizedWithTransaction(true);
|
||||
}
|
||||
|
||||
catch (Exception ex) {
|
||||
catch (Throwable ex) {
|
||||
if (txObject.isNewSession()) {
|
||||
try {
|
||||
if (session.getTransaction().isActive()) {
|
||||
|
|
|
@ -365,7 +365,7 @@ public class JdoTransactionManager extends AbstractPlatformTransactionManager
|
|||
closePersistenceManagerAfterFailedBegin(txObject);
|
||||
throw ex;
|
||||
}
|
||||
catch (Exception ex) {
|
||||
catch (Throwable ex) {
|
||||
closePersistenceManagerAfterFailedBegin(txObject);
|
||||
throw new CannotCreateTransactionException("Could not open JDO PersistenceManager for transaction", ex);
|
||||
}
|
||||
|
|
|
@ -423,7 +423,7 @@ public class JpaTransactionManager extends AbstractPlatformTransactionManager
|
|||
closeEntityManagerAfterFailedBegin(txObject);
|
||||
throw ex;
|
||||
}
|
||||
catch (Exception ex) {
|
||||
catch (Throwable ex) {
|
||||
closeEntityManagerAfterFailedBegin(txObject);
|
||||
throw new CannotCreateTransactionException("Could not open JPA EntityManager for transaction", ex);
|
||||
}
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright 2002-2012 the original author or authors.
|
||||
* Copyright 2002-2013 the original author or authors.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
|
@ -29,8 +29,8 @@ import org.springframework.transaction.TransactionException;
|
|||
import org.springframework.transaction.TransactionSystemException;
|
||||
import org.springframework.transaction.support.AbstractPlatformTransactionManager;
|
||||
import org.springframework.transaction.support.DefaultTransactionStatus;
|
||||
import org.springframework.transaction.support.TransactionSynchronizationManager;
|
||||
import org.springframework.transaction.support.ResourceTransactionManager;
|
||||
import org.springframework.transaction.support.TransactionSynchronizationManager;
|
||||
|
||||
/**
|
||||
* {@link org.springframework.transaction.PlatformTransactionManager} implementation
|
||||
|
@ -139,7 +139,6 @@ public class CciLocalTransactionManager extends AbstractPlatformTransactionManag
|
|||
@Override
|
||||
protected void doBegin(Object transaction, TransactionDefinition definition) {
|
||||
CciLocalTransactionObject txObject = (CciLocalTransactionObject) transaction;
|
||||
|
||||
Connection con = null;
|
||||
|
||||
try {
|
||||
|
@ -167,7 +166,7 @@ public class CciLocalTransactionManager extends AbstractPlatformTransactionManag
|
|||
ConnectionFactoryUtils.releaseConnection(con, getConnectionFactory());
|
||||
throw new CannotCreateTransactionException("Could not begin local CCI transaction", ex);
|
||||
}
|
||||
catch (ResourceException ex) {
|
||||
catch (Throwable ex) {
|
||||
ConnectionFactoryUtils.releaseConnection(con, getConnectionFactory());
|
||||
throw new TransactionSystemException("Unexpected failure on begin of CCI local transaction", ex);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue