HHH-8786 - find, refresh, lock should throw LockTimeoutException or PessimisticLockException when lock problems occur

This commit is contained in:
Steve Ebersole 2018-04-27 09:41:44 -05:00
parent f7aef1cdf8
commit c6dc398fc5
2 changed files with 10 additions and 1 deletions

View File

@ -14,8 +14,11 @@ import javax.persistence.PessimisticLockException;
import org.hibernate.LockOptions; import org.hibernate.LockOptions;
import org.hibernate.cfg.AvailableSettings; import org.hibernate.cfg.AvailableSettings;
import org.hibernate.cfg.Configuration; import org.hibernate.cfg.Configuration;
import org.hibernate.dialect.MariaDBDialect;
import org.hibernate.dialect.SQLServerDialect; import org.hibernate.dialect.SQLServerDialect;
import org.hibernate.testing.SkipForDialect;
import org.hibernate.testing.SkipForDialects;
import org.hibernate.testing.TestForIssue; import org.hibernate.testing.TestForIssue;
import org.hibernate.testing.jdbc.SQLServerSnapshotIsolationConnectionProvider; import org.hibernate.testing.jdbc.SQLServerSnapshotIsolationConnectionProvider;
import org.hibernate.testing.transaction.TransactionUtil2; import org.hibernate.testing.transaction.TransactionUtil2;
@ -28,6 +31,9 @@ import static org.junit.Assert.fail;
/** /**
* @author Steve Ebersole * @author Steve Ebersole
*/ */
@SkipForDialects(
@SkipForDialect( value = MariaDBDialect.class, jiraKey = "HHH-8786", comment = "https://hibernate.atlassian.net/browse/HHH-8786")
)
public class LockExceptionTests extends AbstractJPATest { public class LockExceptionTests extends AbstractJPATest {
@Override @Override
public void configure(Configuration cfg) { public void configure(Configuration cfg) {

View File

@ -4330,7 +4330,10 @@ public class FooBarTest extends LegacyTestCase {
); );
s.refresh(foo); s.refresh(foo);
assertEquals( Long.valueOf( -3l ), foo.getLong() ); assertEquals( Long.valueOf( -3l ), foo.getLong() );
assertEquals( LockMode.READ, s.getCurrentLockMode( foo ) ); // NOTE : this test used to test for LockMode.READ here, but that actually highlights a bug
// `foo` has just been inserted and then updated in this same Session - its lock mode
// therefore ought to be WRITE. See https://hibernate.atlassian.net/browse/HHH-12257
assertEquals( LockMode.WRITE, s.getCurrentLockMode( foo ) );
s.refresh(foo, LockMode.UPGRADE); s.refresh(foo, LockMode.UPGRADE);
if ( getDialect().supportsOuterJoinForUpdate() ) { if ( getDialect().supportsOuterJoinForUpdate() ) {
assertEquals( LockMode.UPGRADE, s.getCurrentLockMode( foo ) ); assertEquals( LockMode.UPGRADE, s.getCurrentLockMode( foo ) );