/*
* 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.annotations.tableperclass;
import javax.persistence.PersistenceException;
import java.util.List;
import org.junit.Test;
import org.hibernate.JDBCException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
import static org.hibernate.testing.junit4.ExtraAssertions.assertTyping;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.fail;
/**
* @author Emmanuel Bernard
*/
public class TablePerClassTest extends BaseCoreFunctionalTestCase {
@Test
public void testUnionSubClass() throws Exception {
Session s;
Transaction tx;
s = openSession();
tx = s.beginTransaction();
Machine computer = new Machine();
computer.setWeight( new Double( 4 ) );
Robot asimov = new Robot();
asimov.setWeight( new Double( 120 ) );
asimov.setName( "Asimov" );
T800 terminator = new T800();
terminator.setName( "Terminator" );
terminator.setWeight( new Double( 300 ) );
terminator.setTargetName( "Sarah Connor" );
s.persist( computer );
s.persist( asimov );
s.persist( terminator );
tx.commit();
s.close();
s = openSession();
tx = s.beginTransaction();
Query q = s.createQuery( "from Machine m where m.weight >= :weight" );
q.setDouble( "weight", new Double( 10 ) );
List result = q.list();
assertEquals( 2, result.size() );
tx.commit();
s.close();
s = openSession();
tx = s.beginTransaction();
tx.commit();
s.close();
}
@Test
public void testConstraintsOnSuperclassProperties() throws Exception {
Session s = openSession();
Transaction tx = s.beginTransaction();
Product product1 = new Product();
product1.setId( 1l );
product1.setManufacturerId( 1l );
product1.setManufacturerPartNumber( "AAFR");
s.persist( product1 );
s.flush();
Product product2 = new Product();
product2.setId( 2l );
product2.setManufacturerId( 1l );
product2.setManufacturerPartNumber( "AAFR");
s.persist( product2 );
try {
s.flush();
fail( "Database Exception not handled" );
}
catch (PersistenceException e) {
assertTyping( JDBCException.class, e.getCause() );
//success
}
finally {
tx.rollback();
s.close();
}
}
@Override
protected Class[] getAnnotatedClasses() {
return new Class[] {
Robot.class,
T800.class,
Machine.class,
Component.class,
Product.class
};
}
}