HHH-12823 CompositeIdTest.testDistinctCountOfEntityWithCompositeId fails on databases that don't support tuple distinct counts because it expects wrong exception

The SQLGrammarException is now wrapped in a PersistenceException, we
should take that into account.
This commit is contained in:
Martin Simka 2018-07-18 13:37:09 +02:00 committed by Guillaume Smet
parent fd5f5cbe0a
commit 103de8de84
1 changed files with 5 additions and 7 deletions

View File

@ -17,20 +17,18 @@ import java.util.Collections;
import java.util.Iterator; import java.util.Iterator;
import java.util.List; import java.util.List;
import javax.persistence.PersistenceException;
import org.hibernate.Hibernate; import org.hibernate.Hibernate;
import org.hibernate.Session; import org.hibernate.Session;
import org.hibernate.Transaction; import org.hibernate.Transaction;
import org.hibernate.dialect.Oracle8iDialect; import org.hibernate.dialect.Oracle8iDialect;
import org.hibernate.dialect.PostgreSQL9Dialect;
import org.hibernate.dialect.PostgresPlusDialect;
import org.hibernate.dialect.SQLServer2005Dialect;
import org.hibernate.dialect.SQLServerDialect; import org.hibernate.dialect.SQLServerDialect;
import org.hibernate.engine.query.spi.HQLQueryPlan; import org.hibernate.engine.query.spi.HQLQueryPlan;
import org.hibernate.exception.SQLGrammarException; import org.hibernate.exception.SQLGrammarException;
import org.hibernate.hql.spi.QueryTranslator; import org.hibernate.hql.spi.QueryTranslator;
import org.hibernate.testing.SkipForDialect; import org.hibernate.testing.SkipForDialect;
import org.hibernate.testing.SkipForDialects;
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase; import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
import org.junit.Test; import org.junit.Test;
@ -108,12 +106,12 @@ public class CompositeIdTest extends BaseCoreFunctionalTestCase {
try { try {
long count = ( Long ) s.createQuery( "select count(distinct o) FROM Order o" ).uniqueResult(); long count = ( Long ) s.createQuery( "select count(distinct o) FROM Order o" ).uniqueResult();
if ( ! getDialect().supportsTupleDistinctCounts() ) { if ( ! getDialect().supportsTupleDistinctCounts() ) {
fail( "expected SQLGrammarException" ); fail( "expected PersistenceException caused by SQLGrammarException" );
} }
assertEquals( 2l, count ); assertEquals( 2l, count );
} }
catch ( SQLGrammarException e ) { catch ( PersistenceException e ) {
if ( getDialect().supportsTupleDistinctCounts() ) { if ( ! (e.getCause() instanceof SQLGrammarException) || getDialect().supportsTupleDistinctCounts() ) {
throw e; throw e;
} }
} }