HHH-8908 : Column of Embedded missing in Audit Table; additional test, format, cleanup
This commit is contained in:
parent
ce6018563c
commit
b3b2312482
|
@ -605,8 +605,7 @@ public final class CollectionMetadataGenerator {
|
||||||
final ReflectionManager reflectionManager = mainGenerator.getCfg().getReflectionManager();
|
final ReflectionManager reflectionManager = mainGenerator.getCfg().getReflectionManager();
|
||||||
|
|
||||||
new ComponentAuditedPropertiesReader(
|
new ComponentAuditedPropertiesReader(
|
||||||
true, // TODO: is this correct???
|
true, // true because the collection is being audited
|
||||||
ModificationStore.FULL,
|
|
||||||
new AuditedPropertiesReader.ComponentPropertiesSource( reflectionManager, component ),
|
new AuditedPropertiesReader.ComponentPropertiesSource( reflectionManager, component ),
|
||||||
auditData, mainGenerator.getGlobalCfg(), reflectionManager, ""
|
auditData, mainGenerator.getGlobalCfg(), reflectionManager, ""
|
||||||
).read();
|
).read();
|
||||||
|
|
|
@ -65,7 +65,7 @@ public final class AnnotationsMetadataReader {
|
||||||
auditData = new ClassAuditingData();
|
auditData = new ClassAuditingData();
|
||||||
}
|
}
|
||||||
|
|
||||||
private ModificationStore getDefaultAudited(XClass clazz) {
|
private ModificationStore getDefaultAuditedModStore(XClass clazz) {
|
||||||
final Audited defaultAudited = clazz.getAnnotation( Audited.class );
|
final Audited defaultAudited = clazz.getAnnotation( Audited.class );
|
||||||
|
|
||||||
if ( defaultAudited != null ) {
|
if ( defaultAudited != null ) {
|
||||||
|
@ -115,14 +115,13 @@ public final class AnnotationsMetadataReader {
|
||||||
try {
|
try {
|
||||||
final XClass xclass = reflectionManager.classForName( pc.getClassName(), this.getClass() );
|
final XClass xclass = reflectionManager.classForName( pc.getClassName(), this.getClass() );
|
||||||
|
|
||||||
final ModificationStore defaultStore = getDefaultAudited( xclass );
|
final ModificationStore defaultStore = getDefaultAuditedModStore( xclass );
|
||||||
if ( defaultStore != null ) {
|
if ( defaultStore != null ) {
|
||||||
auditData.setDefaultAudited( true );
|
auditData.setDefaultAudited( true );
|
||||||
}
|
}
|
||||||
|
|
||||||
new AuditedPropertiesReader(
|
new AuditedPropertiesReader(
|
||||||
auditData.isAudited(),
|
auditData.isAudited(),
|
||||||
defaultStore,
|
|
||||||
new PersistentClassPropertiesSource( xclass ),
|
new PersistentClassPropertiesSource( xclass ),
|
||||||
auditData,
|
auditData,
|
||||||
globalCfg,
|
globalCfg,
|
||||||
|
|
|
@ -73,8 +73,6 @@ import static org.hibernate.envers.internal.tools.Tools.newHashSet;
|
||||||
*/
|
*/
|
||||||
public class AuditedPropertiesReader {
|
public class AuditedPropertiesReader {
|
||||||
private final boolean defaultAudited;
|
private final boolean defaultAudited;
|
||||||
// TODO: can defaultStore be made private?
|
|
||||||
protected final ModificationStore defaultStore;
|
|
||||||
private final PersistentPropertiesSource persistentPropertiesSource;
|
private final PersistentPropertiesSource persistentPropertiesSource;
|
||||||
private final AuditedPropertiesHolder auditedPropertiesHolder;
|
private final AuditedPropertiesHolder auditedPropertiesHolder;
|
||||||
private final GlobalConfiguration globalCfg;
|
private final GlobalConfiguration globalCfg;
|
||||||
|
@ -94,14 +92,12 @@ public class AuditedPropertiesReader {
|
||||||
|
|
||||||
public AuditedPropertiesReader(
|
public AuditedPropertiesReader(
|
||||||
boolean defaultAudited,
|
boolean defaultAudited,
|
||||||
ModificationStore defaultStore,
|
|
||||||
PersistentPropertiesSource persistentPropertiesSource,
|
PersistentPropertiesSource persistentPropertiesSource,
|
||||||
AuditedPropertiesHolder auditedPropertiesHolder,
|
AuditedPropertiesHolder auditedPropertiesHolder,
|
||||||
GlobalConfiguration globalCfg,
|
GlobalConfiguration globalCfg,
|
||||||
ReflectionManager reflectionManager,
|
ReflectionManager reflectionManager,
|
||||||
String propertyNamePrefix) {
|
String propertyNamePrefix) {
|
||||||
this.defaultAudited = defaultAudited;
|
this.defaultAudited = defaultAudited;
|
||||||
this.defaultStore = defaultStore;
|
|
||||||
this.persistentPropertiesSource = persistentPropertiesSource;
|
this.persistentPropertiesSource = persistentPropertiesSource;
|
||||||
this.auditedPropertiesHolder = auditedPropertiesHolder;
|
this.auditedPropertiesHolder = auditedPropertiesHolder;
|
||||||
this.globalCfg = globalCfg;
|
this.globalCfg = globalCfg;
|
||||||
|
@ -436,7 +432,7 @@ public class AuditedPropertiesReader {
|
||||||
propertyValue
|
propertyValue
|
||||||
);
|
);
|
||||||
final AuditedPropertiesReader audPropReader = new AuditedPropertiesReader(
|
final AuditedPropertiesReader audPropReader = new AuditedPropertiesReader(
|
||||||
defaultAudited, ModificationStore.FULL, componentPropertiesSource, componentData, globalCfg,
|
defaultAudited, componentPropertiesSource, componentData, globalCfg,
|
||||||
reflectionManager, propertyNamePrefix + MappingTools.createComponentPrefix( embeddedName )
|
reflectionManager, propertyNamePrefix + MappingTools.createComponentPrefix( embeddedName )
|
||||||
);
|
);
|
||||||
audPropReader.read();
|
audPropReader.read();
|
||||||
|
@ -463,7 +459,6 @@ public class AuditedPropertiesReader {
|
||||||
|
|
||||||
final ComponentAuditedPropertiesReader audPropReader = new ComponentAuditedPropertiesReader(
|
final ComponentAuditedPropertiesReader audPropReader = new ComponentAuditedPropertiesReader(
|
||||||
isAudited,
|
isAudited,
|
||||||
ModificationStore.FULL,
|
|
||||||
componentPropertiesSource,
|
componentPropertiesSource,
|
||||||
componentData,
|
componentData,
|
||||||
globalCfg,
|
globalCfg,
|
||||||
|
|
|
@ -39,13 +39,12 @@ public class ComponentAuditedPropertiesReader extends AuditedPropertiesReader {
|
||||||
|
|
||||||
public ComponentAuditedPropertiesReader(
|
public ComponentAuditedPropertiesReader(
|
||||||
boolean defaultAudited,
|
boolean defaultAudited,
|
||||||
ModificationStore defaultStore,
|
|
||||||
PersistentPropertiesSource persistentPropertiesSource,
|
PersistentPropertiesSource persistentPropertiesSource,
|
||||||
AuditedPropertiesHolder auditedPropertiesHolder,
|
AuditedPropertiesHolder auditedPropertiesHolder,
|
||||||
GlobalConfiguration globalCfg, ReflectionManager reflectionManager,
|
GlobalConfiguration globalCfg, ReflectionManager reflectionManager,
|
||||||
String propertyNamePrefix) {
|
String propertyNamePrefix) {
|
||||||
super(
|
super(
|
||||||
defaultAudited, defaultStore, persistentPropertiesSource, auditedPropertiesHolder,
|
defaultAudited, persistentPropertiesSource, auditedPropertiesHolder,
|
||||||
globalCfg, reflectionManager, propertyNamePrefix
|
globalCfg, reflectionManager, propertyNamePrefix
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,88 @@
|
||||||
|
/*
|
||||||
|
* Hibernate, Relational Persistence for Idiomatic Java
|
||||||
|
*
|
||||||
|
* Copyright (c) 2014, Red Hat Inc. or third-party contributors as
|
||||||
|
* indicated by the @author tags or express copyright attribution
|
||||||
|
* statements applied by the authors. All third-party contributions are
|
||||||
|
* distributed under license by Red Hat Inc.
|
||||||
|
*
|
||||||
|
* This copyrighted material is made available to anyone wishing to use, modify,
|
||||||
|
* copy, or redistribute it subject to the terms and conditions of the GNU
|
||||||
|
* Lesser General Public License, as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
|
||||||
|
* for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public License
|
||||||
|
* along with this distribution; if not, write to:
|
||||||
|
* Free Software Foundation, Inc.
|
||||||
|
* 51 Franklin Street, Fifth Floor
|
||||||
|
* Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
package org.hibernate.envers.test.integration.components.collections.mappedsuperclasselement;
|
||||||
|
|
||||||
|
import javax.persistence.Access;
|
||||||
|
import javax.persistence.AccessType;
|
||||||
|
import javax.persistence.MappedSuperclass;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Jakob Braeuchi.
|
||||||
|
*/
|
||||||
|
|
||||||
|
@MappedSuperclass
|
||||||
|
@Access(AccessType.PROPERTY)
|
||||||
|
public abstract class AbstractCode {
|
||||||
|
/**
|
||||||
|
* Initial Value
|
||||||
|
*/
|
||||||
|
protected static final int UNDEFINED = -1;
|
||||||
|
|
||||||
|
private int code = UNDEFINED;
|
||||||
|
|
||||||
|
protected AbstractCode() {
|
||||||
|
this( UNDEFINED );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor with code
|
||||||
|
*/
|
||||||
|
public AbstractCode(int code) {
|
||||||
|
this.code = code;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getCode() {
|
||||||
|
return code;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCode(int code) {
|
||||||
|
this.code = code;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
final int prime = 31;
|
||||||
|
int result = 1;
|
||||||
|
result = prime * result + code;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
if ( this == obj ) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if ( obj == null ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if ( getClass() != obj.getClass() ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
AbstractCode other = (AbstractCode) obj;
|
||||||
|
if ( code != other.code ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,41 @@
|
||||||
|
/*
|
||||||
|
* Hibernate, Relational Persistence for Idiomatic Java
|
||||||
|
*
|
||||||
|
* Copyright (c) 2014, Red Hat Inc. or third-party contributors as
|
||||||
|
* indicated by the @author tags or express copyright attribution
|
||||||
|
* statements applied by the authors. All third-party contributions are
|
||||||
|
* distributed under license by Red Hat Inc.
|
||||||
|
*
|
||||||
|
* This copyrighted material is made available to anyone wishing to use, modify,
|
||||||
|
* copy, or redistribute it subject to the terms and conditions of the GNU
|
||||||
|
* Lesser General Public License, as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
|
||||||
|
* for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public License
|
||||||
|
* along with this distribution; if not, write to:
|
||||||
|
* Free Software Foundation, Inc.
|
||||||
|
* 51 Franklin Street, Fifth Floor
|
||||||
|
* Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
package org.hibernate.envers.test.integration.components.collections.mappedsuperclasselement;
|
||||||
|
|
||||||
|
import javax.persistence.Embeddable;
|
||||||
|
import javax.persistence.Transient;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Jakob Braeuchi.
|
||||||
|
*/
|
||||||
|
@Embeddable
|
||||||
|
public class Code extends AbstractCode {
|
||||||
|
|
||||||
|
public Code() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public Code(int code) {
|
||||||
|
super( code );
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,102 @@
|
||||||
|
/*
|
||||||
|
* Hibernate, Relational Persistence for Idiomatic Java
|
||||||
|
*
|
||||||
|
* Copyright (c) 2014, Red Hat Middleware LLC or third-party contributors as
|
||||||
|
* indicated by the @author tags or express copyright attribution
|
||||||
|
* statements applied by the authors. All third-party contributions are
|
||||||
|
* distributed under license by Red Hat Middleware LLC.
|
||||||
|
*
|
||||||
|
* This copyrighted material is made available to anyone wishing to use, modify,
|
||||||
|
* copy, or redistribute it subject to the terms and conditions of the GNU
|
||||||
|
* Lesser General Public License, as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
|
||||||
|
* for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public License
|
||||||
|
* along with this distribution; if not, write to:
|
||||||
|
* Free Software Foundation, Inc.
|
||||||
|
* 51 Franklin Street, Fifth Floor
|
||||||
|
* Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
package org.hibernate.envers.test.integration.components.collections.mappedsuperclasselement;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Set;
|
||||||
|
import javax.persistence.EntityManager;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import org.hibernate.envers.test.BaseEnversJPAFunctionalTestCase;
|
||||||
|
import org.hibernate.envers.test.Priority;
|
||||||
|
import org.hibernate.testing.TestForIssue;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Gail Badner
|
||||||
|
*/
|
||||||
|
@TestForIssue( jiraKey = "HHH-8908" )
|
||||||
|
public class CollectionOfMappedSuperclassComponentsTest extends BaseEnversJPAFunctionalTestCase {
|
||||||
|
private Integer id1;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Class<?>[] getAnnotatedClasses() {
|
||||||
|
return new Class[] {MappedSuperclassComponentSetTestEntity.class, Code.class};
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Priority(10)
|
||||||
|
public void initData() {
|
||||||
|
// Revision 1
|
||||||
|
EntityManager em = getEntityManager();
|
||||||
|
em.getTransaction().begin();
|
||||||
|
|
||||||
|
MappedSuperclassComponentSetTestEntity cte1 = new MappedSuperclassComponentSetTestEntity();
|
||||||
|
|
||||||
|
em.persist( cte1 );
|
||||||
|
|
||||||
|
em.getTransaction().commit();
|
||||||
|
|
||||||
|
// Revision 2
|
||||||
|
em = getEntityManager();
|
||||||
|
em.getTransaction().begin();
|
||||||
|
|
||||||
|
cte1 = em.find( MappedSuperclassComponentSetTestEntity.class, cte1.getId() );
|
||||||
|
|
||||||
|
cte1.getComps().add( new Code( 1 ) );
|
||||||
|
cte1.getCompsNotAudited().add( new Code( 100 ) );
|
||||||
|
|
||||||
|
em.getTransaction().commit();
|
||||||
|
|
||||||
|
id1 = cte1.getId();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testRevisionsCounts() {
|
||||||
|
assertEquals(
|
||||||
|
Arrays.asList( 1, 2 ),
|
||||||
|
getAuditReader().getRevisions( MappedSuperclassComponentSetTestEntity.class, id1 )
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testHistoryOfId1() {
|
||||||
|
MappedSuperclassComponentSetTestEntity entity = getAuditReader().find(
|
||||||
|
MappedSuperclassComponentSetTestEntity.class,
|
||||||
|
id1,
|
||||||
|
1
|
||||||
|
);
|
||||||
|
assertEquals( 0, entity.getComps().size() );
|
||||||
|
assertEquals( 0, entity.getCompsNotAudited().size() );
|
||||||
|
|
||||||
|
entity = getAuditReader().find( MappedSuperclassComponentSetTestEntity.class, id1, 2 );
|
||||||
|
Set<Code> comps1 = entity.getComps();
|
||||||
|
assertEquals( 1, comps1.size() );
|
||||||
|
assertTrue( comps1.contains( new Code( 1 ) ) );
|
||||||
|
assertEquals( 0, entity.getCompsNotAudited().size() );
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,123 @@
|
||||||
|
/*
|
||||||
|
* Hibernate, Relational Persistence for Idiomatic Java
|
||||||
|
*
|
||||||
|
* Copyright (c) 2014, Red Hat Middleware LLC or third-party contributors as
|
||||||
|
* indicated by the @author tags or express copyright attribution
|
||||||
|
* statements applied by the authors. All third-party contributions are
|
||||||
|
* distributed under license by Red Hat Middleware LLC.
|
||||||
|
*
|
||||||
|
* This copyrighted material is made available to anyone wishing to use, modify,
|
||||||
|
* copy, or redistribute it subject to the terms and conditions of the GNU
|
||||||
|
* Lesser General Public License, as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
|
||||||
|
* for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public License
|
||||||
|
* along with this distribution; if not, write to:
|
||||||
|
* Free Software Foundation, Inc.
|
||||||
|
* 51 Franklin Street, Fifth Floor
|
||||||
|
* Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
package org.hibernate.envers.test.integration.components.collections.mappedsuperclasselement;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Set;
|
||||||
|
import javax.persistence.CollectionTable;
|
||||||
|
import javax.persistence.ElementCollection;
|
||||||
|
import javax.persistence.Entity;
|
||||||
|
import javax.persistence.GeneratedValue;
|
||||||
|
import javax.persistence.Id;
|
||||||
|
import javax.persistence.JoinColumn;
|
||||||
|
|
||||||
|
import org.hibernate.envers.Audited;
|
||||||
|
import org.hibernate.envers.NotAudited;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Adam Warski (adam at warski dot org)
|
||||||
|
*/
|
||||||
|
@Entity
|
||||||
|
@Audited
|
||||||
|
public class MappedSuperclassComponentSetTestEntity {
|
||||||
|
@Id
|
||||||
|
@GeneratedValue
|
||||||
|
private Integer id;
|
||||||
|
|
||||||
|
@ElementCollection
|
||||||
|
@CollectionTable(name = "MCompTestEntityComps", joinColumns = @JoinColumn(name = "entity_id"))
|
||||||
|
private Set<Code> comps = new HashSet<Code>();
|
||||||
|
|
||||||
|
@NotAudited
|
||||||
|
@ElementCollection
|
||||||
|
@CollectionTable(name = "MCompTestEntityCompsNotAudited", joinColumns = @JoinColumn(name = "entity_id"))
|
||||||
|
private Set<Code> compsNotAudited = new HashSet<Code>();
|
||||||
|
|
||||||
|
public MappedSuperclassComponentSetTestEntity() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public MappedSuperclassComponentSetTestEntity(Integer id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(Integer id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Set<Code> getComps() {
|
||||||
|
return comps;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setComps(Set<Code> comps) {
|
||||||
|
this.comps = comps;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Set<Code> getCompsNotAudited() {
|
||||||
|
return compsNotAudited;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCompsNotAudited(Set<Code> comps) {
|
||||||
|
this.compsNotAudited = compsNotAudited;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object o) {
|
||||||
|
if ( this == o ) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if ( !(o instanceof MappedSuperclassComponentSetTestEntity ) ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
MappedSuperclassComponentSetTestEntity that = (MappedSuperclassComponentSetTestEntity) o;
|
||||||
|
|
||||||
|
if ( comps != null ? !comps.equals( that.comps ) : that.comps != null ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if ( id != null ? !id.equals( that.id ) : that.id != null ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
int result = id != null ? id.hashCode() : 0;
|
||||||
|
result = 31 * result + (comps != null ? comps.hashCode() : 0);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "ComponentSetTestEntity{" +
|
||||||
|
"id=" + id +
|
||||||
|
", comps=" + comps +
|
||||||
|
'}';
|
||||||
|
}
|
||||||
|
}
|
|
@ -33,11 +33,15 @@ import org.junit.Test;
|
||||||
import org.hibernate.envers.AuditReader;
|
import org.hibernate.envers.AuditReader;
|
||||||
import org.hibernate.envers.AuditReaderFactory;
|
import org.hibernate.envers.AuditReaderFactory;
|
||||||
import org.hibernate.envers.test.BaseEnversJPAFunctionalTestCase;
|
import org.hibernate.envers.test.BaseEnversJPAFunctionalTestCase;
|
||||||
|
import org.hibernate.envers.test.Priority;
|
||||||
|
import org.hibernate.testing.TestForIssue;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Jakob Braeuchi.
|
* @author Jakob Braeuchi.
|
||||||
*/
|
*/
|
||||||
|
@TestForIssue(jiraKey = "HHH-8908")
|
||||||
public class MappedSuperclassEmbeddableTest extends BaseEnversJPAFunctionalTestCase {
|
public class MappedSuperclassEmbeddableTest extends BaseEnversJPAFunctionalTestCase {
|
||||||
|
private long id;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Class<?>[] getAnnotatedClasses() {
|
protected Class<?>[] getAnnotatedClasses() {
|
||||||
|
@ -45,7 +49,8 @@ public class MappedSuperclassEmbeddableTest extends BaseEnversJPAFunctionalTestC
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testEmbeddableThatExtendsMappedSuperclass() {
|
@Priority(10)
|
||||||
|
public void initData() {
|
||||||
EntityManager em = getEntityManager();
|
EntityManager em = getEntityManager();
|
||||||
|
|
||||||
SimplePerson person = new SimplePerson();
|
SimplePerson person = new SimplePerson();
|
||||||
|
@ -59,16 +64,22 @@ public class MappedSuperclassEmbeddableTest extends BaseEnversJPAFunctionalTestC
|
||||||
tx.commit();
|
tx.commit();
|
||||||
em.close();
|
em.close();
|
||||||
|
|
||||||
|
id = person.getId();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testEmbeddableThatExtendsMappedSuperclass() {
|
||||||
|
|
||||||
// Reload and Compare Revision
|
// Reload and Compare Revision
|
||||||
em = getEntityManager();
|
EntityManager em = getEntityManager();
|
||||||
SimplePerson personLoaded = em.find(SimplePerson.class, person.getId());
|
SimplePerson personLoaded = em.find( SimplePerson.class, id );
|
||||||
|
|
||||||
AuditReader reader = AuditReaderFactory.get( em );
|
AuditReader reader = AuditReaderFactory.get( em );
|
||||||
|
|
||||||
List<Number> revs = reader.getRevisions(SimplePerson.class, person.getId());
|
List<Number> revs = reader.getRevisions( SimplePerson.class, id );
|
||||||
Assert.assertEquals( 1, revs.size() );
|
Assert.assertEquals( 1, revs.size() );
|
||||||
|
|
||||||
SimplePerson personRev1 = reader.find(SimplePerson.class, person.getId(), revs.get(0));
|
SimplePerson personRev1 = reader.find( SimplePerson.class, id, revs.get( 0 ) );
|
||||||
|
|
||||||
Assert.assertEquals( personLoaded.getName(), personRev1.getName() );
|
Assert.assertEquals( personLoaded.getName(), personRev1.getName() );
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue