/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
* See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
*/
package org.hibernate.test.naturalid.inheritance.cache;
import org.hibernate.cfg.AvailableSettings;
import org.hibernate.cfg.Configuration;
import org.hibernate.testing.FailureExpected;
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
import org.junit.Test;
import org.apache.log4j.Level;
import org.apache.log4j.LogManager;
import org.apache.log4j.Logger;
import static org.hibernate.testing.transaction.TransactionUtil.doInHibernate;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertNull;
@FailureExpected( jiraKey = "HHH-11532" )
public class InheritedNaturalIdCacheTest extends BaseCoreFunctionalTestCase {
@Override
protected void configure(Configuration cfg) {
super.configure( cfg );
cfg.setProperty( AvailableSettings.USE_SECOND_LEVEL_CACHE, "true" );
}
@Override
protected Class<?>[] getAnnotatedClasses() {
return new Class[] {MyEntity.class, ExtendedEntity.class};
}
@Override
protected boolean isCleanupTestDataRequired() {
return true;
}
@Test
public void testLoadExtendedByNormal() {
doInHibernate( this::sessionFactory, session -> {
session.save( new MyEntity( "base" ) );
session.save( new ExtendedEntity( "extended", "ext" ) );
});
doInHibernate( this::sessionFactory, session -> {
// Sanity check, ensure both entities is accessible.
MyEntity user = session.byNaturalId( MyEntity.class ).using(
"uid",
"base"
).load();
ExtendedEntity extendedMyEntity = session.byNaturalId(
ExtendedEntity.class )
.using( "uid", "extended" )
.load();
assertNotNull( user );
assertNotNull( extendedMyEntity );
} );
doInHibernate( this::sessionFactory, session -> {
// This throws WrongClassException, since MyEntity was found using the ID, but we wanted ExtendedEntity.
ExtendedEntity user = session.byNaturalId( ExtendedEntity.class )
.using( "uid", "base" )
.load();
assertNull( user );
} );
}
@Test
public void testLoadExtendedByNormalCatchingWrongClassException() {
doInHibernate( this::sessionFactory, session -> {
session.save( new MyEntity( "normal" ) );
session.save( new ExtendedEntity( "extended", "ext" ) );
});
doInHibernate( this::sessionFactory, session -> {
MyEntity user = session.byNaturalId( MyEntity.class ).using(
"uid",
"normal"
).load();
ExtendedEntity extendedMyEntity = session.byNaturalId(
ExtendedEntity.class )
.using( "uid", "extended" )
.load();
assertNotNull( user );
assertNotNull( extendedMyEntity );
} );
doInHibernate( this::sessionFactory, session -> {
session.byNaturalId( ExtendedEntity.class ).using(
"uid",
"normal"
).load();
} );
}
@Test
public void testLoadExtendedByNormalCatchingWrongClassException2() {
doInHibernate( this::sessionFactory, session -> {
session.save( new MyEntity( "normal" ) );
session.save( new ExtendedEntity( "extended", "ext" ) );
});
doInHibernate( this::sessionFactory, session -> {
MyEntity user = session.byNaturalId( MyEntity.class ).using(
"uid",
"normal"
).load();
ExtendedEntity extendedMyEntity = session.byNaturalId(
ExtendedEntity.class )
.using( "uid", "extended" )
.load();
assertNotNull( user );
assertNotNull( extendedMyEntity );
} );
// Temporarily change logging level for these two classes to DEBUG
final Logger afelLogger = LogManager.getLogger(
"org.hibernate.event.internal.AbstractFlushingEventListener" );
final Logger epLogger = LogManager.getLogger(
"org.hibernate.internal.util.EntityPrinter" );
final Level afelLevel = afelLogger.getLevel();
final Level epLevel = epLogger.getLevel();
try {
// this throws if logging level is set to debug
doInHibernate( this::sessionFactory, session -> {
afelLogger.setLevel( Level.DEBUG );
epLogger.setLevel( Level.DEBUG );
session.byNaturalId( ExtendedEntity.class ).using(
"uid",
"normal"
).load();
} );
}
finally {
// set back previous logging level
afelLogger.setLevel( afelLevel );
epLogger.setLevel( epLevel );
}
}
}