HHH-7249 - Added test case.

This commit is contained in:
Chris Cranford 2016-08-01 18:49:32 -05:00
parent 7552b053db
commit f5bb3bac38
1 changed files with 187 additions and 0 deletions

View File

@ -0,0 +1,187 @@
/*
* 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.envers.test.integration.inheritance.single.relation;
import java.util.Arrays;
import java.util.Set;
import javax.persistence.Column;
import javax.persistence.DiscriminatorColumn;
import javax.persistence.DiscriminatorValue;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Inheritance;
import javax.persistence.InheritanceType;
import javax.persistence.ManyToOne;
import javax.persistence.OneToMany;
import org.hibernate.envers.Audited;
import org.hibernate.envers.test.BaseEnversJPAFunctionalTestCase;
import org.hibernate.envers.test.Priority;
import org.hibernate.testing.TestForIssue;
import org.hibernate.testing.transaction.TransactionUtil;
import org.junit.Test;
import static org.hibernate.testing.junit4.ExtraAssertions.assertTyping;
import static org.junit.Assert.assertEquals;
/**
* Tests that after the removal of an entity that maintains a polymorphic relation that
* the {@code AuditReader} queries return the correct polymorphic type for revisions.
* <p/>
* Previously, this test would have returned {@link EmployeeType} when looking up the
* entity associated to revision 3 of typeId; however after the fix it properly will
* return {@link SalaryEmployeeType} instances instead.
*
* @author Chris Cranford
*/
@TestForIssue(jiraKey = "HHH-7249")
public class PolymorphicRemovalTest extends BaseEnversJPAFunctionalTestCase {
private Integer typeId;
private Integer employeeId;
@Override
protected Class<?>[] getAnnotatedClasses() {
return new Class<?>[] { Employee.class, EmployeeType.class, SalaryEmployeeType.class };
}
@Test
@Priority(10)
public void initData() {
// revision 1
this.typeId = TransactionUtil.doInJPA( this::entityManagerFactory, entityManager -> {
SalaryEmployeeType type = new SalaryEmployeeType();
type.setData( "salaried" );
entityManager.persist( type );
return type.getId();
} );
// revision 2
this.employeeId = TransactionUtil.doInJPA( this::entityManagerFactory, entityManager -> {
EmployeeType type = entityManager.find( EmployeeType.class, typeId );
Employee employee = new Employee();
employee.setType( type );
entityManager.persist( employee );
return employee.getId();
} );
// revision 3
TransactionUtil.doInJPA( this::entityManagerFactory, entityManager -> {
Employee employee = entityManager.find( Employee.class, employeeId );
entityManager.remove( employee );
} );
}
@Test
public void testRevisionCounts() {
assertEquals(Arrays.asList( 1, 2, 3 ), getAuditReader().getRevisions( EmployeeType.class, typeId ) );
assertEquals( Arrays.asList( 2, 3 ), getAuditReader().getRevisions( Employee.class, employeeId ) );
}
@Test
public void testRevisionHistoryPayment() {
final EmployeeType rev1 = getAuditReader().find( EmployeeType.class, typeId, 1 );
assertTyping( SalaryEmployeeType.class, rev1 );
assertEquals( "SALARY", rev1.getType() );
final EmployeeType rev2 = getAuditReader().find( EmployeeType.class, typeId, 2 );
assertTyping( SalaryEmployeeType.class, rev2 );
assertEquals( "SALARY", rev2.getType() );
final EmployeeType rev3 = getAuditReader().find( EmployeeType.class, typeId, 3 );
assertTyping( SalaryEmployeeType.class, rev3 );
assertEquals( "SALARY", rev3.getType() );
}
@Entity(name = "EmployeeType")
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name = "TYPE")
@DiscriminatorValue("UNKNOWN")
@Audited
public static class EmployeeType {
@Id
@GeneratedValue
private Integer id;
@OneToMany(mappedBy = "type")
private Set<Employee> employees;
// used to expose the discriminator value for assertion checking
@Column(name = "TYPE", insertable = false, updatable = false, nullable = false, length = 31)
private String type;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public Set<Employee> getEmployees() {
return employees;
}
public void setEmployees(Set<Employee> employees) {
this.employees = employees;
}
public String getType() {
return type;
}
public void setType(String type) {
this.type = type;
}
}
@Entity(name = "SalaryEmployee")
@DiscriminatorValue("SALARY")
@Audited
public static class SalaryEmployeeType extends EmployeeType {
private String data;
public String getData() {
return data;
}
public void setData(String data) {
this.data = data;
}
}
@Entity(name = "Employee")
@Audited
public static class Employee {
@Id
@GeneratedValue
private Integer id;
private String name;
@ManyToOne(fetch = FetchType.LAZY)
private EmployeeType type;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public EmployeeType getType() {
return type;
}
public void setType(EmployeeType type) {
this.type = type;
}
}
}