HHH-11155 : test case
(cherry picked from commit e17d2f01dc
)
Conflicts:
hibernate-core/src/test/java/org/hibernate/test/bytecode/enhancement/EnhancerTest.java
This commit is contained in:
parent
e26c42845c
commit
8390c50936
|
@ -8,6 +8,7 @@ package org.hibernate.test.bytecode.enhancement;
|
|||
|
||||
import javassist.CtClass;
|
||||
|
||||
import org.hibernate.test.bytecode.enhancement.lazy.group.LazyGroupUpdateTestTask;
|
||||
import org.hibernate.test.bytecode.enhancement.otherentityentrycontext.OtherEntityEntryContextTestTask;
|
||||
import org.hibernate.testing.FailureExpected;
|
||||
import org.hibernate.testing.TestForIssue;
|
||||
|
@ -131,7 +132,13 @@ public class EnhancerTest extends BaseUnitTestCase {
|
|||
public void testLazyGroups() {
|
||||
EnhancerTestUtils.runEnhancerTestTask( LazyGroupAccessTestTask.class );
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
@TestForIssue( jiraKey = "HHH-11155" )
|
||||
public void testLazyGroupsUpdate() {
|
||||
EnhancerTestUtils.runEnhancerTestTask( LazyGroupUpdateTestTask.class );
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testLazyCollectionNoTransactionHandling() {
|
||||
EnhancerTestUtils.runEnhancerTestTask( LazyCollectionNoTransactionLoadingTestTask.class );
|
||||
|
|
|
@ -0,0 +1,172 @@
|
|||
/*
|
||||
* 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.bytecode.enhancement.lazy.group;
|
||||
|
||||
import org.hibernate.Session;
|
||||
import org.hibernate.cfg.Configuration;
|
||||
import org.hibernate.cfg.Environment;
|
||||
import org.hibernate.proxy.HibernateProxy;
|
||||
import org.hibernate.test.bytecode.enhancement.AbstractEnhancerTestTask;
|
||||
import org.hibernate.testing.bytecode.enhancement.EnhancerTestUtils;
|
||||
|
||||
import static junit.framework.Assert.assertEquals;
|
||||
import static junit.framework.Assert.assertNull;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.assertNotNull;
|
||||
|
||||
/**
|
||||
* @author Steve Ebersole
|
||||
* @author Gail Badner
|
||||
*/
|
||||
public class LazyGroupUpdateTestTask extends AbstractEnhancerTestTask {
|
||||
|
||||
@Override
|
||||
public Class<?>[] getAnnotatedClasses() {
|
||||
return new Class[] { Child.class, Parent.class };
|
||||
}
|
||||
|
||||
@Override
|
||||
public void prepare() {
|
||||
Configuration cfg = new Configuration();
|
||||
cfg.setProperty( Environment.ENABLE_LAZY_LOAD_NO_TRANS, "true" );
|
||||
cfg.setProperty( Environment.USE_SECOND_LEVEL_CACHE, "false" );
|
||||
super.prepare( cfg );
|
||||
|
||||
Session s = getFactory().openSession();
|
||||
s.beginTransaction();
|
||||
|
||||
Child c1 = new Child( "steve", "hibernater" );
|
||||
Child c2 = new Child( "sally", "Joe Mama" );
|
||||
|
||||
Parent p1 = new Parent( "Hibernate" );
|
||||
Parent p2 = new Parent( "Swimming" );
|
||||
|
||||
c1.setParent( p1 );
|
||||
p1.getChildren().add( c1 );
|
||||
|
||||
c1.setAlternateParent( p2 );
|
||||
p2.getAlternateChildren().add( c1 );
|
||||
|
||||
c2.setAlternateParent( p1 );
|
||||
p1.getAlternateChildren().add( c2 );
|
||||
|
||||
c2.setParent( p2 );
|
||||
p2.getChildren().add( c2 );
|
||||
|
||||
s.save( p1 );
|
||||
s.save( p2 );
|
||||
|
||||
s.getTransaction().commit();
|
||||
s.close();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void execute() {
|
||||
Session s = getFactory().openSession();
|
||||
s.beginTransaction();
|
||||
|
||||
Child c1 = (Child) s.createQuery( "from Child c where c.name = :name" ).setString( "name", "steve" ).uniqueResult();
|
||||
|
||||
// verify the expected initial loaded state
|
||||
assertLoaded( c1, "name" );
|
||||
assertNotLoaded( c1, "nickName" );
|
||||
assertNotLoaded( c1, "parent" );
|
||||
assertNotLoaded( c1, "alternateParent" );
|
||||
|
||||
// Now lets update nickName which ought to initialize nickName and parent, but not alternateParent
|
||||
c1.setNickName( "new nickName" );
|
||||
assertLoaded( c1, "nickName" );
|
||||
assertLoaded( c1, "parent" );
|
||||
assertNotLoaded( c1, "alternateParent" );
|
||||
assertEquals( "Hibernate", c1.getParent().getNombre() );
|
||||
assertFalse( c1.getParent() instanceof HibernateProxy );
|
||||
|
||||
// Now update c1.parent
|
||||
c1.getParent().getChildren().remove( c1 );
|
||||
Parent p1New = new Parent();
|
||||
p1New.setNombre( "p1New" );
|
||||
c1.setParent( p1New );
|
||||
p1New.getChildren().add( c1 );
|
||||
|
||||
s.getTransaction().commit();
|
||||
s.close();
|
||||
|
||||
s = getFactory().openSession();
|
||||
s.getTransaction().begin();
|
||||
|
||||
c1 = (Child) s.createQuery( "from Child c where c.name = :name" ).setString( "name", "steve" ).uniqueResult();
|
||||
|
||||
// verify updates
|
||||
assertEquals( "new nickName", c1.getNickName() );
|
||||
assertEquals( "p1New", c1.getParent().getNombre() );
|
||||
assertFalse( c1.getParent() instanceof HibernateProxy );
|
||||
|
||||
s.getTransaction().commit();
|
||||
s.close();
|
||||
|
||||
s = getFactory().openSession();
|
||||
s.getTransaction().begin();
|
||||
|
||||
Child c2 = (Child) s.createQuery( "from Child c where c.name = :name" ).setString( "name", "sally" ).uniqueResult();
|
||||
|
||||
// verify the expected initial loaded state
|
||||
assertLoaded( c2, "name" );
|
||||
assertNotLoaded( c2, "nickName" );
|
||||
assertNotLoaded( c2, "parent" );
|
||||
assertNotLoaded( c2, "alternateParent" );
|
||||
|
||||
// Now lets access and update alternateParent which ought to initialize alternateParent and nothing else
|
||||
Parent p1 = c2.getAlternateParent();
|
||||
c2.setAlternateParent( p1New );
|
||||
assertNotLoaded( c2, "nickName" );
|
||||
assertNotLoaded( c2, "parent" );
|
||||
assertLoaded( c2, "alternateParent" );
|
||||
assertEquals( "p1New", c2.getAlternateParent().getNombre() );
|
||||
assertFalse( c2.getAlternateParent() instanceof HibernateProxy );
|
||||
|
||||
p1.getAlternateChildren().remove( c2 );
|
||||
p1New.getAlternateChildren().add( c2 );
|
||||
|
||||
s.getTransaction().commit();
|
||||
s.close();
|
||||
|
||||
s = getFactory().openSession();
|
||||
s.getTransaction().begin();
|
||||
|
||||
c2 = (Child) s.createQuery( "from Child c where c.name = :name" ).setString( "name", "sally" ).uniqueResult();
|
||||
|
||||
// verify update
|
||||
assertEquals( "p1New", c2.getAlternateParent().getNombre() );
|
||||
|
||||
s.getTransaction().commit();
|
||||
s.close();
|
||||
}
|
||||
|
||||
private void assertLoaded(Object owner, String name) {
|
||||
// NOTE we assume null == not-loaded
|
||||
Object fieldByReflection = EnhancerTestUtils.getFieldByReflection( owner, name );
|
||||
assertNotNull( "Expecting field '" + name + "' to be loaded, but it was not", fieldByReflection );
|
||||
}
|
||||
|
||||
private void assertNotLoaded(Object owner, String name) {
|
||||
// NOTE we assume null == not-loaded
|
||||
Object fieldByReflection = EnhancerTestUtils.getFieldByReflection( owner, name );
|
||||
assertNull( "Expecting field '" + name + "' to be not loaded, but it was", fieldByReflection );
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void cleanup() {
|
||||
Session s = getFactory().openSession();
|
||||
s.beginTransaction();
|
||||
|
||||
s.createQuery( "delete Child" ).executeUpdate();
|
||||
s.createQuery( "delete Parent" ).executeUpdate();
|
||||
|
||||
s.getTransaction().commit();
|
||||
s.close();
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue