Re-enabled additional tests
This commit is contained in:
parent
dc3b3db512
commit
f14e70cb8f
|
@ -80,7 +80,9 @@ import org.hibernate.sql.results.graph.FetchParent;
|
|||
import org.hibernate.sql.results.graph.Fetchable;
|
||||
import org.hibernate.sql.results.graph.FetchableContainer;
|
||||
import org.hibernate.sql.results.graph.collection.internal.CollectionDomainResult;
|
||||
import org.hibernate.sql.results.graph.collection.internal.CollectionFetch;
|
||||
import org.hibernate.sql.results.graph.entity.EntityValuedFetchable;
|
||||
import org.hibernate.sql.results.graph.entity.internal.EntityResultImpl;
|
||||
import org.hibernate.sql.results.internal.SqlSelectionImpl;
|
||||
import org.hibernate.sql.results.internal.StandardEntityGraphTraversalStateImpl;
|
||||
|
||||
|
@ -363,17 +365,12 @@ public class LoaderSelectBuilder {
|
|||
}
|
||||
|
||||
private SelectStatement generateSelect() {
|
||||
final Restrictable restrictable;
|
||||
if ( loadable instanceof PluralAttributeMapping ) {
|
||||
final PluralAttributeMapping pluralAttributeMapping = (PluralAttributeMapping) loadable;
|
||||
restrictable = (Restrictable) pluralAttributeMapping.getCollectionDescriptor();
|
||||
if ( pluralAttributeMapping.getMappedType().getCollectionSemantics() instanceof BagSemantics ) {
|
||||
currentBagRole = pluralAttributeMapping.getNavigableRole().getNavigableName();
|
||||
}
|
||||
}
|
||||
else {
|
||||
restrictable = (Restrictable) loadable;
|
||||
}
|
||||
|
||||
final NavigablePath rootNavigablePath = new NavigablePath( loadable.getRootPathName() );
|
||||
|
||||
|
@ -738,6 +735,7 @@ public class LoaderSelectBuilder {
|
|||
boolean explicitFetch = false;
|
||||
EntityGraphTraversalState.TraversalResult traversalResult = null;
|
||||
|
||||
final boolean isFetchablePluralAttributeMapping = fetchable instanceof PluralAttributeMapping;
|
||||
if ( !( fetchable instanceof CollectionPart ) ) {
|
||||
// 'entity graph' takes precedence over 'fetch profile'
|
||||
if ( entityGraphTraversalState != null ) {
|
||||
|
@ -774,7 +772,7 @@ public class LoaderSelectBuilder {
|
|||
if ( cascadeStyle == null || cascadeStyle.doCascade( cascadingAction ) ) {
|
||||
fetchTiming = FetchTiming.IMMEDIATE;
|
||||
// In 5.x the CascadeEntityJoinWalker only join fetched the first collection fetch
|
||||
if ( fetchable instanceof PluralAttributeMapping ) {
|
||||
if ( isFetchablePluralAttributeMapping ) {
|
||||
joined = !hasCollectionJoinFetches;
|
||||
}
|
||||
else {
|
||||
|
@ -786,7 +784,7 @@ public class LoaderSelectBuilder {
|
|||
|
||||
final String previousBagRole = currentBagRole;
|
||||
final String bagRole;
|
||||
if ( fetchable instanceof PluralAttributeMapping
|
||||
if ( isFetchablePluralAttributeMapping
|
||||
&& ( (PluralAttributeMapping) fetchable ).getMappedType()
|
||||
.getCollectionSemantics() instanceof BagSemantics ) {
|
||||
bagRole = fetchable.getNavigableRole().getNavigableName();
|
||||
|
@ -855,7 +853,7 @@ public class LoaderSelectBuilder {
|
|||
creationState
|
||||
);
|
||||
|
||||
if ( fetch.getTiming() == FetchTiming.IMMEDIATE && fetchable instanceof PluralAttributeMapping ) {
|
||||
if ( fetch.getTiming() == FetchTiming.IMMEDIATE && isFetchablePluralAttributeMapping ) {
|
||||
final PluralAttributeMapping pluralAttributeMapping = (PluralAttributeMapping) fetchable;
|
||||
if ( joined ) {
|
||||
hasCollectionJoinFetches = true;
|
||||
|
|
|
@ -584,7 +584,6 @@ public class BasicHibernateAnnotationsTest extends BaseCoreFunctionalTestCase {
|
|||
}
|
||||
|
||||
@Test
|
||||
// @NotImplementedYet(reason = "Support for custom composite types not implemented - org.hibernate.orm.test.annotations.entity.Ransom#getAmount")
|
||||
public void testCompositeType() throws Exception {
|
||||
Session s;
|
||||
Transaction tx;
|
||||
|
|
|
@ -8,6 +8,7 @@ package org.hibernate.orm.test.collection.original;
|
|||
|
||||
import jakarta.persistence.criteria.CriteriaBuilder;
|
||||
import jakarta.persistence.criteria.CriteriaQuery;
|
||||
import jakarta.persistence.criteria.Root;
|
||||
|
||||
import org.hibernate.Hibernate;
|
||||
import org.hibernate.engine.spi.SessionImplementor;
|
||||
|
@ -141,7 +142,12 @@ public class CollectionTest {
|
|||
|
||||
scope.inTransaction(
|
||||
s -> {
|
||||
User u2 = findUser( s );
|
||||
CriteriaBuilder criteriaBuilder = s.getCriteriaBuilder();
|
||||
CriteriaQuery<User> criteria = criteriaBuilder.createQuery( User.class );
|
||||
final Root<User> from = criteria.from( User.class );
|
||||
from.fetch( "emailAddresses" );
|
||||
|
||||
User u2 = s.createQuery( criteria ).uniqueResult();
|
||||
assertTrue( Hibernate.isInitialized( u2.getEmailAddresses() ) );
|
||||
assertFalse( Hibernate.isInitialized( u2.getPermissions() ) );
|
||||
assertEquals( 2, u2.getEmailAddresses().size() );
|
||||
|
|
|
@ -960,6 +960,7 @@ public class DynamicFilterTest extends BaseNonConfigCoreFunctionalTestCase {
|
|||
CriteriaBuilder criteriaBuilder = session.getCriteriaBuilder();
|
||||
CriteriaQuery<Product> criteria = criteriaBuilder.createQuery( Product.class );
|
||||
Root<Product> root = criteria.from( Product.class );
|
||||
root.fetch( "categories" );
|
||||
criteria.where( criteriaBuilder.equal( root.get( "id" ), testData.prod1Id ) );
|
||||
|
||||
List<Product> result = session.createQuery( criteria ).list();
|
||||
|
|
|
@ -6,6 +6,10 @@
|
|||
*/
|
||||
package org.hibernate.orm.test.mapping.collections.custom.basic;
|
||||
|
||||
import org.hibernate.Hibernate;
|
||||
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
/**
|
||||
* @author Steve Ebersole
|
||||
*/
|
||||
|
@ -14,4 +18,9 @@ public class UserCollectionTypeAnnotationsVariantTest extends UserCollectionType
|
|||
protected Class<?>[] getAnnotatedClasses() {
|
||||
return new Class[] { User.class, Email.class };
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void checkEmailAddressInitialization(User user) {
|
||||
assertTrue( Hibernate.isInitialized( user.getEmailAddresses() ) );
|
||||
}
|
||||
}
|
||||
|
|
|
@ -6,6 +6,11 @@
|
|||
*/
|
||||
package org.hibernate.orm.test.mapping.collections.custom.basic;
|
||||
|
||||
import org.hibernate.Hibernate;
|
||||
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
/**
|
||||
* @author Steve Ebersole
|
||||
*/
|
||||
|
@ -19,4 +24,9 @@ public class UserCollectionTypeHbmVariantTest extends UserCollectionTypeTest {
|
|||
public String[] getMappings() {
|
||||
return new String[] { "/org/hibernate/orm/test/mapping/collections/custom/basic/UserPermissions.hbm.xml" };
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void checkEmailAddressInitialization(User user) {
|
||||
assertFalse( Hibernate.isInitialized( user.getEmailAddresses() ) );
|
||||
}
|
||||
}
|
||||
|
|
|
@ -15,6 +15,7 @@ import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase;
|
|||
import org.junit.Test;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
/**
|
||||
|
@ -45,7 +46,7 @@ public abstract class UserCollectionTypeTest extends BaseNonConfigCoreFunctional
|
|||
criteria.from( User.class );
|
||||
User u2 = s.createQuery( criteria ).uniqueResult();
|
||||
// User u2 = (User) s.createCriteria(User.class).uniqueResult();
|
||||
assertTrue( Hibernate.isInitialized( u2.getEmailAddresses() ) );
|
||||
checkEmailAddressInitialization( u2 );
|
||||
assertEquals( u2.getEmailAddresses().size(), 2 );
|
||||
|
||||
}
|
||||
|
@ -65,5 +66,7 @@ public abstract class UserCollectionTypeTest extends BaseNonConfigCoreFunctional
|
|||
);
|
||||
}
|
||||
|
||||
protected abstract void checkEmailAddressInitialization(User user);
|
||||
|
||||
}
|
||||
|
||||
|
|
|
@ -20,7 +20,7 @@
|
|||
<class name="User" table="UC_BSC_USER">
|
||||
<id name="id"/>
|
||||
<property name="userName"/>
|
||||
<list name="emailAddresses" fetch="join" lazy="false" cascade="all, delete-orphan" collection-type="MyListType">
|
||||
<list name="emailAddresses" fetch="join" cascade="all, delete-orphan" collection-type="MyListType">
|
||||
<key column="userName"/>
|
||||
<list-index column="displayOrder" base="1"/>
|
||||
<one-to-many class="Email"/>
|
||||
|
|
|
@ -30,6 +30,10 @@
|
|||
*/
|
||||
package org.hibernate.orm.test.mapping.collections.custom.declaredtype;
|
||||
|
||||
import org.hibernate.Hibernate;
|
||||
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
/**
|
||||
* @author Steve Ebersole
|
||||
*/
|
||||
|
@ -38,4 +42,9 @@ public class UserCollectionTypeAnnotationsVariantTest extends UserCollectionType
|
|||
protected Class<?>[] getAnnotatedClasses() {
|
||||
return new Class[] { User.class, Email.class };
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void checkEmailAddressInitialization(User user) {
|
||||
assertTrue( Hibernate.isInitialized( user.getEmailAddresses() ) );
|
||||
}
|
||||
}
|
||||
|
|
|
@ -6,6 +6,10 @@
|
|||
*/
|
||||
package org.hibernate.orm.test.mapping.collections.custom.declaredtype;
|
||||
|
||||
import org.hibernate.Hibernate;
|
||||
|
||||
import static org.junit.Assert.assertFalse;
|
||||
|
||||
/**
|
||||
* @author Steve Ebersole
|
||||
*/
|
||||
|
@ -14,4 +18,9 @@ public class UserCollectionTypeHbmVariantTest extends UserCollectionTypeTest {
|
|||
public String[] getMappings() {
|
||||
return new String[] { "mapping/collections/custom/declaredtype/UserPermissions.hbm.xml" };
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void checkEmailAddressInitialization(User user) {
|
||||
assertFalse( Hibernate.isInitialized( user.getEmailAddresses() ) );
|
||||
}
|
||||
}
|
||||
|
|
|
@ -71,12 +71,15 @@ public abstract class UserCollectionTypeTest extends BaseCoreFunctionalTestCase
|
|||
criteria.from( User.class );
|
||||
User u2 = s.createQuery( criteria ).uniqueResult();
|
||||
// User u2 = (User) s.createCriteria(User.class).uniqueResult();
|
||||
assertTrue( Hibernate.isInitialized( u2.getEmailAddresses() ) );
|
||||
checkEmailAddressInitialization(u2);
|
||||
assertEquals( u2.getEmailAddresses().size(), 2 );
|
||||
assertNotNull( u2.getEmailAddresses().head());
|
||||
}
|
||||
);
|
||||
}
|
||||
|
||||
protected abstract void checkEmailAddressInitialization(User user);
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
|
|
@ -20,7 +20,7 @@
|
|||
<class name="User" table="UC_BSC_USER">
|
||||
<id name="id"/>
|
||||
<property name="userName"/>
|
||||
<list name="emailAddresses" fetch="join" lazy="false" cascade="all, delete-orphan" collection-type="HeadListType">
|
||||
<list name="emailAddresses" fetch="join" cascade="all, delete-orphan" collection-type="HeadListType">
|
||||
<key column="userName"/>
|
||||
<list-index column="displayOrder" base="1"/>
|
||||
<one-to-many class="Email"/>
|
||||
|
|
|
@ -45,7 +45,6 @@ import static org.junit.Assert.assertTrue;
|
|||
xmlMappings = "/mappings/subselectfetch/ParentChild.hbm.xml"
|
||||
)
|
||||
@SessionFactory( useCollectingStatementInspector = true )
|
||||
//@NotImplementedYet( strict = false, reason = "Need to check why these fail" )
|
||||
public class SubselectFetchTest {
|
||||
@BeforeEach
|
||||
public void prepareTestData(SessionFactoryScope scope) {
|
||||
|
|
|
@ -42,7 +42,6 @@ import jakarta.persistence.OneToMany;
|
|||
import org.hibernate.testing.orm.junit.DomainModel;
|
||||
import org.hibernate.testing.orm.junit.FailureExpected;
|
||||
import org.hibernate.testing.orm.junit.JiraKey;
|
||||
import org.hibernate.testing.orm.junit.NotImplementedYet;
|
||||
import org.hibernate.testing.orm.junit.SessionFactory;
|
||||
import org.hibernate.testing.orm.junit.SessionFactoryScope;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
|
|
@ -11,7 +11,6 @@ import java.util.List;
|
|||
import org.hibernate.Hibernate;
|
||||
|
||||
import org.hibernate.testing.orm.junit.DomainModel;
|
||||
import org.hibernate.testing.orm.junit.NotImplementedYet;
|
||||
import org.hibernate.testing.orm.junit.SessionFactory;
|
||||
import org.hibernate.testing.orm.junit.SessionFactoryScope;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
|
|
@ -7,6 +7,7 @@
|
|||
|
||||
//$Id: Bid.java 6793 2005-05-16 05:46:47Z oneovthafew $
|
||||
package org.hibernate.orm.test.query.joinfetch;
|
||||
|
||||
import java.util.Calendar;
|
||||
|
||||
/**
|
||||
|
|
|
@ -7,6 +7,7 @@
|
|||
|
||||
//$Id: Comment.java 6797 2005-05-16 12:08:03Z oneovthafew $
|
||||
package org.hibernate.orm.test.query.joinfetch;
|
||||
|
||||
import java.util.Calendar;
|
||||
|
||||
/**
|
||||
|
|
|
@ -7,6 +7,7 @@
|
|||
|
||||
//$Id: Group.java 7175 2005-06-17 05:23:15Z oneovthafew $
|
||||
package org.hibernate.orm.test.query.joinfetch;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
|
|
|
@ -7,6 +7,7 @@
|
|||
|
||||
//$Id: Item.java 6957 2005-05-31 04:21:58Z oneovthafew $
|
||||
package org.hibernate.orm.test.query.joinfetch;
|
||||
|
||||
import java.util.HashSet;
|
||||
import java.util.Set;
|
||||
|
||||
|
|
|
@ -14,9 +14,7 @@
|
|||
|
||||
-->
|
||||
|
||||
<hibernate-mapping
|
||||
package="org.hibernate.orm.test.query.joinfetch"
|
||||
default-access="field">
|
||||
<hibernate-mapping package="org.hibernate.orm.test.query.joinfetch" default-access="field">
|
||||
|
||||
<class name="Category" table="AuctionCategories">
|
||||
<id name="name"/>
|
||||
|
|
|
@ -7,21 +7,21 @@
|
|||
package org.hibernate.orm.test.query.joinfetch;
|
||||
|
||||
import java.util.List;
|
||||
import jakarta.persistence.criteria.CriteriaBuilder;
|
||||
import jakarta.persistence.criteria.CriteriaQuery;
|
||||
import jakarta.persistence.criteria.JoinType;
|
||||
import jakarta.persistence.criteria.Root;
|
||||
|
||||
import org.hibernate.Hibernate;
|
||||
|
||||
import org.hibernate.testing.orm.junit.DomainModel;
|
||||
import org.hibernate.testing.orm.junit.NotImplementedYet;
|
||||
import org.hibernate.testing.orm.junit.ServiceRegistry;
|
||||
import org.hibernate.testing.orm.junit.SessionFactory;
|
||||
import org.hibernate.testing.orm.junit.SessionFactoryScope;
|
||||
import org.hibernate.testing.orm.junit.Setting;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import jakarta.persistence.criteria.CriteriaBuilder;
|
||||
import jakarta.persistence.criteria.CriteriaQuery;
|
||||
import jakarta.persistence.criteria.JoinType;
|
||||
import jakarta.persistence.criteria.Root;
|
||||
|
||||
import static org.hibernate.cfg.AvailableSettings.MAX_FETCH_DEPTH;
|
||||
import static org.hibernate.cfg.AvailableSettings.USE_SECOND_LEVEL_CACHE;
|
||||
import static org.junit.Assert.assertEquals;
|
||||
|
@ -34,8 +34,8 @@ import static org.junit.Assert.assertTrue;
|
|||
*/
|
||||
@ServiceRegistry(
|
||||
settings = {
|
||||
@Setting( name = MAX_FETCH_DEPTH, value = "10" ),
|
||||
@Setting( name = USE_SECOND_LEVEL_CACHE, value = "false" )
|
||||
@Setting(name = MAX_FETCH_DEPTH, value = "10"),
|
||||
@Setting(name = USE_SECOND_LEVEL_CACHE, value = "false")
|
||||
}
|
||||
)
|
||||
@DomainModel(
|
||||
|
@ -47,27 +47,7 @@ import static org.junit.Assert.assertTrue;
|
|||
@SessionFactory
|
||||
public class JoinFetchTest {
|
||||
|
||||
// @Test
|
||||
// public void testProjection() {
|
||||
// inTransaction(
|
||||
// s -> {
|
||||
// CriteriaBuilder criteriaBuilder = s.getCriteriaBuilder();
|
||||
// CriteriaQuery<Long> criteria = criteriaBuilder.createQuery( Long.class );
|
||||
// criteria.select( criteriaBuilder.count( criteria.from( Item.class ) ) );
|
||||
// s.createQuery( criteria ).uniqueResult();
|
||||
//
|
||||
// CriteriaQuery<Item> itemCriteria = criteriaBuilder.createQuery( Item.class );
|
||||
// itemCriteria.from( Item.class );
|
||||
// s.createQuery( itemCriteria ).uniqueResult();
|
||||
//
|
||||
//// s.createCriteria(Item.class).setProjection( Projections.rowCount() ).uniqueResult();
|
||||
//// s.createCriteria(Item.class).uniqueResult();
|
||||
// }
|
||||
// );
|
||||
// }
|
||||
|
||||
@Test
|
||||
@NotImplementedYet( strict = false )
|
||||
public void testJoinFetch(SessionFactoryScope scope) {
|
||||
scope.inTransaction( (s) -> {
|
||||
s.createQuery( "delete from Bid" ).executeUpdate();
|
||||
|
@ -93,10 +73,10 @@ public class JoinFetchTest {
|
|||
|
||||
scope.inTransaction( (s) -> {
|
||||
Item i1 = s.get( Item.class, i.getId() );
|
||||
assertTrue( Hibernate.isInitialized( i1.getBids() ) );
|
||||
assertFalse( Hibernate.isInitialized( i1.getBids() ) );
|
||||
assertEquals( i1.getBids().size(), 2 );
|
||||
assertTrue( Hibernate.isInitialized( i1.getComments() ) );
|
||||
assertEquals( i1.getComments().size(), 3 );
|
||||
assertFalse( Hibernate.isInitialized( i1.getComments() ) );
|
||||
assertEquals( 3, i1.getComments().size() );
|
||||
} );
|
||||
|
||||
|
||||
|
@ -104,9 +84,9 @@ public class JoinFetchTest {
|
|||
|
||||
scope.inTransaction( (s) -> {
|
||||
Bid b1 = s.get( Bid.class, b.getId() );
|
||||
assertTrue( Hibernate.isInitialized( b1.getItem() ) );
|
||||
assertTrue( Hibernate.isInitialized( b1.getItem().getComments() ) );
|
||||
assertEquals( b1.getItem().getComments().size(), 3 );
|
||||
assertFalse( Hibernate.isInitialized( b1.getItem() ) );
|
||||
assertFalse( Hibernate.isInitialized( b1.getItem().getComments() ) );
|
||||
assertEquals( 3, b1.getItem().getComments().size() );
|
||||
} );
|
||||
|
||||
scope.getSessionFactory().getCache().evictCollectionData( Item.class.getName() + ".bids" );
|
||||
|
@ -131,20 +111,21 @@ public class JoinFetchTest {
|
|||
|
||||
|
||||
scope.inTransaction( (s) -> {
|
||||
Item i1 = (Item) s.createQuery( "from Item i left join fetch i.bids left join fetch i.comments" ).uniqueResult();
|
||||
Item i1 = (Item) s.createQuery( "from Item i left join fetch i.bids left join fetch i.comments" )
|
||||
.uniqueResult();
|
||||
assertTrue( Hibernate.isInitialized( i1.getBids() ) );
|
||||
assertTrue( Hibernate.isInitialized( i1.getComments() ) );
|
||||
assertEquals( i1.getComments().size(), 3 );
|
||||
assertEquals( i1.getBids().size(), 2 );
|
||||
assertEquals( 3, i1.getComments().size() );
|
||||
assertEquals( 2, i1.getBids().size() );
|
||||
} );
|
||||
|
||||
|
||||
scope.inTransaction( (s) -> {
|
||||
Item i1 = (Item) ((Object[])s.getNamedQuery( Item.class.getName() + ".all" ).list().get( 0 ))[0];
|
||||
Item i1 = (Item) s.getNamedQuery( Item.class.getName() + ".all" ).list().get( 0 );
|
||||
assertTrue( Hibernate.isInitialized( i1.getBids() ) );
|
||||
assertTrue( Hibernate.isInitialized( i1.getComments() ) );
|
||||
assertEquals( i1.getComments().size(), 3 );
|
||||
assertEquals( i1.getBids().size(), 2 );
|
||||
assertEquals( 3, i1.getComments().size() );
|
||||
assertEquals( 2, i1.getBids().size() );
|
||||
} );
|
||||
|
||||
scope.inTransaction( (s) -> {
|
||||
|
@ -154,12 +135,13 @@ public class JoinFetchTest {
|
|||
Item i1 = s.createQuery( criteria ).uniqueResult();
|
||||
assertFalse( Hibernate.isInitialized( i1.getBids() ) );
|
||||
assertFalse( Hibernate.isInitialized( i1.getComments() ) );
|
||||
assertEquals( i1.getComments().size(), 3 );
|
||||
assertEquals( i1.getBids().size(), 2 );
|
||||
assertEquals( 3, i1.getComments().size() );
|
||||
assertEquals( 2, i1.getBids().size() );
|
||||
} );
|
||||
|
||||
scope.inTransaction( (s) -> {
|
||||
List bids = s.createQuery( "select b from Bid b left join fetch b.item i left join fetch i.category" ).list();
|
||||
List bids = s.createQuery( "select b from Bid b left join fetch b.item i left join fetch i.category" )
|
||||
.list();
|
||||
Bid bid = (Bid) bids.get( 0 );
|
||||
assertTrue( Hibernate.isInitialized( bid.getItem() ) );
|
||||
assertTrue( Hibernate.isInitialized( bid.getItem().getCategory() ) );
|
||||
|
@ -172,7 +154,7 @@ public class JoinFetchTest {
|
|||
assertTrue( Hibernate.isInitialized( item.getCategory() ) );
|
||||
s.clear();
|
||||
pairs = s.createQuery( "select i, b from Item i left join i.bids b left join i.category" ).list();
|
||||
item = (Item) ((Object[])pairs.get( 0 ))[0];
|
||||
item = (Item) ( (Object[]) pairs.get( 0 ) )[0];
|
||||
assertFalse( Hibernate.isInitialized( item.getBids() ) );
|
||||
assertFalse( Hibernate.isInitialized( item.getCategory() ) );
|
||||
s.clear();
|
||||
|
@ -191,7 +173,7 @@ public class JoinFetchTest {
|
|||
assertTrue( Hibernate.isInitialized( bid.getItem() ) );
|
||||
assertFalse( Hibernate.isInitialized( bid.getItem().getCategory() ) );
|
||||
pairs = s.createQuery( "select b from Bid b left join b.item i left join i.category" ).list();
|
||||
bid = (Bid) pairs.get( 0 ) ;
|
||||
bid = (Bid) pairs.get( 0 );
|
||||
assertTrue( Hibernate.isInitialized( bid.getItem() ) );
|
||||
assertFalse( Hibernate.isInitialized( bid.getItem().getCategory() ) );
|
||||
} );
|
||||
|
@ -204,45 +186,7 @@ public class JoinFetchTest {
|
|||
} );
|
||||
}
|
||||
|
||||
// @Test
|
||||
// public void testCollectionFilter() {
|
||||
// inTransaction(
|
||||
// s -> {
|
||||
// Group hb = new Group( "hibernate" );
|
||||
// User gavin = new User( "gavin" );
|
||||
// User max = new User( "max" );
|
||||
// hb.getUsers().put( "gavin", gavin );
|
||||
// hb.getUsers().put( "max", max );
|
||||
// gavin.getGroups().put( "hibernate", hb );
|
||||
// max.getGroups().put( "hibernate", hb );
|
||||
// s.persist( hb );
|
||||
// }
|
||||
// );
|
||||
//
|
||||
// inTransaction(
|
||||
// s -> {
|
||||
// CriteriaBuilder criteriaBuilder = s.getCriteriaBuilder();
|
||||
// CriteriaQuery<Group> criteria = criteriaBuilder.createQuery( Group.class );
|
||||
// Root<Group> from = criteria.from( Group.class );
|
||||
//// from.join( "users", JoinType.LEFT );
|
||||
// criteria.where( criteriaBuilder.equal( from.get( "name" ), "hibernate" ) );
|
||||
// Group hb = s.createQuery( criteria ).uniqueResult();
|
||||
//// hb = (Group) s.createCriteria( Group.class )
|
||||
//// .setFetchMode( "users", FetchMode.SELECT )
|
||||
//// .add( Restrictions.idEq( "hibernate" ) )
|
||||
//// .uniqueResult();
|
||||
//// assertFalse( Hibernate.isInitialized( hb.getUsers() ) );
|
||||
//// gavin = (User) s.createFilter( hb.getUsers(), "where index(this) = 'gavin'" ).uniqueResult();
|
||||
//// Long size = (Long) s.createFilter( hb.getUsers(), "select count(*)" ).uniqueResult();
|
||||
//// assertEquals( new Long( 2 ), size );
|
||||
//// assertFalse( Hibernate.isInitialized( hb.getUsers() ) );
|
||||
// s.delete( hb );
|
||||
// }
|
||||
// );
|
||||
// }
|
||||
|
||||
@Test
|
||||
@NotImplementedYet( strict = false )
|
||||
public void testJoinFetchManyToMany(SessionFactoryScope scope) {
|
||||
Group group = new Group( "hibernate" );
|
||||
|
||||
|
@ -258,7 +202,7 @@ public class JoinFetchTest {
|
|||
|
||||
scope.inTransaction( (s) -> {
|
||||
Group hb = s.get( Group.class, "hibernate" );
|
||||
assertTrue( Hibernate.isInitialized( hb.getUsers() ) );
|
||||
assertFalse( Hibernate.isInitialized( hb.getUsers() ) );
|
||||
User gavin = (User) hb.getUsers().get( "gavin" );
|
||||
assertFalse( Hibernate.isInitialized( gavin.getGroups() ) );
|
||||
User max = s.get( User.class, "max" );
|
||||
|
|
|
@ -7,6 +7,7 @@
|
|||
|
||||
//$Id: User.java 7175 2005-06-17 05:23:15Z oneovthafew $
|
||||
package org.hibernate.orm.test.query.joinfetch;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
|
|
|
@ -14,9 +14,7 @@
|
|||
|
||||
-->
|
||||
|
||||
<hibernate-mapping
|
||||
package="org.hibernate.orm.test.query.joinfetch"
|
||||
default-access="field">
|
||||
<hibernate-mapping package="org.hibernate.orm.test.query.joinfetch" default-access="field">
|
||||
|
||||
<class name="User" table="AuctionUsers">
|
||||
<id name="name"/>
|
||||
|
|
|
@ -23,7 +23,6 @@ import org.hibernate.query.Query;
|
|||
|
||||
import org.hibernate.testing.orm.junit.DomainModel;
|
||||
import org.hibernate.testing.orm.junit.JiraKey;
|
||||
import org.hibernate.testing.orm.junit.NotImplementedYet;
|
||||
import org.hibernate.testing.orm.junit.RequiresDialect;
|
||||
import org.hibernate.testing.orm.junit.ServiceRegistry;
|
||||
import org.hibernate.testing.orm.junit.SessionFactory;
|
||||
|
@ -49,8 +48,6 @@ import static org.junit.jupiter.api.Assertions.assertEquals;
|
|||
)
|
||||
@SessionFactory( useCollectingStatementInspector = true )
|
||||
@RequiresDialect(AbstractHANADialect.class)
|
||||
// afaik this does not work
|
||||
//@NotImplementedYet( strict = false )
|
||||
public class QueryHintHANATest {
|
||||
|
||||
@BeforeEach
|
||||
|
|
|
@ -14,7 +14,6 @@ import org.hibernate.stat.spi.StatisticsImplementor;
|
|||
import org.hibernate.testing.jdbc.SQLStatementInspector;
|
||||
import org.hibernate.testing.orm.domain.gambit.EntityWithManyToOneSelfReference;
|
||||
import org.hibernate.testing.orm.junit.DomainModel;
|
||||
import org.hibernate.testing.orm.junit.FailureExpected;
|
||||
import org.hibernate.testing.orm.junit.NotImplementedYet;
|
||||
import org.hibernate.testing.orm.junit.ServiceRegistry;
|
||||
import org.hibernate.testing.orm.junit.SessionFactory;
|
||||
|
|
Loading…
Reference in New Issue