Jpa/JdoTransactionManager passes resolved timeout into Jpa/JdoDialect's beginTransaction; HibernateJpaDialect applies timeout onto native Hibernate Transaction before begin call (SPR-5195)
This commit is contained in:
@@ -35,6 +35,7 @@ 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.DelegatingTransactionDefinition;
|
||||
import org.springframework.transaction.support.ResourceTransactionManager;
|
||||
import org.springframework.transaction.support.TransactionSynchronizationManager;
|
||||
|
||||
@@ -299,7 +300,7 @@ public class JdoTransactionManager extends AbstractPlatformTransactionManager
|
||||
"on a single DataSource, no matter whether JDO or JDBC access.");
|
||||
}
|
||||
|
||||
PersistenceManager pm = null;
|
||||
PersistenceManager pm;
|
||||
|
||||
try {
|
||||
if (txObject.getPersistenceManagerHolder() == null ||
|
||||
@@ -314,13 +315,19 @@ public class JdoTransactionManager extends AbstractPlatformTransactionManager
|
||||
pm = txObject.getPersistenceManagerHolder().getPersistenceManager();
|
||||
|
||||
// Delegate to JdoDialect for actual transaction begin.
|
||||
Object transactionData = getJdoDialect().beginTransaction(pm.currentTransaction(), definition);
|
||||
final int timeoutToUse = determineTimeout(definition);
|
||||
Object transactionData = getJdoDialect().beginTransaction(pm.currentTransaction(),
|
||||
new DelegatingTransactionDefinition(definition) {
|
||||
@Override
|
||||
public int getTimeout() {
|
||||
return timeoutToUse;
|
||||
}
|
||||
});
|
||||
txObject.setTransactionData(transactionData);
|
||||
|
||||
// Register transaction timeout.
|
||||
int timeout = determineTimeout(definition);
|
||||
if (timeout != TransactionDefinition.TIMEOUT_DEFAULT) {
|
||||
txObject.getPersistenceManagerHolder().setTimeoutInSeconds(timeout);
|
||||
if (timeoutToUse != TransactionDefinition.TIMEOUT_DEFAULT) {
|
||||
txObject.getPersistenceManagerHolder().setTimeoutInSeconds(timeoutToUse);
|
||||
}
|
||||
|
||||
// Register the JDO PersistenceManager's JDBC Connection for the DataSource, if set.
|
||||
@@ -328,8 +335,8 @@ public class JdoTransactionManager extends AbstractPlatformTransactionManager
|
||||
ConnectionHandle conHandle = getJdoDialect().getJdbcConnection(pm, definition.isReadOnly());
|
||||
if (conHandle != null) {
|
||||
ConnectionHolder conHolder = new ConnectionHolder(conHandle);
|
||||
if (timeout != TransactionDefinition.TIMEOUT_DEFAULT) {
|
||||
conHolder.setTimeoutInSeconds(timeout);
|
||||
if (timeoutToUse != TransactionDefinition.TIMEOUT_DEFAULT) {
|
||||
conHolder.setTimeoutInSeconds(timeoutToUse);
|
||||
}
|
||||
if (logger.isDebugEnabled()) {
|
||||
logger.debug("Exposing JDO transaction as JDBC transaction [" + conHolder.getConnectionHandle() + "]");
|
||||
|
||||
@@ -42,6 +42,7 @@ 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.DelegatingTransactionDefinition;
|
||||
import org.springframework.transaction.support.ResourceTransactionManager;
|
||||
import org.springframework.transaction.support.TransactionSynchronizationManager;
|
||||
import org.springframework.util.CollectionUtils;
|
||||
@@ -327,13 +328,19 @@ public class JpaTransactionManager extends AbstractPlatformTransactionManager
|
||||
EntityManager em = txObject.getEntityManagerHolder().getEntityManager();
|
||||
|
||||
// Delegate to JpaDialect for actual transaction begin.
|
||||
Object transactionData = getJpaDialect().beginTransaction(em, definition);
|
||||
final int timeoutToUse = determineTimeout(definition);
|
||||
Object transactionData = getJpaDialect().beginTransaction(em,
|
||||
new DelegatingTransactionDefinition(definition) {
|
||||
@Override
|
||||
public int getTimeout() {
|
||||
return timeoutToUse;
|
||||
}
|
||||
});
|
||||
txObject.setTransactionData(transactionData);
|
||||
|
||||
// Register transaction timeout.
|
||||
int timeout = determineTimeout(definition);
|
||||
if (timeout != TransactionDefinition.TIMEOUT_DEFAULT) {
|
||||
txObject.getEntityManagerHolder().setTimeoutInSeconds(timeout);
|
||||
if (timeoutToUse != TransactionDefinition.TIMEOUT_DEFAULT) {
|
||||
txObject.getEntityManagerHolder().setTimeoutInSeconds(timeoutToUse);
|
||||
}
|
||||
|
||||
// Register the JPA EntityManager's JDBC Connection for the DataSource, if set.
|
||||
@@ -341,8 +348,8 @@ public class JpaTransactionManager extends AbstractPlatformTransactionManager
|
||||
ConnectionHandle conHandle = getJpaDialect().getJdbcConnection(em, definition.isReadOnly());
|
||||
if (conHandle != null) {
|
||||
ConnectionHolder conHolder = new ConnectionHolder(conHandle);
|
||||
if (timeout != TransactionDefinition.TIMEOUT_DEFAULT) {
|
||||
conHolder.setTimeoutInSeconds(timeout);
|
||||
if (timeoutToUse != TransactionDefinition.TIMEOUT_DEFAULT) {
|
||||
conHolder.setTimeoutInSeconds(timeoutToUse);
|
||||
}
|
||||
if (logger.isDebugEnabled()) {
|
||||
logger.debug("Exposing JPA transaction as JDBC transaction [" + conHolder.getConnectionHandle() + "]");
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2002-2008 the original author or authors.
|
||||
* Copyright 2002-2009 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.
|
||||
@@ -18,7 +18,6 @@ package org.springframework.orm.jpa.vendor;
|
||||
|
||||
import java.sql.Connection;
|
||||
import java.sql.SQLException;
|
||||
|
||||
import javax.persistence.EntityManager;
|
||||
import javax.persistence.PersistenceException;
|
||||
|
||||
@@ -38,7 +37,7 @@ import org.springframework.transaction.TransactionException;
|
||||
|
||||
/**
|
||||
* {@link org.springframework.orm.jpa.JpaDialect} implementation for
|
||||
* Hibernate EntityManager. Developed and tested against Hibernate 3.2.
|
||||
* Hibernate EntityManager. Developed and tested against Hibernate 3.3.
|
||||
*
|
||||
* @author Costin Leau
|
||||
* @author Juergen Hoeller
|
||||
@@ -50,6 +49,9 @@ public class HibernateJpaDialect extends DefaultJpaDialect {
|
||||
public Object beginTransaction(EntityManager entityManager, TransactionDefinition definition)
|
||||
throws PersistenceException, SQLException, TransactionException {
|
||||
|
||||
if (definition.getTimeout() != TransactionDefinition.TIMEOUT_DEFAULT) {
|
||||
getSession(entityManager).getTransaction().setTimeout(definition.getTimeout());
|
||||
}
|
||||
super.beginTransaction(entityManager, definition);
|
||||
return prepareTransaction(entityManager, definition.isReadOnly(), definition.getName());
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user