/* * 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.legacy; import java.io.Serializable; import org.junit.Test; import org.hibernate.LockMode; import org.hibernate.Session; import static org.junit.Assert.assertTrue; /** * @author Gavin King */ public class IJ2Test extends LegacyTestCase { public String[] getMappings() { return new String[] { "legacy/IJ2.hbm.xml" }; } @SuppressWarnings( {"UnusedAssignment"}) @Test public void testUnionSubclass() throws Exception { Session s = sessionFactory().openSession(); s.beginTransaction(); I i = new I(); i.setName( "i" ); i.setType( 'a' ); J j = new J(); j.setName( "j" ); j.setType( 'x' ); j.setAmount( 1.0f ); Serializable iid = s.save(i); Serializable jid = s.save(j); s.getTransaction().commit(); s.close(); sessionFactory().getCache().evictEntityRegion( I.class ); s = sessionFactory().openSession(); s.beginTransaction(); j = (J) s.get(I.class, jid); j = (J) s.get(J.class, jid); i = (I) s.get(I.class, iid); assertTrue( i.getClass()==I.class ); j.setAmount( 0.5f ); s.lock(i, LockMode.UPGRADE); s.getTransaction().commit(); s.close(); sessionFactory().getCache().evictEntityRegion( I.class ); s = sessionFactory().openSession(); s.beginTransaction(); j = (J) s.get(J.class, jid); j = (J) s.get(I.class, jid); i = (I) s.get(I.class, iid); assertTrue( i.getClass()==I.class ); j.setAmount( 0.5f ); s.lock(i, LockMode.UPGRADE); s.getTransaction().commit(); s.close(); sessionFactory().getCache().evictEntityRegion( I.class ); s = sessionFactory().openSession(); s.beginTransaction(); assertTrue( s.createQuery( "from I" ).list().size()==2 ); assertTrue( s.createQuery( "from J" ).list().size()==1 ); assertTrue( s.createQuery( "from J j where j.amount > 0 and j.name is not null" ).list().size()==1 ); assertTrue( s.createQuery( "from I i where i.class = org.hibernate.test.legacy.I" ).list().size()==1 ); assertTrue( s.createQuery( "from I i where i.class = J" ).list().size()==1 ); s.getTransaction().commit(); s.close(); sessionFactory().getCache().evictEntityRegion( I.class ); s = sessionFactory().openSession(); s.beginTransaction(); j = (J) s.get(J.class, jid); i = (I) s.get(I.class, iid); K k = new K(); Serializable kid = s.save(k); i.setParent(k); j.setParent(k); s.getTransaction().commit(); s.close(); sessionFactory().getCache().evictEntityRegion( I.class ); s = sessionFactory().openSession(); s.beginTransaction(); j = (J) s.get(J.class, jid); i = (I) s.get(I.class, iid); k = (K) s.get(K.class, kid); System.out.println(k + "=" + i.getParent()); assertTrue( i.getParent()==k ); assertTrue( j.getParent()==k ); assertTrue( k.getIs().size()==2 ); s.getTransaction().commit(); s.close(); sessionFactory().getCache().evictEntityRegion( I.class ); s = sessionFactory().openSession(); s.beginTransaction(); assertTrue( s.createQuery( "from K k inner join k.is i where i.name = 'j'" ).list().size()==1 ); assertTrue( s.createQuery( "from K k inner join k.is i where i.name = 'i'" ).list().size()==1 ); assertTrue( s.createQuery( "from K k left join fetch k.is" ).list().size()==2 ); s.getTransaction().commit(); s.close(); s = sessionFactory().openSession(); s.beginTransaction(); j = (J) s.get(J.class, jid); i = (I) s.get(I.class, iid); k = (K) s.get(K.class, kid); s.delete(k); s.delete(j); s.delete(i); s.getTransaction().commit(); s.close(); } }