HHH-9933 - Uninitialized PersistentSet with lazy="extra" doesn't respect added elements

This commit is contained in:
lrcuhuh 2015-07-16 14:15:23 +02:00 committed by Vlad Mihalcea
parent cd4a6e9a49
commit 63e4702629
3 changed files with 137 additions and 4 deletions

View File

@ -329,8 +329,8 @@ public class PersistentSet extends AbstractPersistentCollection implements java.
public boolean endRead() { public boolean endRead() {
set.addAll( tempList ); set.addAll( tempList );
tempList = null; tempList = null;
setInitialized(); // ensure that operationQueue is considered
return true; return super.endRead();
} }
@Override @Override

View File

@ -0,0 +1,130 @@
/*
* 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.extralazy;
import org.hibernate.testing.TestForIssue;
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
import org.junit.Test;
import static org.hibernate.testing.transaction.TransactionUtil.doInHibernate;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue;
/**
* @author Vlad Mihalcea
*/
public class ExtraLazyCollectionConsistencyTest extends BaseCoreFunctionalTestCase {
private User user;
@Override
public String[] getMappings() {
return new String[] { "extralazy/UserGroup.hbm.xml","extralazy/Parent.hbm.xml","extralazy/Child.hbm.xml" };
}
@Override
protected void prepareTest() {
doInHibernate( this::sessionFactory, session -> {
user = new User("victor", "hugo");
session.persist(user);
});
}
@Override
protected boolean isCleanupTestDataRequired() {
return true;
}
@Test
@TestForIssue(jiraKey = "HHH-9933")
public void testSetSize() {
doInHibernate( this::sessionFactory, session -> {
User _user = session.get(User.class, user.getName());
Document document = new Document("Les Miserables", "sad", _user);
assertEquals(1, _user.getDocuments().size());
});
}
@Test
@TestForIssue(jiraKey = "HHH-9933")
public void testSetIterator() {
doInHibernate( this::sessionFactory, session -> {
User _user = session.get(User.class, user.getName());
Document document = new Document("Les Miserables", "sad", _user);
assertTrue(_user.getDocuments().iterator().hasNext());
});
}
@Test
@TestForIssue(jiraKey = "HHH-9933")
public void testSetIsEmpty() {
doInHibernate( this::sessionFactory, session -> {
User _user = session.get(User.class, user.getName());
Document document = new Document("Les Miserables", "sad", _user);
assertFalse(_user.getDocuments().isEmpty());
});
}
@Test
@TestForIssue(jiraKey = "HHH-9933")
public void testSetContains() {
doInHibernate( this::sessionFactory, session -> {
User _user = session.get(User.class, user.getName());
Document document = new Document("Les Miserables", "sad", _user);
assertTrue(_user.getDocuments().contains(document));
});
}
@Test
@TestForIssue(jiraKey = "HHH-9933")
public void testSetAdd() {
doInHibernate( this::sessionFactory, session -> {
User _user = session.get(User.class, user.getName());
Document document = new Document();
document.setTitle("Les Miserables");
document.setContent("sad");
document.setOwner(_user);
assertTrue("not added", _user.getDocuments().add(document));
assertFalse("added", _user.getDocuments().add(document));
});
}
@Test
@TestForIssue(jiraKey = "HHH-9933")
public void testSetRemove() {
doInHibernate( this::sessionFactory, session -> {
User _user = session.get(User.class, user.getName());
Document document = new Document("Les Miserables", "sad", _user);
assertTrue("not removed", _user.getDocuments().remove(document));
});
}
@Test
@TestForIssue(jiraKey = "HHH-9933")
public void testSetToArray() {
doInHibernate( this::sessionFactory, session -> {
User _user = session.get(User.class, user.getName());
Document document = new Document("Les Miserables", "sad", _user);
assertEquals(1, _user.getDocuments().toArray().length);
});
}
@Test
@TestForIssue(jiraKey = "HHH-9933")
public void testSetToArrayTyped() {
doInHibernate( this::sessionFactory, session -> {
User _user = session.get(User.class, user.getName());
Document document = new Document("Les Miserables", "sad", _user);
assertEquals(1, _user.getDocuments().toArray(new Document[0]).length);
});
}
}

View File

@ -18,8 +18,11 @@ import org.hibernate.testing.FailureExpected;
import org.hibernate.testing.RequiresDialectFeature; import org.hibernate.testing.RequiresDialectFeature;
import org.hibernate.testing.TestForIssue; import org.hibernate.testing.TestForIssue;
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase; import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
import org.hibernate.test.naturalid.inheritance.cache.ExtendedEntity;
import org.hibernate.test.naturalid.inheritance.cache.MyEntity;
import org.junit.Test; import org.junit.Test;
import static org.hibernate.testing.transaction.TransactionUtil.doInHibernate;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNotNull;
@ -34,7 +37,7 @@ public class ExtraLazyTest extends BaseCoreFunctionalTestCase {
public String[] getMappings() { public String[] getMappings() {
return new String[] { "extralazy/UserGroup.hbm.xml","extralazy/Parent.hbm.xml","extralazy/Child.hbm.xml" }; return new String[] { "extralazy/UserGroup.hbm.xml","extralazy/Parent.hbm.xml","extralazy/Child.hbm.xml" };
} }
@Override @Override
protected Class<?>[] getAnnotatedClasses() { protected Class<?>[] getAnnotatedClasses() {
return new Class<?>[] { School.class, Student.class, Championship.class }; return new Class<?>[] { School.class, Student.class, Championship.class };
@ -255,7 +258,7 @@ public class ExtraLazyTest extends BaseCoreFunctionalTestCase {
assertNotNull(child2); assertNotNull(child2);
session2.close(); session2.close();
} }
@Test @Test
@TestForIssue(jiraKey = "HHH-10874") @TestForIssue(jiraKey = "HHH-10874")
public void testWhereClauseOnBidirectionalCollection() { public void testWhereClauseOnBidirectionalCollection() {