[hibernate-commits] Hibernate SVN: r11489 - in branches/Branch_3_2/Hibernate3: test/org/hibernate/test and 1 other directories.

hibernate-commits at lists.jboss.org hibernate-commits at lists.jboss.org
Tue May 8 21:42:44 EDT 2007


Author: steve.ebersole at jboss.com
Date: 2007-05-08 21:42:44 -0400 (Tue, 08 May 2007)
New Revision: 11489

Added:
   branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/
   branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/Child.java
   branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/CollectionReattachmentTest.java
   branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/Mappings.hbm.xml
   branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/Parent.java
   branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/ProxyReattachmentTest.java
   branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/ReattachmentSuite.java
Modified:
   branches/Branch_3_2/Hibernate3/src/org/hibernate/engine/StatefulPersistenceContext.java
   branches/Branch_3_2/Hibernate3/test/org/hibernate/test/AllTests.java
Log:
HHH-511 : collection reattachment

Modified: branches/Branch_3_2/Hibernate3/src/org/hibernate/engine/StatefulPersistenceContext.java
===================================================================
--- branches/Branch_3_2/Hibernate3/src/org/hibernate/engine/StatefulPersistenceContext.java	2007-05-08 22:21:46 UTC (rev 11488)
+++ branches/Branch_3_2/Hibernate3/src/org/hibernate/engine/StatefulPersistenceContext.java	2007-05-09 01:42:44 UTC (rev 11489)
@@ -178,6 +178,15 @@
 	}
 
 	public void clear() {
+		Iterator itr = proxiesByKey.values().iterator();
+		while ( itr.hasNext() ) {
+			final LazyInitializer li = ( ( HibernateProxy ) itr.next() ).getHibernateLazyInitializer();
+			li.setSession( null );
+		}
+		Map.Entry[] collectionEntryArray = IdentityMap.concurrentEntries( collectionEntries );
+		for ( int i = 0; i < collectionEntryArray.length; i++ ) {
+			( ( PersistentCollection ) collectionEntryArray[i].getKey() ).unsetSession( getSession() );
+		}
 		arrayHolders.clear();
 		entitiesByKey.clear();
 		entitiesByUniqueKey.clear();

Modified: branches/Branch_3_2/Hibernate3/test/org/hibernate/test/AllTests.java
===================================================================
--- branches/Branch_3_2/Hibernate3/test/org/hibernate/test/AllTests.java	2007-05-08 22:21:46 UTC (rev 11488)
+++ branches/Branch_3_2/Hibernate3/test/org/hibernate/test/AllTests.java	2007-05-09 01:42:44 UTC (rev 11489)
@@ -130,6 +130,7 @@
 import org.hibernate.test.version.sybase.SybaseTimestampVersioningTest;
 import org.hibernate.test.where.WhereTest;
 import org.hibernate.test.insertordering.InsertOrderingTest;
+import org.hibernate.test.reattachment.ReattachmentSuite;
 
 /**
  * @author Gavin King
@@ -303,6 +304,7 @@
 			suite.addTest( DialectFunctionalTestsSuite.suite() );
 			suite.addTest( DialectUnitTestsSuite.suite() );
 			suite.addTest( InsertOrderingTest.suite() );
+			suite.addTest( ReattachmentSuite.suite() );
 
 			return suite;
 		}

Added: branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/Child.java
===================================================================
--- branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/Child.java	                        (rev 0)
+++ branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/Child.java	2007-05-09 01:42:44 UTC (rev 11489)
@@ -0,0 +1,34 @@
+package org.hibernate.test.reattachment;
+
+/**
+ * Child entity
+ *
+ * @author Steve Ebersole
+ */
+public class Child {
+	private String name;
+	private Parent parent;
+
+	public Child() {
+	}
+
+	public Child(String name) {
+		this.name = name;
+	}
+
+	public String getName() {
+		return name;
+	}
+
+	public void setName(String name) {
+		this.name = name;
+	}
+
+	public Parent getParent() {
+		return parent;
+	}
+
+	public void setParent(Parent parent) {
+		this.parent = parent;
+	}
+}

Added: branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/CollectionReattachmentTest.java
===================================================================
--- branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/CollectionReattachmentTest.java	                        (rev 0)
+++ branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/CollectionReattachmentTest.java	2007-05-09 01:42:44 UTC (rev 11489)
@@ -0,0 +1,78 @@
+package org.hibernate.test.reattachment;
+
+import junit.framework.Test;
+
+import org.hibernate.junit.functional.FunctionalTestCase;
+import org.hibernate.junit.functional.FunctionalTestClassTestSuite;
+import org.hibernate.Session;
+
+/**
+ * Test of collection reattachment semantics
+ *
+ * @author Steve Ebersole
+ */
+public class CollectionReattachmentTest extends FunctionalTestCase {
+	public CollectionReattachmentTest(String string) {
+		super( string );
+	}
+
+	public static Test suite() {
+		return new FunctionalTestClassTestSuite( CollectionReattachmentTest.class );
+	}
+
+	public String[] getMappings() {
+		return new String[] { "reattachment/Mappings.hbm.xml" };
+	}
+
+	public void testUpdateOwnerAfterClear() {
+		Session s = openSession();
+		s.beginTransaction();
+		Parent p = new Parent( "p" );
+		p.getChildren().add( new Child( "c" ) );
+		s.save( p );
+		s.getTransaction().commit();
+		s.close();
+
+		s = openSession();
+		s.beginTransaction();
+		p = ( Parent ) s.get( Parent.class, "p" );
+		// clear...
+		s.clear();
+		// now try to reattach...
+		s.update( p );
+		s.getTransaction().commit();
+		s.close();
+
+		s = openSession();
+		s.beginTransaction();
+		s.delete( p );
+		s.getTransaction().commit();
+		s.close();
+	}
+
+	public void testUpdateOwnerAfterEvict() {
+		Session s = openSession();
+		s.beginTransaction();
+		Parent p = new Parent( "p" );
+		p.getChildren().add( new Child( "c" ) );
+		s.save( p );
+		s.getTransaction().commit();
+		s.close();
+
+		s = openSession();
+		s.beginTransaction();
+		p = ( Parent ) s.get( Parent.class, "p" );
+		// evict...
+		s.evict( p );
+		// now try to reattach...
+		s.update( p );
+		s.getTransaction().commit();
+		s.close();
+
+		s = openSession();
+		s.beginTransaction();
+		s.delete( p );
+		s.getTransaction().commit();
+		s.close();
+	}
+}

Added: branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/Mappings.hbm.xml
===================================================================
--- branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/Mappings.hbm.xml	                        (rev 0)
+++ branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/Mappings.hbm.xml	2007-05-09 01:42:44 UTC (rev 11489)
@@ -0,0 +1,23 @@
+<?xml version="1.0"?>
+<!DOCTYPE hibernate-mapping PUBLIC
+	"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
+	"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
+
+
+<hibernate-mapping package="org.hibernate.test.reattachment">
+
+    <class name="Parent">
+		<id name="name" column="NAME" type="string" />
+        <many-to-one name="other" class="Parent" column="OTHER_ID" lazy="proxy"/>
+        <set name="children" inverse="true" cascade="all">
+            <key column="PARENT" />
+            <one-to-many class="Child" />
+        </set>
+	</class>
+
+    <class name="Child">
+        <id name="name" column="NAME" type="string"/>
+        <many-to-one name="parent" class="Parent" cascade="none" />
+    </class>
+
+</hibernate-mapping>

Added: branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/Parent.java
===================================================================
--- branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/Parent.java	                        (rev 0)
+++ branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/Parent.java	2007-05-09 01:42:44 UTC (rev 11489)
@@ -0,0 +1,51 @@
+package org.hibernate.test.reattachment;
+
+import java.util.Set;
+import java.util.HashSet;
+
+/**
+ * Parent entity
+ *
+ * @author Steve Ebersole
+ */
+public class Parent {
+	private String name;
+	private Parent other;
+	private Set children = new HashSet();
+
+	public Parent() {
+	}
+
+	public Parent(String name) {
+		this.name = name;
+	}
+
+	public Parent(String name, Parent other) {
+		this.name = name;
+		this.other = other;
+	}
+
+	public String getName() {
+		return name;
+	}
+
+	public void setName(String name) {
+		this.name = name;
+	}
+
+	public Parent getOther() {
+		return other;
+	}
+
+	public void setOther(Parent other) {
+		this.other = other;
+	}
+
+	public Set getChildren() {
+		return children;
+	}
+
+	public void setChildren(Set children) {
+		this.children = children;
+	}
+}

Added: branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/ProxyReattachmentTest.java
===================================================================
--- branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/ProxyReattachmentTest.java	                        (rev 0)
+++ branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/ProxyReattachmentTest.java	2007-05-09 01:42:44 UTC (rev 11489)
@@ -0,0 +1,76 @@
+package org.hibernate.test.reattachment;
+
+import junit.framework.Test;
+
+import org.hibernate.junit.functional.FunctionalTestCase;
+import org.hibernate.junit.functional.FunctionalTestClassTestSuite;
+import org.hibernate.Session;
+
+/**
+ * Test of proxy reattachment semantics
+ *
+ * @author Steve Ebersole
+ */
+public class ProxyReattachmentTest extends FunctionalTestCase {
+	public ProxyReattachmentTest(String string) {
+		super( string );
+	}
+
+	public static Test suite() {
+		return new FunctionalTestClassTestSuite( ProxyReattachmentTest.class );
+	}
+
+	public String[] getMappings() {
+		return new String[] { "reattachment/Mappings.hbm.xml" };
+	}
+
+	public void testUpdateAfterEvict() {
+		Session s = openSession();
+		s.beginTransaction();
+		Parent p = new Parent( "p" );
+		s.save( p );
+		s.getTransaction().commit();
+		s.close();
+
+		s = openSession();
+		s.beginTransaction();
+		p = ( Parent ) s.load( Parent.class, "p" );
+		// evict...
+		s.evict( p );
+		// now try to reattach...
+		s.update( p );
+		s.getTransaction().commit();
+		s.close();
+
+		s = openSession();
+		s.beginTransaction();
+		s.delete( p );
+		s.getTransaction().commit();
+		s.close();
+	}
+
+	public void testUpdateAfterClear() {
+		Session s = openSession();
+		s.beginTransaction();
+		Parent p = new Parent( "p" );
+		s.save( p );
+		s.getTransaction().commit();
+		s.close();
+
+		s = openSession();
+		s.beginTransaction();
+		p = ( Parent ) s.load( Parent.class, "p" );
+		// clear...
+		s.clear();
+		// now try to reattach...
+		s.update( p );
+		s.getTransaction().commit();
+		s.close();
+
+		s = openSession();
+		s.beginTransaction();
+		s.delete( p );
+		s.getTransaction().commit();
+		s.close();
+	}
+}

Added: branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/ReattachmentSuite.java
===================================================================
--- branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/ReattachmentSuite.java	                        (rev 0)
+++ branches/Branch_3_2/Hibernate3/test/org/hibernate/test/reattachment/ReattachmentSuite.java	2007-05-09 01:42:44 UTC (rev 11489)
@@ -0,0 +1,18 @@
+package org.hibernate.test.reattachment;
+
+import junit.framework.Test;
+import junit.framework.TestSuite;
+
+/**
+ * Suite of reattachment specific tests.
+ *
+ * @author Steve Ebersole
+ */
+public class ReattachmentSuite {
+	public static Test suite() {
+		TestSuite suite = new TestSuite( "reattachment semantics" );
+		suite.addTest( CollectionReattachmentTest.suite() );
+		suite.addTest( ProxyReattachmentTest.suite() );
+		return suite;
+	}
+}




More information about the hibernate-commits mailing list