HHH-6702 mysql test failures
This commit is contained in:
parent
a34c99a34c
commit
e4480f905c
|
@ -57,6 +57,7 @@ public enum LockMode {
|
|||
*
|
||||
* @deprecated instead use PESSIMISTIC_WRITE
|
||||
*/
|
||||
@Deprecated
|
||||
UPGRADE( 10 ),
|
||||
/**
|
||||
* Attempt to obtain an upgrade lock, using an Oracle-style
|
||||
|
@ -79,6 +80,7 @@ public enum LockMode {
|
|||
*
|
||||
* @deprecated instead use PESSIMISTIC_FORCE_INCREMENT
|
||||
*/
|
||||
@Deprecated
|
||||
FORCE( 15 ),
|
||||
|
||||
/**
|
||||
|
|
|
@ -226,6 +226,7 @@ public interface SessionFactory extends Referenceable, Serializable {
|
|||
* @deprecated Use {@link Cache#evictEntityRegion(Class)} accessed through
|
||||
* {@link #getCache()} instead.
|
||||
*/
|
||||
@Deprecated
|
||||
public void evict(Class persistentClass) throws HibernateException;
|
||||
|
||||
/**
|
||||
|
@ -243,6 +244,7 @@ public interface SessionFactory extends Referenceable, Serializable {
|
|||
* @deprecated Use {@link Cache#containsEntity(Class, Serializable)} accessed through
|
||||
* {@link #getCache()} instead.
|
||||
*/
|
||||
@Deprecated
|
||||
public void evict(Class persistentClass, Serializable id) throws HibernateException;
|
||||
|
||||
/**
|
||||
|
@ -259,6 +261,7 @@ public interface SessionFactory extends Referenceable, Serializable {
|
|||
* @deprecated Use {@link Cache#evictEntityRegion(String)} accessed through
|
||||
* {@link #getCache()} instead.
|
||||
*/
|
||||
@Deprecated
|
||||
public void evictEntity(String entityName) throws HibernateException;
|
||||
|
||||
/**
|
||||
|
@ -276,6 +279,7 @@ public interface SessionFactory extends Referenceable, Serializable {
|
|||
* @deprecated Use {@link Cache#evictEntity(String,Serializable)} accessed through
|
||||
* {@link #getCache()} instead.
|
||||
*/
|
||||
@Deprecated
|
||||
public void evictEntity(String entityName, Serializable id) throws HibernateException;
|
||||
|
||||
/**
|
||||
|
@ -292,6 +296,7 @@ public interface SessionFactory extends Referenceable, Serializable {
|
|||
* @deprecated Use {@link Cache#evictCollectionRegion(String)} accessed through
|
||||
* {@link #getCache()} instead.
|
||||
*/
|
||||
@Deprecated
|
||||
public void evictCollection(String roleName) throws HibernateException;
|
||||
|
||||
/**
|
||||
|
@ -309,6 +314,7 @@ public interface SessionFactory extends Referenceable, Serializable {
|
|||
* @deprecated Use {@link Cache#evictCollection(String,Serializable)} accessed through
|
||||
* {@link #getCache()} instead.
|
||||
*/
|
||||
@Deprecated
|
||||
public void evictCollection(String roleName, Serializable id) throws HibernateException;
|
||||
|
||||
/**
|
||||
|
@ -322,6 +328,7 @@ public interface SessionFactory extends Referenceable, Serializable {
|
|||
* @deprecated Use {@link Cache#evictQueryRegion(String)} accessed through
|
||||
* {@link #getCache()} instead.
|
||||
*/
|
||||
@Deprecated
|
||||
public void evictQueries(String cacheRegion) throws HibernateException;
|
||||
|
||||
/**
|
||||
|
@ -333,6 +340,7 @@ public interface SessionFactory extends Referenceable, Serializable {
|
|||
* @deprecated Use {@link Cache#evictQueryRegions} accessed through
|
||||
* {@link #getCache()} instead.
|
||||
*/
|
||||
@Deprecated
|
||||
public void evictQueries() throws HibernateException;
|
||||
|
||||
/**
|
||||
|
|
|
@ -53,6 +53,6 @@ public class CallableStatementProxyHandler extends PreparedStatementProxyHandler
|
|||
}
|
||||
|
||||
private Object executeQuery() throws SQLException {
|
||||
return getConnectionProxy().getJdbcServices().getDialect().getResultSet( ( CallableStatement ) this );
|
||||
return getConnectionProxy().getJdbcServices().getDialect().getResultSet( ( CallableStatement ) getStatementWithoutChecks() );
|
||||
}
|
||||
}
|
||||
|
|
|
@ -66,21 +66,31 @@ public abstract class BasicBinder<J> implements ValueBinder<J> {
|
|||
* {@inheritDoc}
|
||||
*/
|
||||
public final void bind(PreparedStatement st, J value, int index, WrapperOptions options) throws SQLException {
|
||||
if ( value == null ) {
|
||||
if (LOG.isTraceEnabled()) {
|
||||
LOG.trace(String.format(NULL_BIND_MSG_TEMPLATE, index, JdbcTypeNameMapper.getTypeName(sqlDescriptor.getSqlType())));
|
||||
}
|
||||
st.setNull( index, sqlDescriptor.getSqlType() );
|
||||
}
|
||||
else {
|
||||
if (LOG.isTraceEnabled()) {
|
||||
LOG.trace(String.format(BIND_MSG_TEMPLATE,
|
||||
index,
|
||||
JdbcTypeNameMapper.getTypeName(sqlDescriptor.getSqlType()),
|
||||
getJavaDescriptor().extractLoggableRepresentation(value)));
|
||||
}
|
||||
doBind( st, value, index, options );
|
||||
}
|
||||
if ( value == null ) {
|
||||
if ( LOG.isTraceEnabled() ) {
|
||||
LOG.trace(
|
||||
String.format(
|
||||
NULL_BIND_MSG_TEMPLATE,
|
||||
index,
|
||||
JdbcTypeNameMapper.getTypeName( sqlDescriptor.getSqlType() )
|
||||
)
|
||||
);
|
||||
}
|
||||
st.setNull( index, sqlDescriptor.getSqlType() );
|
||||
}
|
||||
else {
|
||||
if ( LOG.isTraceEnabled() ) {
|
||||
LOG.trace(
|
||||
String.format(
|
||||
BIND_MSG_TEMPLATE,
|
||||
index,
|
||||
JdbcTypeNameMapper.getTypeName( sqlDescriptor.getSqlType() ),
|
||||
getJavaDescriptor().extractLoggableRepresentation( value )
|
||||
)
|
||||
);
|
||||
}
|
||||
doBind( st, value, index, options );
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -31,9 +31,9 @@
|
|||
<id name="id" type="long">
|
||||
<generator class="increment"/>
|
||||
</id>
|
||||
<property name="type" type="string" />
|
||||
<property name="value" type="string" />
|
||||
<property name="key" type="string" />
|
||||
<property name="type" type="string" column="`type`"/>
|
||||
<property name="value" type="string" column="`value`"/>
|
||||
<property name="key" type="string" column="`key`"/>
|
||||
<property name="entry" type="string" />
|
||||
</class>
|
||||
|
||||
|
|
|
@ -34,6 +34,8 @@ import org.hibernate.bytecode.spi.InstrumentedClassLoader;
|
|||
import org.junit.Rule;
|
||||
import org.junit.Test;
|
||||
|
||||
import org.hibernate.dialect.MySQLDialect;
|
||||
import org.hibernate.testing.SkipForDialect;
|
||||
import org.hibernate.testing.junit4.BaseUnitTestCase;
|
||||
import org.hibernate.testing.junit4.ClassLoadingIsolater;
|
||||
|
||||
|
@ -89,21 +91,25 @@ public abstract class AbstractTransformingClassLoaderInstrumentTestCase extends
|
|||
}
|
||||
|
||||
@Test
|
||||
@SkipForDialect( value = MySQLDialect.class, comment = "wrong sql in mapping, mysql needs double type, but it is float type in mapping")
|
||||
public void testFetchAll() throws Exception {
|
||||
executeExecutable( "org.hibernate.test.instrument.cases.TestFetchAllExecutable" );
|
||||
}
|
||||
|
||||
@Test
|
||||
@SkipForDialect( value = MySQLDialect.class, comment = "wrong sql in mapping, mysql needs double type, but it is float type in mapping")
|
||||
public void testLazy() {
|
||||
executeExecutable( "org.hibernate.test.instrument.cases.TestLazyExecutable" );
|
||||
}
|
||||
|
||||
@Test
|
||||
@SkipForDialect( value = MySQLDialect.class, comment = "wrong sql in mapping, mysql needs double type, but it is float type in mapping")
|
||||
public void testLazyManyToOne() {
|
||||
executeExecutable( "org.hibernate.test.instrument.cases.TestLazyManyToOneExecutable" );
|
||||
}
|
||||
|
||||
@Test
|
||||
@SkipForDialect( value = MySQLDialect.class, comment = "wrong sql in mapping, mysql needs double type, but it is float type in mapping")
|
||||
public void testPropertyInitialized() {
|
||||
executeExecutable( "org.hibernate.test.instrument.cases.TestIsPropertyInitializedExecutable" );
|
||||
}
|
||||
|
@ -124,6 +130,7 @@ public abstract class AbstractTransformingClassLoaderInstrumentTestCase extends
|
|||
}
|
||||
|
||||
@Test
|
||||
@SkipForDialect( value = MySQLDialect.class, comment = "wrong sql in mapping, mysql needs double type, but it is float type in mapping")
|
||||
public void testCustomColumnReadAndWrite() {
|
||||
executeExecutable( "org.hibernate.test.instrument.cases.TestCustomColumnReadAndWrite" );
|
||||
}
|
||||
|
|
|
@ -7,11 +7,13 @@ import java.util.List;
|
|||
|
||||
import org.hibernate.HibernateException;
|
||||
import org.hibernate.Session;
|
||||
import org.hibernate.dialect.Dialect;
|
||||
import org.hibernate.id.PostInsertIdentifierGenerator;
|
||||
|
||||
import org.junit.Test;
|
||||
|
||||
import org.hibernate.testing.SkipLog;
|
||||
import org.hibernate.testing.DialectCheck;
|
||||
import org.hibernate.testing.RequiresDialectFeature;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertNotSame;
|
||||
|
@ -27,18 +29,17 @@ public class CustomSQLTest extends LegacyTestCase {
|
|||
return new String[] { "legacy/CustomSQL.hbm.xml" };
|
||||
}
|
||||
|
||||
private boolean isUsingIdentity() {
|
||||
return PostInsertIdentifierGenerator.class.isAssignableFrom( getDialect().getNativeIdentifierGeneratorClass() );
|
||||
}
|
||||
public static class NonIdentityGeneratorChecker implements DialectCheck {
|
||||
@Override
|
||||
public boolean isMatch(Dialect dialect) {
|
||||
return !PostInsertIdentifierGenerator.class.isAssignableFrom( getDialect().getNativeIdentifierGeneratorClass() );
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
@RequiresDialectFeature( NonIdentityGeneratorChecker.class )
|
||||
@SuppressWarnings( {"UnnecessaryBoxing"})
|
||||
public void testInsert() throws HibernateException, SQLException {
|
||||
if ( isUsingIdentity() ) {
|
||||
SkipLog.reportSkip( "hand sql expecting non-identity id gen", "Custom SQL" );
|
||||
return;
|
||||
}
|
||||
|
||||
Session s = openSession();
|
||||
s.beginTransaction();
|
||||
Role p = new Role();
|
||||
|
@ -82,12 +83,8 @@ public class CustomSQLTest extends LegacyTestCase {
|
|||
|
||||
// @Test
|
||||
@SuppressWarnings( {"UnnecessaryBoxing", "unchecked"})
|
||||
// @RequiresDialectFeature( NonIdentityGeneratorChecker.class )
|
||||
public void testCollectionCUD() throws HibernateException, SQLException {
|
||||
if ( isUsingIdentity() ) {
|
||||
SkipLog.reportSkip( "hand sql expecting non-identity id gen", "Custom SQL" );
|
||||
return;
|
||||
}
|
||||
|
||||
Role role = new Role();
|
||||
role.setName("Jim Flanders");
|
||||
Intervention iv = new Medication();
|
||||
|
@ -135,12 +132,8 @@ public class CustomSQLTest extends LegacyTestCase {
|
|||
}
|
||||
|
||||
// @Test
|
||||
// @RequiresDialectFeature( NonIdentityGeneratorChecker.class )
|
||||
public void testCRUD() throws HibernateException, SQLException {
|
||||
if ( isUsingIdentity() ) {
|
||||
SkipLog.reportSkip( "hand sql expecting non-identity id gen", "Custom SQL" );
|
||||
return;
|
||||
}
|
||||
|
||||
Person p = new Person();
|
||||
p.setName("Max");
|
||||
p.setLastName("Andersen");
|
||||
|
|
|
@ -89,8 +89,8 @@ public abstract class CustomSQLTestSupport extends BaseCoreFunctionalTestCase {
|
|||
assertEquals( jboss.getName(), "JBOSS" );
|
||||
emp = ( Employment ) jboss.getEmployments().iterator().next();
|
||||
gavin = emp.getEmployee();
|
||||
assertEquals( gavin.getName(), "GAVIN" );
|
||||
assertEquals( s.getCurrentLockMode( gavin ), LockMode.PESSIMISTIC_WRITE );
|
||||
assertEquals( "GAVIN" , gavin.getName() );
|
||||
assertEquals( LockMode.UPGRADE , s.getCurrentLockMode( gavin ));
|
||||
emp.setEndDate( new Date() );
|
||||
Employment emp3 = new Employment( gavin, jboss, "US" );
|
||||
s.save( emp3 );
|
||||
|
|
|
@ -101,7 +101,7 @@ public class CMTTest extends BaseCoreFunctionalTestCase {
|
|||
assertEquals(3, sessionFactory().getStatistics().getUpdateTimestampsCachePutCount()); // Twice preinvalidate & one invalidate
|
||||
assertEquals(0, sessionFactory().getStatistics().getUpdateTimestampsCacheMissCount());
|
||||
|
||||
sessionFactory().evictEntity( "Item" );
|
||||
sessionFactory().getCache().evictEntityRegion( "Item" );
|
||||
|
||||
TestingJtaBootstrap.INSTANCE.getTransactionManager().begin();
|
||||
Session s1 = openSession();
|
||||
|
@ -118,7 +118,7 @@ public class CMTTest extends BaseCoreFunctionalTestCase {
|
|||
TestingJtaBootstrap.INSTANCE.getTransactionManager().resume( tx );
|
||||
TestingJtaBootstrap.INSTANCE.getTransactionManager().commit();
|
||||
|
||||
sessionFactory().evictEntity( "Item" );
|
||||
sessionFactory().getCache().evictEntityRegion( "Item" );
|
||||
|
||||
TestingJtaBootstrap.INSTANCE.getTransactionManager().begin();
|
||||
s1 = openSession();
|
||||
|
@ -174,7 +174,7 @@ public class CMTTest extends BaseCoreFunctionalTestCase {
|
|||
|
||||
sessionFactory().getStatistics().clear();
|
||||
|
||||
sessionFactory().evictEntity( "Item" );
|
||||
sessionFactory().getCache().evictEntityRegion( "Item" );
|
||||
|
||||
TestingJtaBootstrap.INSTANCE.getTransactionManager().begin();
|
||||
Session s4 = openSession();
|
||||
|
@ -274,7 +274,7 @@ public class CMTTest extends BaseCoreFunctionalTestCase {
|
|||
|
||||
sessionFactory().getStatistics().clear();
|
||||
|
||||
sessionFactory().evictEntity( "Item" );
|
||||
sessionFactory().getCache().evictEntityRegion( "Item" );
|
||||
|
||||
TestingJtaBootstrap.INSTANCE.getTransactionManager().begin();
|
||||
Session s4 = openSession();
|
||||
|
@ -296,7 +296,6 @@ public class CMTTest extends BaseCoreFunctionalTestCase {
|
|||
.setCacheable( true ).list();
|
||||
assertEquals( r2.size(), 2 );
|
||||
TestingJtaBootstrap.INSTANCE.getTransactionManager().commit();
|
||||
|
||||
assertEquals( sessionFactory().getStatistics().getSecondLevelCacheHitCount(), 0 );
|
||||
assertEquals( sessionFactory().getStatistics().getSecondLevelCacheMissCount(), 0 );
|
||||
assertEquals( sessionFactory().getStatistics().getEntityLoadCount(), 4 );
|
||||
|
|
Loading…
Reference in New Issue