HHH-7948 - Fix and test

This commit is contained in:
Lukasz Antoniak 2013-01-29 19:03:06 +01:00
parent b22bb1a7a8
commit 11e3800f49
2 changed files with 73 additions and 0 deletions

View File

@ -76,6 +76,7 @@ public class CollectionChangeWorkUnit extends AbstractAuditWorkUnit implements A
}
public AuditWorkUnit merge(ModWorkUnit second) {
mergeCollectionModifiedData(second.getData());
return second;
}

View File

@ -0,0 +1,72 @@
package org.hibernate.envers.test.integration.modifiedflags;
import java.util.ArrayList;
import java.util.List;
import javax.persistence.EntityManager;
import org.junit.Test;
import org.hibernate.envers.test.Priority;
import org.hibernate.envers.test.entities.onetomany.ListRefEdEntity;
import org.hibernate.envers.test.entities.onetomany.ListRefIngEntity;
import org.hibernate.testing.TestForIssue;
import static org.hibernate.envers.test.tools.TestTools.extractRevisionNumbers;
import static org.hibernate.envers.test.tools.TestTools.makeList;
import static org.junit.Assert.assertEquals;
/**
* @author Lukasz Antoniak (lukasz dot antoniak at gmail dot com)
*/
public class HasChangedMergeTest extends AbstractModifiedFlagsEntityTest {
private Integer parentId = null;
private Integer childId = null;
@Override
protected Class<?>[] getAnnotatedClasses() {
return new Class<?>[] { ListRefEdEntity.class, ListRefIngEntity.class };
}
@Test
@Priority(10)
public void initData() {
EntityManager em = getEntityManager();
// Revision 1 - data preparation
em.getTransaction().begin();
ListRefEdEntity parent = new ListRefEdEntity( 1, "initial data" );
parent.setReffering( new ArrayList<ListRefIngEntity>() ); // Empty collection is not the same as null reference.
em.persist( parent );
em.getTransaction().commit();
// Revision 2 - inserting new child entity and updating parent
em.getTransaction().begin();
parent = em.find( ListRefEdEntity.class, parent.getId() );
ListRefIngEntity child = new ListRefIngEntity( 1, "initial data", parent );
em.persist( child );
parent.setData( "updated data" );
parent = em.merge( parent );
em.getTransaction().commit();
parentId = parent.getId();
childId = child.getId();
em.close();
}
@Test
@TestForIssue(jiraKey = "HHH-7948")
public void testOneToManyInsertChildUpdateParent() {
List list = queryForPropertyHasChanged( ListRefEdEntity.class, parentId, "data" );
assertEquals( 2, list.size() );
assertEquals( makeList( 1, 2 ), extractRevisionNumbers( list ) );
list = queryForPropertyHasChanged( ListRefEdEntity.class, parentId, "reffering" );
assertEquals( 2, list.size() );
assertEquals( makeList( 1, 2 ), extractRevisionNumbers( list ) );
list = queryForPropertyHasChanged( ListRefIngEntity.class, childId, "reference" );
assertEquals( 1, list.size() );
assertEquals( makeList( 2 ), extractRevisionNumbers( list ) );
}
}