package org.hibernate.envers.test.integration.readwriteexpression;
import java.math.BigDecimal;
import java.util.List;
import javax.persistence.EntityManager;
import org.hibernate.dialect.Oracle8iDialect;
import org.junit.Assert;
import org.junit.Test;
import org.hibernate.ejb.Ejb3Configuration;
import org.hibernate.envers.test.BaseEnversJPAFunctionalTestCase;
import org.hibernate.envers.test.Priority;
public class ReadWriteExpressionChange extends BaseEnversJPAFunctionalTestCase {
private static final Double HEIGHT_INCHES = 73.0d;
private static final Double HEIGHT_CENTIMETERS = HEIGHT_INCHES * 2.54d;
private Integer id;
@Override
public void configure(Ejb3Configuration cfg) {
cfg.addAnnotatedClass(Staff.class);
}
@Test
@Priority(10)
public void initData() {
EntityManager em = getEntityManager();
em.getTransaction().begin();
Staff staff = new Staff(HEIGHT_INCHES, 1);
em.persist(staff);
em.getTransaction().commit();
id = staff.getId();
}
@Test
public void shouldRespectWriteExpression() {
EntityManager em = getEntityManager();
List resultList = em.createNativeQuery("select size_in_cm from t_staff_AUD where id ="+id).getResultList();
Assert.assertEquals(1, resultList.size());
Double sizeInCm = null;
if (getDialect() instanceof Oracle8iDialect) {
sizeInCm = ((BigDecimal) resultList.get(0)).doubleValue();
} else {
sizeInCm = (Double) resultList.get(0);
}
Assert.assertEquals(HEIGHT_CENTIMETERS, sizeInCm.doubleValue(), 0.00000001);
}
@Test
public void shouldRespectReadExpression() {
List<Number> revisions = getAuditReader().getRevisions(Staff.class, id);
Assert.assertEquals(1, revisions.size());
Number number = revisions.get(0);
Staff staffRev = getAuditReader().find(Staff.class, id, number);
Assert.assertEquals(HEIGHT_INCHES, staffRev.getSizeInInches(), 0.00000001);
}
}