6 - SQM based on JPA type system
- focus on reducing compilation errors
This commit is contained in:
parent
3d5209d105
commit
1713e82d24
|
@ -29,8 +29,6 @@ import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
|
||||||
import org.hibernate.boot.spi.MetadataImplementor;
|
import org.hibernate.boot.spi.MetadataImplementor;
|
||||||
import org.hibernate.cfg.AvailableSettings;
|
import org.hibernate.cfg.AvailableSettings;
|
||||||
import org.hibernate.cfg.Configuration;
|
import org.hibernate.cfg.Configuration;
|
||||||
import org.hibernate.engine.spi.SessionFactoryImplementor;
|
|
||||||
import org.hibernate.hql.internal.ast.tree.JavaConstantNode;
|
|
||||||
import org.hibernate.internal.util.ConfigHelper;
|
import org.hibernate.internal.util.ConfigHelper;
|
||||||
import org.hibernate.mapping.PersistentClass;
|
import org.hibernate.mapping.PersistentClass;
|
||||||
import org.hibernate.mapping.Property;
|
import org.hibernate.mapping.Property;
|
||||||
|
@ -349,18 +347,11 @@ public class AttributeConverterTest extends BaseUnitTestCase {
|
||||||
|
|
||||||
s = sf.openSession();
|
s = sf.openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
entity = (EntityWithConvertibleField) s.load( EntityWithConvertibleField.class, entityID );
|
entity = s.load( EntityWithConvertibleField.class, entityID );
|
||||||
assertEquals( ConvertibleEnum.VALUE, entity.getConvertibleEnum() );
|
assertEquals( ConvertibleEnum.VALUE, entity.getConvertibleEnum() );
|
||||||
s.getTransaction().commit();
|
s.getTransaction().commit();
|
||||||
s.close();
|
s.close();
|
||||||
|
|
||||||
JavaConstantNode javaConstantNode = new JavaConstantNode();
|
|
||||||
javaConstantNode.setExpectedType( type );
|
|
||||||
javaConstantNode.setSessionFactory( (SessionFactoryImplementor) sf );
|
|
||||||
javaConstantNode.setText( "org.hibernate.test.converter.AttributeConverterTest$ConvertibleEnum.VALUE" );
|
|
||||||
final String outcome = javaConstantNode.getRenderText( (SessionFactoryImplementor) sf );
|
|
||||||
assertEquals( "'VALUE'", outcome );
|
|
||||||
|
|
||||||
s = sf.openSession();
|
s = sf.openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
s.createQuery( "FROM EntityWithConvertibleField e where e.convertibleEnum = org.hibernate.test.converter.AttributeConverterTest$ConvertibleEnum.VALUE" )
|
s.createQuery( "FROM EntityWithConvertibleField e where e.convertibleEnum = org.hibernate.test.converter.AttributeConverterTest$ConvertibleEnum.VALUE" )
|
||||||
|
|
|
@ -14,9 +14,9 @@ import javax.persistence.InheritanceType;
|
||||||
import javax.persistence.MappedSuperclass;
|
import javax.persistence.MappedSuperclass;
|
||||||
|
|
||||||
import org.hibernate.cfg.AnnotationBinder;
|
import org.hibernate.cfg.AnnotationBinder;
|
||||||
import org.hibernate.hql.internal.ast.QuerySyntaxException;
|
|
||||||
import org.hibernate.internal.CoreMessageLogger;
|
import org.hibernate.internal.CoreMessageLogger;
|
||||||
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
||||||
|
import org.hibernate.query.SemanticException;
|
||||||
|
|
||||||
import org.hibernate.testing.TestForIssue;
|
import org.hibernate.testing.TestForIssue;
|
||||||
import org.hibernate.testing.logger.LoggerInspectionRule;
|
import org.hibernate.testing.logger.LoggerInspectionRule;
|
||||||
|
@ -75,7 +75,7 @@ public class MappedSuperclassInheritanceTest extends BaseEntityManagerFunctional
|
||||||
entityManager.createQuery("from Employee").getResultList();
|
entityManager.createQuery("from Employee").getResultList();
|
||||||
fail();
|
fail();
|
||||||
} catch (Exception expected) {
|
} catch (Exception expected) {
|
||||||
QuerySyntaxException rootException = (QuerySyntaxException) ExceptionUtil.rootCause(expected);
|
SemanticException rootException = (SemanticException) ExceptionUtil.rootCause( expected);
|
||||||
assertEquals("Employee is not mapped", rootException.getMessage());
|
assertEquals("Employee is not mapped", rootException.getMessage());
|
||||||
}
|
}
|
||||||
} );
|
} );
|
||||||
|
|
|
@ -25,13 +25,11 @@ package org.hibernate.test.inheritance.discriminator;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import javax.persistence.AssociationOverride;
|
import javax.persistence.AssociationOverride;
|
||||||
import javax.persistence.AssociationOverrides;
|
import javax.persistence.AssociationOverrides;
|
||||||
import javax.persistence.Basic;
|
import javax.persistence.Basic;
|
||||||
|
@ -52,14 +50,12 @@ import javax.persistence.MappedSuperclass;
|
||||||
import javax.persistence.OneToMany;
|
import javax.persistence.OneToMany;
|
||||||
import javax.persistence.OrderColumn;
|
import javax.persistence.OrderColumn;
|
||||||
|
|
||||||
import org.hibernate.hql.spi.QueryTranslator;
|
import org.hibernate.NotYetImplementedFor6Exception;
|
||||||
|
|
||||||
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.hibernate.testing.transaction.TransactionUtil.doInHibernate;
|
import static org.hibernate.testing.transaction.TransactionUtil.doInHibernate;
|
||||||
import static org.junit.Assert.assertEquals;
|
|
||||||
import static org.junit.Assert.assertNotEquals;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Christian Beikov
|
* @author Christian Beikov
|
||||||
|
@ -116,27 +112,28 @@ public class MultiInheritanceImplicitDowncastTest extends BaseCoreFunctionalTest
|
||||||
}
|
}
|
||||||
|
|
||||||
private void testMultiJoinAddition(String hql) {
|
private void testMultiJoinAddition(String hql) {
|
||||||
final HQLQueryPlan plan = sessionFactory().getQueryInterpretationCache().getHQLQueryPlan(
|
throw new NotYetImplementedFor6Exception( getClass() );
|
||||||
hql,
|
// final HQLQueryPlan plan = sessionFactory().getQueryInterpretationCache().getHQLQueryPlan(
|
||||||
false,
|
// hql,
|
||||||
Collections.EMPTY_MAP
|
// false,
|
||||||
);
|
// Collections.EMPTY_MAP
|
||||||
assertEquals( 1, plan.getTranslators().length );
|
// );
|
||||||
final QueryTranslator translator = plan.getTranslators()[0];
|
// assertEquals( 1, plan.getTranslators().length );
|
||||||
final String generatedSql = translator.getSQLString();
|
// final QueryTranslator translator = plan.getTranslators()[0];
|
||||||
|
// final String generatedSql = translator.getSQLString();
|
||||||
int sub1JoinColumnIndex = generatedSql.indexOf( ".base_sub_1" );
|
//
|
||||||
assertNotEquals(
|
// int sub1JoinColumnIndex = generatedSql.indexOf( ".base_sub_1" );
|
||||||
"Generated SQL doesn't contain a join for 'base' with 'PolymorphicSub1' via 'base_sub_1':\n" + generatedSql,
|
// assertNotEquals(
|
||||||
-1,
|
// "Generated SQL doesn't contain a join for 'base' with 'PolymorphicSub1' via 'base_sub_1':\n" + generatedSql,
|
||||||
sub1JoinColumnIndex
|
// -1,
|
||||||
);
|
// sub1JoinColumnIndex
|
||||||
int sub2JoinColumnIndex = generatedSql.indexOf( ".base_sub_2" );
|
// );
|
||||||
assertNotEquals(
|
// int sub2JoinColumnIndex = generatedSql.indexOf( ".base_sub_2" );
|
||||||
"Generated SQL doesn't contain a join for 'base' with 'PolymorphicSub2' via 'base_sub_2':\n" + generatedSql,
|
// assertNotEquals(
|
||||||
-1,
|
// "Generated SQL doesn't contain a join for 'base' with 'PolymorphicSub2' via 'base_sub_2':\n" + generatedSql,
|
||||||
sub2JoinColumnIndex
|
// -1,
|
||||||
);
|
// sub2JoinColumnIndex
|
||||||
|
// );
|
||||||
}
|
}
|
||||||
|
|
||||||
@MappedSuperclass
|
@MappedSuperclass
|
||||||
|
|
|
@ -6,8 +6,11 @@
|
||||||
*/
|
*/
|
||||||
package org.hibernate.test.inheritance.discriminator.joinedsubclass;
|
package org.hibernate.test.inheritance.discriminator.joinedsubclass;
|
||||||
|
|
||||||
|
import javax.persistence.criteria.CriteriaBuilder;
|
||||||
|
import javax.persistence.criteria.CriteriaQuery;
|
||||||
|
import javax.persistence.criteria.Root;
|
||||||
|
|
||||||
import org.hibernate.Transaction;
|
import org.hibernate.Transaction;
|
||||||
import org.hibernate.criterion.Restrictions;
|
|
||||||
import org.hibernate.resource.transaction.spi.TransactionStatus;
|
import org.hibernate.resource.transaction.spi.TransactionStatus;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
|
@ -84,9 +87,11 @@ public class JoinedSubclassTest extends BaseCoreFunctionalTestCase {
|
||||||
public void shouldRetrieveSubSubEntityWithCriteria() {
|
public void shouldRetrieveSubSubEntityWithCriteria() {
|
||||||
session = openSession();
|
session = openSession();
|
||||||
try {
|
try {
|
||||||
SubSubEntity loaded = (SubSubEntity) session.createCriteria( SubSubEntity.class )
|
final CriteriaBuilder criteriaBuilder = session.getSessionFactory().getCriteriaBuilder();
|
||||||
.add( Restrictions.idEq( subSubEntityId ) )
|
final CriteriaQuery<SubSubEntity> criteria = criteriaBuilder.createQuery( SubSubEntity.class );
|
||||||
.uniqueResult();
|
final Root<SubSubEntity> root = criteria.from( SubSubEntity.class );
|
||||||
|
criteria.where( criteriaBuilder.equal( root.get( SubSubEntity_.id ), subSubEntityId ) );
|
||||||
|
final SubSubEntity loaded = session.createQuery( criteria ).uniqueResult();
|
||||||
assertNotNull( loaded );
|
assertNotNull( loaded );
|
||||||
}
|
}
|
||||||
finally {
|
finally {
|
||||||
|
@ -98,9 +103,12 @@ public class JoinedSubclassTest extends BaseCoreFunctionalTestCase {
|
||||||
public void shouldNotRetrieveSubSubSubEntityWithCriteria() {
|
public void shouldNotRetrieveSubSubSubEntityWithCriteria() {
|
||||||
session = openSession();
|
session = openSession();
|
||||||
try {
|
try {
|
||||||
SubSubSubEntity loaded = (SubSubSubEntity) session.createCriteria( SubSubSubEntity.class )
|
final CriteriaBuilder criteriaBuilder = session.getSessionFactory().getCriteriaBuilder();
|
||||||
.add( Restrictions.idEq( subSubEntityId ) )
|
final CriteriaQuery<SubSubSubEntity> criteria = criteriaBuilder.createQuery( SubSubSubEntity.class );
|
||||||
.uniqueResult();
|
final Root<SubSubSubEntity> root = criteria.from( SubSubSubEntity.class );
|
||||||
|
|
||||||
|
criteria.where( criteriaBuilder.equal( root.get( SubSubSubEntity_.id ), subSubEntityId ) );
|
||||||
|
final SubSubEntity loaded = session.createQuery( criteria ).uniqueResult();
|
||||||
assertNull( loaded );
|
assertNull( loaded );
|
||||||
}
|
}
|
||||||
finally {
|
finally {
|
||||||
|
@ -116,7 +124,7 @@ public class JoinedSubclassTest extends BaseCoreFunctionalTestCase {
|
||||||
try {
|
try {
|
||||||
SubSubEntity loaded = (SubSubEntity) session.createQuery(
|
SubSubEntity loaded = (SubSubEntity) session.createQuery(
|
||||||
"select se from SubSubEntity se where se.id = :id" )
|
"select se from SubSubEntity se where se.id = :id" )
|
||||||
.setLong( "id", subSubEntityId )
|
.setParameter( "id", subSubEntityId )
|
||||||
.uniqueResult();
|
.uniqueResult();
|
||||||
assertNotNull( loaded );
|
assertNotNull( loaded );
|
||||||
}
|
}
|
||||||
|
@ -131,7 +139,7 @@ public class JoinedSubclassTest extends BaseCoreFunctionalTestCase {
|
||||||
try {
|
try {
|
||||||
SubSubSubEntity loaded = (SubSubSubEntity) session.createQuery(
|
SubSubSubEntity loaded = (SubSubSubEntity) session.createQuery(
|
||||||
"select se from SubSubSubEntity se where se.id = :id" )
|
"select se from SubSubSubEntity se where se.id = :id" )
|
||||||
.setLong( "id", subSubEntityId )
|
.setParameter( "id", subSubEntityId )
|
||||||
.uniqueResult();
|
.uniqueResult();
|
||||||
assertNull( loaded );
|
assertNull( loaded );
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,9 +9,8 @@ package org.hibernate.test.naturalid.cid;
|
||||||
import org.hibernate.Session;
|
import org.hibernate.Session;
|
||||||
import org.hibernate.cfg.Configuration;
|
import org.hibernate.cfg.Configuration;
|
||||||
import org.hibernate.cfg.Environment;
|
import org.hibernate.cfg.Environment;
|
||||||
import org.hibernate.criterion.Restrictions;
|
|
||||||
|
|
||||||
import org.hibernate.persister.entity.EntityPersister;
|
import org.hibernate.persister.entity.EntityPersister;
|
||||||
|
|
||||||
import org.hibernate.testing.TestForIssue;
|
import org.hibernate.testing.TestForIssue;
|
||||||
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -72,10 +71,7 @@ public class CompositeIdAndNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
|
|
||||||
s = openSession();
|
s = openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
u = ( Account ) s.createCriteria( Account.class )
|
u = s.bySimpleNaturalId( Account.class ).load( "testAcct" );
|
||||||
.add( Restrictions.naturalId().set( "shortCode", "testAcct" ) )
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull( u );
|
assertNotNull( u );
|
||||||
s.getTransaction().commit();
|
s.getTransaction().commit();
|
||||||
s.close();
|
s.close();
|
||||||
|
|
|
@ -6,21 +6,19 @@
|
||||||
*/
|
*/
|
||||||
package org.hibernate.test.naturalid.immutable;
|
package org.hibernate.test.naturalid.immutable;
|
||||||
|
|
||||||
import javax.persistence.PersistenceException;
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
|
import javax.persistence.PersistenceException;
|
||||||
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
import org.hibernate.FetchMode;
|
|
||||||
import org.hibernate.Session;
|
import org.hibernate.Session;
|
||||||
import org.hibernate.Transaction;
|
import org.hibernate.Transaction;
|
||||||
import org.hibernate.cfg.Configuration;
|
import org.hibernate.cfg.Configuration;
|
||||||
import org.hibernate.cfg.Environment;
|
import org.hibernate.cfg.Environment;
|
||||||
import org.hibernate.criterion.Restrictions;
|
|
||||||
import org.hibernate.persister.entity.EntityPersister;
|
import org.hibernate.persister.entity.EntityPersister;
|
||||||
|
import org.hibernate.tuple.entity.EntityMetamodel;
|
||||||
|
|
||||||
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.tuple.entity.EntityMetamodel;
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.junit.Assert.assertFalse;
|
import static org.junit.Assert.assertFalse;
|
||||||
import static org.junit.Assert.fail;
|
import static org.junit.Assert.fail;
|
||||||
|
@ -107,11 +105,9 @@ public class ImmutableEntityNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
s = openSession();
|
s = openSession();
|
||||||
t = s.beginTransaction();
|
t = s.beginTransaction();
|
||||||
|
|
||||||
p = (Parent) s.createCriteria(Parent.class)
|
p = s.createQuery( "from Parent p join fetch p.children where p.name = 'alex'", Parent.class )
|
||||||
.add( Restrictions.eq("name", "alex") )
|
.setCacheable( true )
|
||||||
.setFetchMode("children", FetchMode.JOIN)
|
.uniqueResult();
|
||||||
.setCacheable(true)
|
|
||||||
.uniqueResult();
|
|
||||||
|
|
||||||
t.commit();
|
t.commit();
|
||||||
s.close();
|
s.close();
|
||||||
|
|
|
@ -8,17 +8,15 @@ package org.hibernate.test.naturalid.immutable;
|
||||||
|
|
||||||
import javax.persistence.PersistenceException;
|
import javax.persistence.PersistenceException;
|
||||||
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
import org.hibernate.HibernateException;
|
|
||||||
import org.hibernate.Session;
|
import org.hibernate.Session;
|
||||||
import org.hibernate.Transaction;
|
import org.hibernate.Transaction;
|
||||||
import org.hibernate.cfg.Configuration;
|
import org.hibernate.cfg.Configuration;
|
||||||
import org.hibernate.cfg.Environment;
|
import org.hibernate.cfg.Environment;
|
||||||
import org.hibernate.criterion.Restrictions;
|
|
||||||
import org.hibernate.persister.entity.EntityPersister;
|
import org.hibernate.persister.entity.EntityPersister;
|
||||||
|
|
||||||
import org.hibernate.testing.TestForIssue;
|
import org.hibernate.testing.TestForIssue;
|
||||||
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertFalse;
|
import static org.junit.Assert.assertFalse;
|
||||||
|
@ -112,10 +110,7 @@ public class ImmutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
|
|
||||||
s = openSession();
|
s = openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.bySimpleNaturalId( User.class ).load( "steve" );
|
||||||
.add( Restrictions.naturalId().set( "userName", "steve" ) )
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull( u );
|
assertNotNull( u );
|
||||||
s.getTransaction().commit();
|
s.getTransaction().commit();
|
||||||
s.close();
|
s.close();
|
||||||
|
@ -135,17 +130,11 @@ public class ImmutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
|
|
||||||
s = openSession();
|
s = openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.bySimpleNaturalId( User.class ).load( "steve" );
|
||||||
.add( Restrictions.naturalId().set( "userName", "steve" ) )
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull( u );
|
assertNotNull( u );
|
||||||
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() ); //0: incorrect stats since hbm.xml can't enable NaturalId caching
|
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() ); //0: incorrect stats since hbm.xml can't enable NaturalId caching
|
||||||
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() ); //1: no stats since hbm.xml can't enable NaturalId caching
|
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() ); //1: no stats since hbm.xml can't enable NaturalId caching
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.bySimpleNaturalId( User.class ).load( "steve" );
|
||||||
.add( Restrictions.naturalId().set( "userName", "steve" ) )
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull( u );
|
assertNotNull( u );
|
||||||
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() ); //0: incorrect stats since hbm.xml can't enable NaturalId caching
|
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() ); //0: incorrect stats since hbm.xml can't enable NaturalId caching
|
||||||
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() ); //2: no stats since hbm.xml can't enable NaturalId caching
|
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() ); //2: no stats since hbm.xml can't enable NaturalId caching
|
||||||
|
@ -172,10 +161,7 @@ public class ImmutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
|
|
||||||
s = openSession();
|
s = openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.bySimpleNaturalId( User.class ).load( "steve" );
|
||||||
.add( Restrictions.naturalId().set( "userName", "steve" ) )
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull( u );
|
assertNotNull( u );
|
||||||
s.getTransaction().commit();
|
s.getTransaction().commit();
|
||||||
s.close();
|
s.close();
|
||||||
|
@ -188,11 +174,7 @@ public class ImmutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
|
|
||||||
s = openSession();
|
s = openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.bySimpleNaturalId( User.class ).load( "steve" );
|
||||||
.add( Restrictions.naturalId().set( "userName", "steve" ) )
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull( u );
|
|
||||||
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() ); //0: incorrect stats since hbm.xml can't enable NaturalId caching
|
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() ); //0: incorrect stats since hbm.xml can't enable NaturalId caching
|
||||||
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() ); //1: no stats since hbm.xml can't enable NaturalId caching
|
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() ); //1: no stats since hbm.xml can't enable NaturalId caching
|
||||||
|
|
||||||
|
@ -203,10 +185,7 @@ public class ImmutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
|
|
||||||
s = openSession();
|
s = openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.bySimpleNaturalId( User.class ).load( "steve" );
|
||||||
.add( Restrictions.naturalId().set( "userName", "steve" ) )
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNull( u );
|
assertNull( u );
|
||||||
s.getTransaction().commit();
|
s.getTransaction().commit();
|
||||||
s.close();
|
s.close();
|
||||||
|
@ -227,10 +206,7 @@ public class ImmutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
|
|
||||||
s = openSession();
|
s = openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.bySimpleNaturalId( User.class ).load( "steve" );
|
||||||
.add( Restrictions.naturalId().set( "userName", "steve" ) )
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull( u );
|
assertNotNull( u );
|
||||||
|
|
||||||
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() );
|
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() );
|
||||||
|
@ -241,10 +217,7 @@ public class ImmutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
s.getTransaction().commit();
|
s.getTransaction().commit();
|
||||||
s = openSession();
|
s = openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.bySimpleNaturalId( User.class ).load( "steve" );
|
||||||
.add( Restrictions.naturalId().set( "userName", "steve" ) )
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull( u );
|
assertNotNull( u );
|
||||||
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() ); //0: incorrect stats since hbm.xml can't enable NaturalId caching
|
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() ); //0: incorrect stats since hbm.xml can't enable NaturalId caching
|
||||||
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() ); //1: no stats since hbm.xml can't enable NaturalId caching
|
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() ); //1: no stats since hbm.xml can't enable NaturalId caching
|
||||||
|
|
|
@ -8,19 +8,18 @@ package org.hibernate.test.naturalid.mutable;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
import org.hibernate.HibernateException;
|
import org.hibernate.HibernateException;
|
||||||
import org.hibernate.LockOptions;
|
import org.hibernate.LockOptions;
|
||||||
import org.hibernate.Session;
|
import org.hibernate.Session;
|
||||||
import org.hibernate.Transaction;
|
import org.hibernate.Transaction;
|
||||||
import org.hibernate.cfg.Configuration;
|
import org.hibernate.cfg.Configuration;
|
||||||
import org.hibernate.cfg.Environment;
|
import org.hibernate.cfg.Environment;
|
||||||
import org.hibernate.criterion.Restrictions;
|
|
||||||
import org.hibernate.persister.entity.EntityPersister;
|
import org.hibernate.persister.entity.EntityPersister;
|
||||||
|
import org.hibernate.tuple.entity.EntityMetamodel;
|
||||||
|
|
||||||
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.tuple.entity.EntityMetamodel;
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertFalse;
|
import static org.junit.Assert.assertFalse;
|
||||||
|
@ -172,14 +171,10 @@ public class MutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
Session s = openSession();
|
Session s = openSession();
|
||||||
Transaction t = s.beginTransaction();
|
Transaction t = s.beginTransaction();
|
||||||
|
|
||||||
Object nullUser = s.createCriteria(User.class)
|
Object nullUser = s.byNaturalId( User.class )
|
||||||
.add( Restrictions.naturalId()
|
.using( "name", "gavin" )
|
||||||
.set("name", "gavin")
|
.using( "org", "hb" )
|
||||||
.set("org", "hb")
|
.load();
|
||||||
)
|
|
||||||
.setCacheable(true)
|
|
||||||
.uniqueResult();
|
|
||||||
|
|
||||||
assertNull(nullUser);
|
assertNull(nullUser);
|
||||||
|
|
||||||
t.commit();
|
t.commit();
|
||||||
|
@ -203,13 +198,10 @@ public class MutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
s = openSession();
|
s = openSession();
|
||||||
t = s.beginTransaction();
|
t = s.beginTransaction();
|
||||||
|
|
||||||
u = (User) s.createCriteria(User.class)
|
u = s.byNaturalId( User.class )
|
||||||
.add( Restrictions.naturalId()
|
.using( "name", "gavin" )
|
||||||
.set("name", "gavin")
|
.using( "org", "hb" )
|
||||||
.set("org", "hb")
|
.load();
|
||||||
)
|
|
||||||
.setCacheable(true)
|
|
||||||
.uniqueResult();
|
|
||||||
|
|
||||||
assertNotNull(u);
|
assertNotNull(u);
|
||||||
|
|
||||||
|
@ -225,12 +217,10 @@ public class MutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
s = openSession();
|
s = openSession();
|
||||||
t = s.beginTransaction();
|
t = s.beginTransaction();
|
||||||
|
|
||||||
u = (User) s.createCriteria(User.class)
|
u = s.byNaturalId( User.class )
|
||||||
.add( Restrictions.naturalId()
|
.using( "name", "gavin" )
|
||||||
.set("name", "gavin")
|
.using( "org", "hb" )
|
||||||
.set("org", "hb")
|
.load();
|
||||||
).setCacheable(true)
|
|
||||||
.uniqueResult();
|
|
||||||
|
|
||||||
s.delete(u);
|
s.delete(u);
|
||||||
|
|
||||||
|
@ -245,13 +235,10 @@ public class MutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
s = openSession();
|
s = openSession();
|
||||||
t = s.beginTransaction();
|
t = s.beginTransaction();
|
||||||
|
|
||||||
nullUser = s.createCriteria(User.class)
|
nullUser = s.byNaturalId( User.class )
|
||||||
.add( Restrictions.naturalId()
|
.using( "name", "gavin" )
|
||||||
.set("name", "gavin")
|
.using( "org", "hb" )
|
||||||
.set("org", "hb")
|
.load();
|
||||||
)
|
|
||||||
.setCacheable(true)
|
|
||||||
.uniqueResult();
|
|
||||||
|
|
||||||
assertNull(nullUser);
|
assertNull(nullUser);
|
||||||
|
|
||||||
|
@ -276,13 +263,10 @@ public class MutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
|
|
||||||
s = openSession();
|
s = openSession();
|
||||||
t = s.beginTransaction();
|
t = s.beginTransaction();
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.byNaturalId( User.class )
|
||||||
.add( Restrictions.naturalId()
|
.using( "name", "gavin" )
|
||||||
.set( "name", "gavin" )
|
.using( "org", "hb" )
|
||||||
.set( "org", "hb" )
|
.load();
|
||||||
)
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull( u );
|
assertNotNull( u );
|
||||||
t.commit();
|
t.commit();
|
||||||
s.close();
|
s.close();
|
||||||
|
@ -302,24 +286,18 @@ public class MutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
|
|
||||||
s = openSession();
|
s = openSession();
|
||||||
t = s.beginTransaction();
|
t = s.beginTransaction();
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.byNaturalId( User.class )
|
||||||
.add( Restrictions.naturalId()
|
.using( "name", "gavin" )
|
||||||
.set("name", "gavin")
|
.using( "org", "hb" )
|
||||||
.set("org", "hb")
|
.load();
|
||||||
)
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull(u);
|
assertNotNull(u);
|
||||||
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() );
|
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() );
|
||||||
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() );
|
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() );
|
||||||
|
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.byNaturalId( User.class )
|
||||||
.add( Restrictions.naturalId()
|
.using( "name", "gavin" )
|
||||||
.set("name", "gavin")
|
.using( "org", "hb" )
|
||||||
.set("org", "hb")
|
.load();
|
||||||
)
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull(u);
|
assertNotNull(u);
|
||||||
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() );
|
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() );
|
||||||
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() ); //1: no stats since hbm.xml can't enable NaturalId caching
|
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() ); //1: no stats since hbm.xml can't enable NaturalId caching
|
||||||
|
@ -347,13 +325,10 @@ public class MutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
|
|
||||||
s = openSession();
|
s = openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.byNaturalId( User.class )
|
||||||
.add( Restrictions.naturalId()
|
.using( "name", "steve" )
|
||||||
.set("name", "steve")
|
.using( "org", "hb" )
|
||||||
.set("org", "hb")
|
.load();
|
||||||
)
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull( u );
|
assertNotNull( u );
|
||||||
s.getTransaction().commit();
|
s.getTransaction().commit();
|
||||||
s.close();
|
s.close();
|
||||||
|
@ -366,13 +341,10 @@ public class MutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
|
|
||||||
s = openSession();
|
s = openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.byNaturalId( User.class )
|
||||||
.add( Restrictions.naturalId()
|
.using( "name", "steve" )
|
||||||
.set("name", "steve")
|
.using( "org", "hb" )
|
||||||
.set("org", "hb")
|
.load();
|
||||||
)
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull( u );
|
assertNotNull( u );
|
||||||
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() ); //0: incorrect stats since hbm.xml can't enable NaturalId caching
|
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() ); //0: incorrect stats since hbm.xml can't enable NaturalId caching
|
||||||
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() ); //1: no stats since hbm.xml can't enable NaturalId caching
|
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() ); //1: no stats since hbm.xml can't enable NaturalId caching
|
||||||
|
@ -384,13 +356,10 @@ public class MutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
|
|
||||||
s = openSession();
|
s = openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.byNaturalId( User.class )
|
||||||
.add( Restrictions.naturalId()
|
.using( "name", "steve" )
|
||||||
.set("name", "steve")
|
.using( "org", "hb" )
|
||||||
.set("org", "hb")
|
.load();
|
||||||
)
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNull( u );
|
assertNull( u );
|
||||||
s.getTransaction().commit();
|
s.getTransaction().commit();
|
||||||
s.close();
|
s.close();
|
||||||
|
@ -411,13 +380,10 @@ public class MutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
|
|
||||||
s = openSession();
|
s = openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.byNaturalId( User.class )
|
||||||
.add( Restrictions.naturalId()
|
.using( "name", "steve" )
|
||||||
.set("name", "steve")
|
.using( "org", "hb" )
|
||||||
.set("org", "hb")
|
.load();
|
||||||
)
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull( u );
|
assertNotNull( u );
|
||||||
|
|
||||||
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() );
|
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() );
|
||||||
|
@ -430,13 +396,10 @@ public class MutableNaturalIdTest extends BaseCoreFunctionalTestCase {
|
||||||
|
|
||||||
s = openSession();
|
s = openSession();
|
||||||
s.beginTransaction();
|
s.beginTransaction();
|
||||||
u = ( User ) s.createCriteria( User.class )
|
u = s.byNaturalId( User.class )
|
||||||
.add( Restrictions.naturalId()
|
.using( "name", "steve" )
|
||||||
.set("name", "steve")
|
.using( "org", "hb" )
|
||||||
.set("org", "hb")
|
.load();
|
||||||
)
|
|
||||||
.setCacheable( true )
|
|
||||||
.uniqueResult();
|
|
||||||
assertNotNull( u );
|
assertNotNull( u );
|
||||||
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() ); //0: incorrect stats since hbm.xml can't enable NaturalId caching
|
assertEquals( 1, sessionFactory().getStatistics().getNaturalIdQueryExecutionCount() ); //0: incorrect stats since hbm.xml can't enable NaturalId caching
|
||||||
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() ); //1: no stats since hbm.xml can't enable NaturalId caching
|
assertEquals( 0, sessionFactory().getStatistics().getNaturalIdCacheHitCount() ); //1: no stats since hbm.xml can't enable NaturalId caching
|
||||||
|
|
|
@ -6,14 +6,12 @@
|
||||||
*/
|
*/
|
||||||
package org.hibernate.test.propertyref.cachedcollections;
|
package org.hibernate.test.propertyref.cachedcollections;
|
||||||
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
import org.hibernate.FetchMode;
|
|
||||||
import org.hibernate.Hibernate;
|
import org.hibernate.Hibernate;
|
||||||
import org.hibernate.Session;
|
import org.hibernate.Session;
|
||||||
import org.hibernate.criterion.Restrictions;
|
|
||||||
import org.hibernate.testing.TestForIssue;
|
import org.hibernate.testing.TestForIssue;
|
||||||
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.junit.Assert.assertNotNull;
|
import static org.junit.Assert.assertNotNull;
|
||||||
import static org.junit.Assert.assertTrue;
|
import static org.junit.Assert.assertTrue;
|
||||||
|
@ -44,7 +42,7 @@ public class CachedPropertyRefCollectionTest extends BaseCoreFunctionalTestCase
|
||||||
// First attempt to load it via PK lookup
|
// First attempt to load it via PK lookup
|
||||||
session = openSession();
|
session = openSession();
|
||||||
session.beginTransaction();
|
session.beginTransaction();
|
||||||
ManagedObject obj = (ManagedObject) session.get( ManagedObject.class, 1L );
|
ManagedObject obj = session.get( ManagedObject.class, 1L );
|
||||||
assertNotNull( obj );
|
assertNotNull( obj );
|
||||||
assertTrue( Hibernate.isInitialized( obj ) );
|
assertTrue( Hibernate.isInitialized( obj ) );
|
||||||
obj.getMembers().size();
|
obj.getMembers().size();
|
||||||
|
@ -55,11 +53,7 @@ public class CachedPropertyRefCollectionTest extends BaseCoreFunctionalTestCase
|
||||||
// Now try to access it via natural key
|
// Now try to access it via natural key
|
||||||
session = openSession();
|
session = openSession();
|
||||||
session.beginTransaction();
|
session.beginTransaction();
|
||||||
Criteria criteria = session.createCriteria( ManagedObject.class )
|
obj = session.bySimpleNaturalId( ManagedObject.class ).load( "test" );
|
||||||
.add( Restrictions.naturalId().set( "name", "test" ) )
|
|
||||||
.setCacheable( true )
|
|
||||||
.setFetchMode( "members", FetchMode.JOIN );
|
|
||||||
obj = (ManagedObject) criteria.uniqueResult();
|
|
||||||
assertNotNull( obj );
|
assertNotNull( obj );
|
||||||
assertTrue( Hibernate.isInitialized( obj ) );
|
assertTrue( Hibernate.isInitialized( obj ) );
|
||||||
obj.getMembers().size();
|
obj.getMembers().size();
|
||||||
|
|
|
@ -12,6 +12,13 @@ import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import javax.persistence.criteria.CriteriaBuilder;
|
||||||
|
import javax.persistence.criteria.CriteriaQuery;
|
||||||
|
import javax.persistence.criteria.Join;
|
||||||
|
import javax.persistence.criteria.JoinType;
|
||||||
|
import javax.persistence.criteria.Order;
|
||||||
|
import javax.persistence.criteria.Root;
|
||||||
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import org.hibernate.CacheMode;
|
import org.hibernate.CacheMode;
|
||||||
|
@ -25,7 +32,10 @@ import org.hibernate.cfg.Environment;
|
||||||
import org.hibernate.internal.util.ReflectHelper;
|
import org.hibernate.internal.util.ReflectHelper;
|
||||||
import org.hibernate.proxy.HibernateProxy;
|
import org.hibernate.proxy.HibernateProxy;
|
||||||
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase;
|
||||||
|
|
||||||
|
import org.hibernate.query.criteria.JpaCriteriaQuery;
|
||||||
import org.hibernate.transform.AliasToBeanConstructorResultTransformer;
|
import org.hibernate.transform.AliasToBeanConstructorResultTransformer;
|
||||||
|
import org.hibernate.transform.AliasToEntityMapResultTransformer;
|
||||||
import org.hibernate.transform.ResultTransformer;
|
import org.hibernate.transform.ResultTransformer;
|
||||||
import org.hibernate.transform.Transformers;
|
import org.hibernate.transform.Transformers;
|
||||||
import org.hibernate.type.StandardBasicTypes;
|
import org.hibernate.type.StandardBasicTypes;
|
||||||
|
@ -65,11 +75,28 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
}
|
}
|
||||||
|
|
||||||
protected abstract class CriteriaExecutor extends QueryExecutor {
|
protected abstract class CriteriaExecutor extends QueryExecutor {
|
||||||
protected abstract Criteria getCriteria(Session s) throws Exception;
|
protected abstract JpaCriteriaQuery<?> getCriteria(Session s) throws Exception;
|
||||||
|
|
||||||
|
protected ResultTransformer getResultTransformer() {
|
||||||
|
return AliasToEntityMapResultTransformer.INSTANCE;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Object getResults(Session s, boolean isSingleResult) throws Exception {
|
protected Object getResults(Session s, boolean isSingleResult) throws Exception {
|
||||||
Criteria criteria = getCriteria( s ).setCacheable( getQueryCacheMode() != CacheMode.IGNORE ).setCacheMode( getQueryCacheMode() );
|
final CacheMode cacheMode = getQueryCacheMode();
|
||||||
return ( isSingleResult ? criteria.uniqueResult() : criteria.list() );
|
|
||||||
|
final JpaCriteriaQuery<?> criteria = getCriteria( s );
|
||||||
|
final Query<?> query = s.createQuery( criteria ).setCacheMode( cacheMode );
|
||||||
|
|
||||||
|
if ( cacheMode != CacheMode.IGNORE ) {
|
||||||
|
query.setCacheable( true );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( getResultTransformer() != null ) {
|
||||||
|
query.setResultTransformer( getResultTransformer() );
|
||||||
|
}
|
||||||
|
|
||||||
|
return ( isSingleResult ? query.uniqueResult() : query.list() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -193,14 +220,20 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
public void testAliasToEntityMapNoProjectionList() throws Exception {
|
public void testAliasToEntityMapNoProjectionList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
@Override
|
@Override
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Student.class, "s" )
|
final CriteriaBuilder builder = s.getSessionFactory().getCriteriaBuilder();
|
||||||
.createAlias( "s.enrolments", "e", CriteriaSpecification.LEFT_JOIN )
|
|
||||||
.createAlias( "e.course", "c", CriteriaSpecification.LEFT_JOIN )
|
final JpaCriteriaQuery<Student> criteria = (JpaCriteriaQuery<Student>) builder.createQuery( Student.class );
|
||||||
.setResultTransformer( CriteriaSpecification.ALIAS_TO_ENTITY_MAP )
|
|
||||||
.addOrder( Order.asc( "s.studentNumber") );
|
final Root<Student> studentRoot = criteria.from( Student.class );
|
||||||
|
studentRoot.join( "enrolments", JoinType.LEFT ).join( "course", JoinType.LEFT );
|
||||||
|
|
||||||
|
criteria.orderBy( builder.asc( studentRoot.get( "studentNumber" ) ) );
|
||||||
|
|
||||||
|
return criteria;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
HqlExecutor hqlExecutor = new HqlExecutor() {
|
HqlExecutor hqlExecutor = new HqlExecutor() {
|
||||||
@Override
|
@Override
|
||||||
public Query getQuery(Session s) {
|
public Query getQuery(Session s) {
|
||||||
|
@ -208,6 +241,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
.setResultTransformer( Transformers.ALIAS_TO_ENTITY_MAP );
|
.setResultTransformer( Transformers.ALIAS_TO_ENTITY_MAP );
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
ResultChecker checker = new ResultChecker() {
|
ResultChecker checker = new ResultChecker() {
|
||||||
public void check(Object results) {
|
public void check(Object results) {
|
||||||
List resultList = ( List ) results;
|
List resultList = ( List ) results;
|
||||||
|
@ -232,12 +266,18 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
public void testAliasToEntityMapNoProjectionMultiAndNullList() throws Exception {
|
public void testAliasToEntityMapNoProjectionMultiAndNullList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
@Override
|
@Override
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Student.class, "s" )
|
final CriteriaBuilder builder = s.getSessionFactory().getCriteriaBuilder();
|
||||||
.createAlias( "s.preferredCourse", "p", CriteriaSpecification.LEFT_JOIN )
|
|
||||||
.createAlias( "s.addresses", "a", CriteriaSpecification.LEFT_JOIN )
|
final JpaCriteriaQuery<Student> criteria = (JpaCriteriaQuery<Student>) builder.createQuery( Student.class );
|
||||||
.setResultTransformer( CriteriaSpecification.ALIAS_TO_ENTITY_MAP )
|
|
||||||
.addOrder( Order.asc( "s.studentNumber" ) );
|
final Root<Student> studentRoot = criteria.from( Student.class );
|
||||||
|
studentRoot.join( "preferredCourse", JoinType.LEFT );
|
||||||
|
studentRoot.join( "addresses", JoinType.LEFT );
|
||||||
|
|
||||||
|
criteria.orderBy( builder.asc( studentRoot.get( "studentNumber" ) ) );
|
||||||
|
|
||||||
|
return criteria;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
HqlExecutor hqlExecutor = new HqlExecutor() {
|
HqlExecutor hqlExecutor = new HqlExecutor() {
|
||||||
|
@ -282,7 +322,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
public void testAliasToEntityMapNoProjectionNullAndNonNullAliasList() throws Exception {
|
public void testAliasToEntityMapNoProjectionNullAndNonNullAliasList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
@Override
|
@Override
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createAlias( "s.addresses", "a", CriteriaSpecification.LEFT_JOIN )
|
.createAlias( "s.addresses", "a", CriteriaSpecification.LEFT_JOIN )
|
||||||
.setResultTransformer( CriteriaSpecification.ALIAS_TO_ENTITY_MAP )
|
.setResultTransformer( CriteriaSpecification.ALIAS_TO_ENTITY_MAP )
|
||||||
|
@ -323,7 +363,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testEntityWithNonLazyOneToManyUnique() throws Exception {
|
public void testEntityWithNonLazyOneToManyUnique() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Course.class );
|
return s.createCriteria( Course.class );
|
||||||
}
|
}
|
||||||
|
@ -347,7 +387,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testEntityWithNonLazyManyToOneList() throws Exception {
|
public void testEntityWithNonLazyManyToOneList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( CourseMeeting.class )
|
return s.createCriteria( CourseMeeting.class )
|
||||||
.addOrder( Order.asc( "id.day" ) );
|
.addOrder( Order.asc( "id.day" ) );
|
||||||
|
@ -376,7 +416,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testEntityWithLazyAssnUnique() throws Exception {
|
public void testEntityWithLazyAssnUnique() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.add( Restrictions.eq( "studentNumber", shermanExpected.getStudentNumber() ) );
|
.add( Restrictions.eq( "studentNumber", shermanExpected.getStudentNumber() ) );
|
||||||
|
@ -403,7 +443,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testEntityWithLazyAssnList() throws Exception {
|
public void testEntityWithLazyAssnList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class )
|
return s.createCriteria( Student.class )
|
||||||
.addOrder( Order.asc( "studentNumber" ) );
|
.addOrder( Order.asc( "studentNumber" ) );
|
||||||
|
@ -437,7 +477,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
public void testEntityWithUnaliasedJoinFetchedLazyOneToManySingleElementList() throws Exception {
|
public void testEntityWithUnaliasedJoinFetchedLazyOneToManySingleElementList() throws Exception {
|
||||||
// unaliased
|
// unaliased
|
||||||
CriteriaExecutor criteriaExecutorUnaliased = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorUnaliased = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.setFetchMode( "enrolments", FetchMode.JOIN )
|
.setFetchMode( "enrolments", FetchMode.JOIN )
|
||||||
|
@ -473,7 +513,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testJoinWithFetchJoinListCriteria() throws Exception {
|
public void testJoinWithFetchJoinListCriteria() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createAlias( "s.preferredCourse", "pc", Criteria.LEFT_JOIN )
|
.createAlias( "s.preferredCourse", "pc", Criteria.LEFT_JOIN )
|
||||||
.setFetchMode( "enrolments", FetchMode.JOIN )
|
.setFetchMode( "enrolments", FetchMode.JOIN )
|
||||||
|
@ -689,7 +729,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testEntityWithSelectFetchedLazyOneToManySingleElementListCriteria() throws Exception {
|
public void testEntityWithSelectFetchedLazyOneToManySingleElementListCriteria() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutorUnaliased = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorUnaliased = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.setFetchMode( "enrolments", FetchMode.SELECT )
|
.setFetchMode( "enrolments", FetchMode.SELECT )
|
||||||
|
@ -716,7 +756,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
public void testEntityWithJoinFetchedLazyOneToManyMultiAndNullElementList() throws Exception {
|
public void testEntityWithJoinFetchedLazyOneToManyMultiAndNullElementList() throws Exception {
|
||||||
//unaliased
|
//unaliased
|
||||||
CriteriaExecutor criteriaExecutorUnaliased = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorUnaliased = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.setFetchMode( "addresses", FetchMode.JOIN )
|
.setFetchMode( "addresses", FetchMode.JOIN )
|
||||||
|
@ -731,7 +771,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
|
|
||||||
//aliased
|
//aliased
|
||||||
CriteriaExecutor criteriaExecutorAliased1 = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorAliased1 = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createAlias( "s.addresses", "a", Criteria.LEFT_JOIN )
|
.createAlias( "s.addresses", "a", Criteria.LEFT_JOIN )
|
||||||
|
@ -740,7 +780,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
CriteriaExecutor criteriaExecutorAliased2 = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorAliased2 = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createAlias( "s.addresses", "a", Criteria.LEFT_JOIN )
|
.createAlias( "s.addresses", "a", Criteria.LEFT_JOIN )
|
||||||
|
@ -749,7 +789,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
CriteriaExecutor criteriaExecutorAliased3 = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorAliased3 = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createCriteria( "s.addresses", "a", Criteria.LEFT_JOIN )
|
.createCriteria( "s.addresses", "a", Criteria.LEFT_JOIN )
|
||||||
|
@ -758,7 +798,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
CriteriaExecutor criteriaExecutorAliased4 = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorAliased4 = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createCriteria( "s.addresses", "a", Criteria.LEFT_JOIN )
|
.createCriteria( "s.addresses", "a", Criteria.LEFT_JOIN )
|
||||||
|
@ -800,7 +840,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
public void testEntityWithJoinFetchedLazyManyToOneList() throws Exception {
|
public void testEntityWithJoinFetchedLazyManyToOneList() throws Exception {
|
||||||
// unaliased
|
// unaliased
|
||||||
CriteriaExecutor criteriaExecutorUnaliased = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorUnaliased = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.setFetchMode( "preferredCourse", FetchMode.JOIN )
|
.setFetchMode( "preferredCourse", FetchMode.JOIN )
|
||||||
|
@ -815,7 +855,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
|
|
||||||
// aliased
|
// aliased
|
||||||
CriteriaExecutor criteriaExecutorAliased1 = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorAliased1 = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createAlias( "s.preferredCourse", "pCourse", Criteria.LEFT_JOIN )
|
.createAlias( "s.preferredCourse", "pCourse", Criteria.LEFT_JOIN )
|
||||||
|
@ -824,7 +864,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
CriteriaExecutor criteriaExecutorAliased2 = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorAliased2 = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createAlias( "s.preferredCourse", "pCourse", Criteria.LEFT_JOIN )
|
.createAlias( "s.preferredCourse", "pCourse", Criteria.LEFT_JOIN )
|
||||||
|
@ -833,7 +873,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
CriteriaExecutor criteriaExecutorAliased3 = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorAliased3 = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createCriteria( "s.preferredCourse", "pCourse", Criteria.LEFT_JOIN )
|
.createCriteria( "s.preferredCourse", "pCourse", Criteria.LEFT_JOIN )
|
||||||
|
@ -842,7 +882,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
CriteriaExecutor criteriaExecutorAliased4 = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorAliased4 = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createCriteria( "s.preferredCourse", "pCourse", Criteria.LEFT_JOIN )
|
.createCriteria( "s.preferredCourse", "pCourse", Criteria.LEFT_JOIN )
|
||||||
|
@ -878,7 +918,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
public void testEntityWithJoinFetchedLazyManyToOneUsingProjectionList() throws Exception {
|
public void testEntityWithJoinFetchedLazyManyToOneUsingProjectionList() throws Exception {
|
||||||
// unaliased
|
// unaliased
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Enrolment.class, "e" )
|
return s.createCriteria( Enrolment.class, "e" )
|
||||||
.createAlias( "e.student", "s", Criteria.LEFT_JOIN )
|
.createAlias( "e.student", "s", Criteria.LEFT_JOIN )
|
||||||
|
@ -927,7 +967,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testEntityWithJoinedLazyOneToManySingleElementListCriteria() throws Exception {
|
public void testEntityWithJoinedLazyOneToManySingleElementListCriteria() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutorUnaliased = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorUnaliased = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createCriteria( "s.enrolments", Criteria.LEFT_JOIN )
|
.createCriteria( "s.enrolments", Criteria.LEFT_JOIN )
|
||||||
|
@ -935,7 +975,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
CriteriaExecutor criteriaExecutorAliased1 = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorAliased1 = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createCriteria( "s.enrolments", "e", Criteria.LEFT_JOIN )
|
.createCriteria( "s.enrolments", "e", Criteria.LEFT_JOIN )
|
||||||
|
@ -943,7 +983,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
CriteriaExecutor criteriaExecutorAliased2 = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorAliased2 = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createAlias( "s.enrolments", "e", Criteria.LEFT_JOIN )
|
.createAlias( "s.enrolments", "e", Criteria.LEFT_JOIN )
|
||||||
|
@ -974,7 +1014,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testEntityWithJoinedLazyOneToManyMultiAndNullListCriteria() throws Exception {
|
public void testEntityWithJoinedLazyOneToManyMultiAndNullListCriteria() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutorUnaliased = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorUnaliased = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createCriteria( "s.addresses", Criteria.LEFT_JOIN )
|
.createCriteria( "s.addresses", Criteria.LEFT_JOIN )
|
||||||
|
@ -982,7 +1022,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
CriteriaExecutor criteriaExecutorAliased1 = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorAliased1 = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createCriteria( "s.addresses", "a", Criteria.LEFT_JOIN )
|
.createCriteria( "s.addresses", "a", Criteria.LEFT_JOIN )
|
||||||
|
@ -990,7 +1030,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
CriteriaExecutor criteriaExecutorAliased2 = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorAliased2 = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createAlias( "s.addresses", "a", Criteria.LEFT_JOIN )
|
.createAlias( "s.addresses", "a", Criteria.LEFT_JOIN )
|
||||||
|
@ -1022,7 +1062,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testEntityWithJoinedLazyManyToOneListCriteria() throws Exception {
|
public void testEntityWithJoinedLazyManyToOneListCriteria() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutorUnaliased = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorUnaliased = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createCriteria( "s.preferredCourse", Criteria.LEFT_JOIN )
|
.createCriteria( "s.preferredCourse", Criteria.LEFT_JOIN )
|
||||||
|
@ -1030,7 +1070,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
CriteriaExecutor criteriaExecutorAliased1 = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorAliased1 = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createCriteria( "s.preferredCourse", "p", Criteria.LEFT_JOIN )
|
.createCriteria( "s.preferredCourse", "p", Criteria.LEFT_JOIN )
|
||||||
|
@ -1038,7 +1078,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
CriteriaExecutor criteriaExecutorAliased2 = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutorAliased2 = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use RootEntityTransformer by default
|
// should use RootEntityTransformer by default
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createAlias( "s.preferredCourse", "p", Criteria.LEFT_JOIN )
|
.createAlias( "s.preferredCourse", "p", Criteria.LEFT_JOIN )
|
||||||
|
@ -1159,7 +1199,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testAliasToEntityMapOneProjectionList() throws Exception {
|
public void testAliasToEntityMapOneProjectionList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Enrolment.class, "e" )
|
return s.createCriteria( Enrolment.class, "e" )
|
||||||
.setProjection( Projections.property( "e.student" ).as( "student" ) )
|
.setProjection( Projections.property( "e.student" ).as( "student" ) )
|
||||||
.addOrder( Order.asc( "e.studentNumber") )
|
.addOrder( Order.asc( "e.studentNumber") )
|
||||||
|
@ -1195,7 +1235,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testAliasToEntityMapMultiProjectionList() throws Exception {
|
public void testAliasToEntityMapMultiProjectionList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Enrolment.class, "e" )
|
return s.createCriteria( Enrolment.class, "e" )
|
||||||
.setProjection(
|
.setProjection(
|
||||||
Projections.projectionList()
|
Projections.projectionList()
|
||||||
|
@ -1243,7 +1283,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testAliasToEntityMapMultiProjectionWithNullAliasList() throws Exception {
|
public void testAliasToEntityMapMultiProjectionWithNullAliasList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Enrolment.class, "e" )
|
return s.createCriteria( Enrolment.class, "e" )
|
||||||
.setProjection(
|
.setProjection(
|
||||||
Projections.projectionList()
|
Projections.projectionList()
|
||||||
|
@ -1288,7 +1328,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testAliasToEntityMapMultiAggregatedPropProjectionSingleResult() throws Exception {
|
public void testAliasToEntityMapMultiAggregatedPropProjectionSingleResult() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Enrolment.class )
|
return s.createCriteria( Enrolment.class )
|
||||||
.setProjection(
|
.setProjection(
|
||||||
Projections.projectionList()
|
Projections.projectionList()
|
||||||
|
@ -1320,7 +1360,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testOneNonEntityProjectionUnique() throws Exception {
|
public void testOneNonEntityProjectionUnique() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use PassThroughTransformer by default
|
// should use PassThroughTransformer by default
|
||||||
return s.createCriteria( Enrolment.class, "e" )
|
return s.createCriteria( Enrolment.class, "e" )
|
||||||
.setProjection( Projections.property( "e.semester" ) )
|
.setProjection( Projections.property( "e.semester" ) )
|
||||||
|
@ -1345,7 +1385,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testOneNonEntityProjectionList() throws Exception {
|
public void testOneNonEntityProjectionList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use PassThroughTransformer by default
|
// should use PassThroughTransformer by default
|
||||||
return s.createCriteria( Enrolment.class, "e" )
|
return s.createCriteria( Enrolment.class, "e" )
|
||||||
.setProjection( Projections.property( "e.semester" ) )
|
.setProjection( Projections.property( "e.semester" ) )
|
||||||
|
@ -1401,7 +1441,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testOneEntityProjectionUnique() throws Exception {
|
public void testOneEntityProjectionUnique() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use PassThroughTransformer by default
|
// should use PassThroughTransformer by default
|
||||||
return s.createCriteria( Enrolment.class )
|
return s.createCriteria( Enrolment.class )
|
||||||
.setProjection( Projections.property( "student" ) )
|
.setProjection( Projections.property( "student" ) )
|
||||||
|
@ -1430,7 +1470,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
public void testOneEntityProjectionList() throws Exception {
|
public void testOneEntityProjectionList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
// should use PassThroughTransformer by default
|
// should use PassThroughTransformer by default
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Enrolment.class, "e" )
|
return s.createCriteria( Enrolment.class, "e" )
|
||||||
.setProjection( Projections.property( "e.student" ) )
|
.setProjection( Projections.property( "e.student" ) )
|
||||||
.addOrder( Order.asc( "e.studentNumber") );
|
.addOrder( Order.asc( "e.studentNumber") );
|
||||||
|
@ -1458,7 +1498,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testMultiEntityProjectionUnique() throws Exception {
|
public void testMultiEntityProjectionUnique() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use PassThroughTransformer by default
|
// should use PassThroughTransformer by default
|
||||||
return s.createCriteria( Enrolment.class )
|
return s.createCriteria( Enrolment.class )
|
||||||
.setProjection(
|
.setProjection(
|
||||||
|
@ -1500,7 +1540,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testMultiEntityProjectionList() throws Exception {
|
public void testMultiEntityProjectionList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use PassThroughTransformer by default
|
// should use PassThroughTransformer by default
|
||||||
return s.createCriteria( Enrolment.class, "e" )
|
return s.createCriteria( Enrolment.class, "e" )
|
||||||
.setProjection(
|
.setProjection(
|
||||||
|
@ -1545,7 +1585,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testMultiEntityProjectionAliasedList() throws Exception {
|
public void testMultiEntityProjectionAliasedList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
// should use PassThroughTransformer by default
|
// should use PassThroughTransformer by default
|
||||||
return s.createCriteria( Enrolment.class, "e" )
|
return s.createCriteria( Enrolment.class, "e" )
|
||||||
.setProjection(
|
.setProjection(
|
||||||
|
@ -1590,7 +1630,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testSingleAggregatedPropProjectionSingleResult() throws Exception {
|
public void testSingleAggregatedPropProjectionSingleResult() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Enrolment.class )
|
return s.createCriteria( Enrolment.class )
|
||||||
.setProjection( Projections.min( "studentNumber" ) );
|
.setProjection( Projections.min( "studentNumber" ) );
|
||||||
}
|
}
|
||||||
|
@ -1612,7 +1652,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testMultiAggregatedPropProjectionSingleResult() throws Exception {
|
public void testMultiAggregatedPropProjectionSingleResult() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Enrolment.class )
|
return s.createCriteria( Enrolment.class )
|
||||||
.setProjection(
|
.setProjection(
|
||||||
Projections.projectionList()
|
Projections.projectionList()
|
||||||
|
@ -1641,7 +1681,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testAliasToBeanDtoOneArgList() throws Exception {
|
public void testAliasToBeanDtoOneArgList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Enrolment.class, "e" )
|
return s.createCriteria( Enrolment.class, "e" )
|
||||||
.createAlias( "e.student", "st" )
|
.createAlias( "e.student", "st" )
|
||||||
.createAlias( "e.course", "co" )
|
.createAlias( "e.course", "co" )
|
||||||
|
@ -1674,7 +1714,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testAliasToBeanDtoMultiArgList() throws Exception {
|
public void testAliasToBeanDtoMultiArgList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Enrolment.class, "e" )
|
return s.createCriteria( Enrolment.class, "e" )
|
||||||
.createAlias( "e.student", "st" )
|
.createAlias( "e.student", "st" )
|
||||||
.createAlias( "e.course", "co" )
|
.createAlias( "e.course", "co" )
|
||||||
|
@ -1711,7 +1751,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testMultiProjectionListThenApplyAliasToBean() throws Exception {
|
public void testMultiProjectionListThenApplyAliasToBean() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Enrolment.class, "e" )
|
return s.createCriteria( Enrolment.class, "e" )
|
||||||
.createAlias( "e.student", "st" )
|
.createAlias( "e.student", "st" )
|
||||||
.createAlias( "e.course", "co" )
|
.createAlias( "e.course", "co" )
|
||||||
|
@ -1755,7 +1795,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testAliasToBeanDtoLiteralArgList() throws Exception {
|
public void testAliasToBeanDtoLiteralArgList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Enrolment.class, "e" )
|
return s.createCriteria( Enrolment.class, "e" )
|
||||||
.createAlias( "e.student", "st" )
|
.createAlias( "e.student", "st" )
|
||||||
.createAlias( "e.course", "co" )
|
.createAlias( "e.course", "co" )
|
||||||
|
@ -1797,7 +1837,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testAliasToBeanDtoWithNullAliasList() throws Exception {
|
public void testAliasToBeanDtoWithNullAliasList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Enrolment.class, "e" )
|
return s.createCriteria( Enrolment.class, "e" )
|
||||||
.createAlias( "e.student", "st" )
|
.createAlias( "e.student", "st" )
|
||||||
.createAlias( "e.course", "co" )
|
.createAlias( "e.course", "co" )
|
||||||
|
@ -1835,7 +1875,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testOneSelectNewNoAliasesList() throws Exception {
|
public void testOneSelectNewNoAliasesList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) throws Exception {
|
protected JpaCriteriaQuery getCriteria(Session s) throws Exception {
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.setProjection( Projections.property( "s.name" ) )
|
.setProjection( Projections.property( "s.name" ) )
|
||||||
.addOrder( Order.asc( "s.studentNumber" ) )
|
.addOrder( Order.asc( "s.studentNumber" ) )
|
||||||
|
@ -1868,7 +1908,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testOneSelectNewAliasesList() throws Exception {
|
public void testOneSelectNewAliasesList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) throws Exception {
|
protected JpaCriteriaQuery getCriteria(Session s) throws Exception {
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.setProjection( Projections.property( "s.name" ).as( "name" ))
|
.setProjection( Projections.property( "s.name" ).as( "name" ))
|
||||||
.addOrder( Order.asc( "s.studentNumber" ) )
|
.addOrder( Order.asc( "s.studentNumber" ) )
|
||||||
|
@ -1901,7 +1941,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testMultiSelectNewList() throws Exception{
|
public void testMultiSelectNewList() throws Exception{
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) throws Exception {
|
protected JpaCriteriaQuery getCriteria(Session s) throws Exception {
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.setProjection(
|
.setProjection(
|
||||||
Projections.projectionList()
|
Projections.projectionList()
|
||||||
|
@ -1938,7 +1978,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testMultiSelectNewWithLiteralList() throws Exception {
|
public void testMultiSelectNewWithLiteralList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) throws Exception {
|
protected JpaCriteriaQuery getCriteria(Session s) throws Exception {
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.setProjection(
|
.setProjection(
|
||||||
Projections.projectionList()
|
Projections.projectionList()
|
||||||
|
@ -1976,7 +2016,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testMultiSelectNewListList() throws Exception {
|
public void testMultiSelectNewListList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.setProjection(
|
.setProjection(
|
||||||
Projections.projectionList()
|
Projections.projectionList()
|
||||||
|
@ -2010,7 +2050,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testMultiSelectNewMapUsingAliasesList() throws Exception {
|
public void testMultiSelectNewMapUsingAliasesList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.setProjection(
|
.setProjection(
|
||||||
Projections.projectionList()
|
Projections.projectionList()
|
||||||
|
@ -2044,7 +2084,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testMultiSelectNewMapUsingAliasesWithFetchJoinList() throws Exception {
|
public void testMultiSelectNewMapUsingAliasesWithFetchJoinList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createAlias( "s.preferredCourse", "pc", Criteria.LEFT_JOIN )
|
.createAlias( "s.preferredCourse", "pc", Criteria.LEFT_JOIN )
|
||||||
.setFetchMode( "enrolments", FetchMode.JOIN )
|
.setFetchMode( "enrolments", FetchMode.JOIN )
|
||||||
|
@ -2081,7 +2121,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testMultiSelectAliasToEntityMapUsingAliasesWithFetchJoinList() throws Exception {
|
public void testMultiSelectAliasToEntityMapUsingAliasesWithFetchJoinList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createAlias( "s.preferredCourse", "pc", Criteria.LEFT_JOIN )
|
.createAlias( "s.preferredCourse", "pc", Criteria.LEFT_JOIN )
|
||||||
.setFetchMode( "enrolments", FetchMode.JOIN )
|
.setFetchMode( "enrolments", FetchMode.JOIN )
|
||||||
|
@ -2149,7 +2189,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testSelectNewMapUsingAliasesList() throws Exception {
|
public void testSelectNewMapUsingAliasesList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.setProjection(
|
.setProjection(
|
||||||
Projections.projectionList()
|
Projections.projectionList()
|
||||||
|
@ -2183,7 +2223,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testSelectNewEntityConstructorList() throws Exception {
|
public void testSelectNewEntityConstructorList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.setProjection(
|
.setProjection(
|
||||||
Projections.projectionList()
|
Projections.projectionList()
|
||||||
|
@ -2224,7 +2264,7 @@ public abstract class AbstractQueryCacheResultTransformerTest extends BaseCoreFu
|
||||||
@Test
|
@Test
|
||||||
public void testMapKeyList() throws Exception {
|
public void testMapKeyList() throws Exception {
|
||||||
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
CriteriaExecutor criteriaExecutor = new CriteriaExecutor() {
|
||||||
protected Criteria getCriteria(Session s) {
|
protected JpaCriteriaQuery getCriteria(Session s) {
|
||||||
return s.createCriteria( Student.class, "s" )
|
return s.createCriteria( Student.class, "s" )
|
||||||
.createAlias( "s.addresses", "a" )
|
.createAlias( "s.addresses", "a" )
|
||||||
.setProjection( Projections.property( "a.addressType" ) );
|
.setProjection( Projections.property( "a.addressType" ) );
|
||||||
|
|
|
@ -12,15 +12,13 @@ import javax.persistence.Entity;
|
||||||
import javax.persistence.Id;
|
import javax.persistence.Id;
|
||||||
|
|
||||||
import org.hibernate.dialect.H2Dialect;
|
import org.hibernate.dialect.H2Dialect;
|
||||||
import org.hibernate.hql.internal.ast.QuerySyntaxException;
|
|
||||||
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
||||||
|
import org.hibernate.query.SemanticException;
|
||||||
|
|
||||||
import org.hibernate.testing.RequiresDialect;
|
import org.hibernate.testing.RequiresDialect;
|
||||||
import org.hibernate.testing.TestForIssue;
|
import org.hibernate.testing.TestForIssue;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import org.jboss.logging.Logger;
|
|
||||||
|
|
||||||
import static org.hibernate.testing.transaction.TransactionUtil.doInJPA;
|
import static org.hibernate.testing.transaction.TransactionUtil.doInJPA;
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.fail;
|
import static org.junit.Assert.fail;
|
||||||
|
@ -78,7 +76,7 @@ public class JpaFunctionTest extends BaseEntityManagerFunctionalTestCase {
|
||||||
} );
|
} );
|
||||||
}
|
}
|
||||||
catch ( Exception e ) {
|
catch ( Exception e ) {
|
||||||
assertEquals( QuerySyntaxException.class, e.getCause().getClass() );
|
assertEquals( SemanticException.class, e.getCause().getClass() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,6 @@
|
||||||
package org.hibernate.test.tm;
|
package org.hibernate.test.tm;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Iterator;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import javax.transaction.Transaction;
|
import javax.transaction.Transaction;
|
||||||
|
@ -17,7 +16,6 @@ import org.hibernate.EntityMode;
|
||||||
import org.hibernate.ScrollableResults;
|
import org.hibernate.ScrollableResults;
|
||||||
import org.hibernate.Session;
|
import org.hibernate.Session;
|
||||||
import org.hibernate.cfg.AvailableSettings;
|
import org.hibernate.cfg.AvailableSettings;
|
||||||
import org.hibernate.criterion.Order;
|
|
||||||
import org.hibernate.dialect.SQLServerDialect;
|
import org.hibernate.dialect.SQLServerDialect;
|
||||||
import org.hibernate.resource.transaction.backend.jta.internal.JtaTransactionCoordinatorBuilderImpl;
|
import org.hibernate.resource.transaction.backend.jta.internal.JtaTransactionCoordinatorBuilderImpl;
|
||||||
|
|
||||||
|
@ -33,7 +31,6 @@ 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;
|
||||||
import static org.junit.Assert.assertSame;
|
import static org.junit.Assert.assertSame;
|
||||||
import static org.junit.Assert.fail;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Gavin King
|
* @author Gavin King
|
||||||
|
@ -109,14 +106,14 @@ public class CMTTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
||||||
s1 = openSession();
|
s1 = openSession();
|
||||||
s1.createCriteria( "Item" ).list();
|
s1.createQuery( "from Item" ).list();
|
||||||
//foo.put("description", "a big red foo");
|
//foo.put("description", "a big red foo");
|
||||||
//s1.flush();
|
//s1.flush();
|
||||||
tx = TestingJtaPlatformImpl.INSTANCE.getTransactionManager().suspend();
|
tx = TestingJtaPlatformImpl.INSTANCE.getTransactionManager().suspend();
|
||||||
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
||||||
s2 = openSession();
|
s2 = openSession();
|
||||||
s2.createCriteria( "Item" ).list();
|
s2.createQuery( "from Item" ).list();
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
||||||
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().resume( tx );
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().resume( tx );
|
||||||
|
@ -124,7 +121,7 @@ public class CMTTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
||||||
s2 = openSession();
|
s2 = openSession();
|
||||||
s2.createCriteria( "Item" ).list();
|
s2.createQuery( "from Item" ).list();
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
||||||
|
|
||||||
assertEquals( 7, sessionFactory().getStatistics().getEntityLoadCount() );
|
assertEquals( 7, sessionFactory().getStatistics().getEntityLoadCount() );
|
||||||
|
@ -171,15 +168,13 @@ public class CMTTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
||||||
Session s1 = openSession();
|
Session s1 = openSession();
|
||||||
List r1 = s1.createCriteria( "Item" ).addOrder( Order.asc( "description" ) )
|
List r1 = s1.createQuery( "from Item order by description" ).setCacheable( true ).list();
|
||||||
.setCacheable( true ).list();
|
|
||||||
assertEquals( r1.size(), 2 );
|
assertEquals( r1.size(), 2 );
|
||||||
Transaction tx1 = TestingJtaPlatformImpl.INSTANCE.getTransactionManager().suspend();
|
Transaction tx1 = TestingJtaPlatformImpl.INSTANCE.getTransactionManager().suspend();
|
||||||
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
||||||
Session s2 = openSession();
|
Session s2 = openSession();
|
||||||
List r2 = s2.createCriteria( "Item" ).addOrder( Order.asc( "description" ) )
|
List r2 = s2.createQuery( "from Item order by description" ).setCacheable( true ).list();
|
||||||
.setCacheable( true ).list();
|
|
||||||
assertEquals( r2.size(), 2 );
|
assertEquals( r2.size(), 2 );
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
||||||
|
|
||||||
|
@ -199,8 +194,7 @@ public class CMTTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
||||||
Session s3 = openSession();
|
Session s3 = openSession();
|
||||||
s3.createCriteria( "Item" ).addOrder( Order.asc( "description" ) )
|
s3.createQuery( "from Item order by description" ).setCacheable( true ).list();
|
||||||
.setCacheable( true ).list();
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
||||||
|
|
||||||
assertEquals( sessionFactory().getStatistics().getSecondLevelCacheHitCount(), 4 );
|
assertEquals( sessionFactory().getStatistics().getSecondLevelCacheHitCount(), 4 );
|
||||||
|
@ -216,8 +210,7 @@ public class CMTTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
assertEquals( sessionFactory().getStatistics().getUpdateTimestampsCacheMissCount(), 0 );
|
assertEquals( sessionFactory().getStatistics().getUpdateTimestampsCacheMissCount(), 0 );
|
||||||
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().resume( tx4 );
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().resume( tx4 );
|
||||||
List r4 = s4.createCriteria( "Item" ).addOrder( Order.asc( "description" ) )
|
List r4 = s4.createQuery( "from Item order by description" ).setCacheable( true ).list();
|
||||||
.setCacheable( true ).list();
|
|
||||||
assertEquals( r4.size(), 2 );
|
assertEquals( r4.size(), 2 );
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
||||||
|
|
||||||
|
@ -272,8 +265,7 @@ public class CMTTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
// open a new TX and execute a query, this would fill the query cache.
|
// open a new TX and execute a query, this would fill the query cache.
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
||||||
Session s1 = openSession();
|
Session s1 = openSession();
|
||||||
List r1 = s1.createCriteria( "Item" ).addOrder( Order.asc( "description" ) )
|
List r1 = s1.createQuery( "from Item order by description" ).setCacheable( true ).list();
|
||||||
.setCacheable( true ).list();
|
|
||||||
assertEquals( r1.size(), 2 );
|
assertEquals( r1.size(), 2 );
|
||||||
foo = ( Map ) r1.get( 0 );
|
foo = ( Map ) r1.get( 0 );
|
||||||
// update data and make query cache stale, but TX is suspended
|
// update data and make query cache stale, but TX is suspended
|
||||||
|
@ -285,8 +277,7 @@ public class CMTTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
// this TX is committed after query
|
// this TX is committed after query
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
||||||
Session s2 = openSession();
|
Session s2 = openSession();
|
||||||
List r2 = s2.createCriteria( "Item" ).addOrder( Order.asc( "description" ) )
|
List r2 = s2.createQuery( "from Item order by description" ).setCacheable( true ).list();
|
||||||
.setCacheable( true ).list();
|
|
||||||
assertEquals( r2.size(), 2 );
|
assertEquals( r2.size(), 2 );
|
||||||
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
||||||
|
@ -321,8 +312,7 @@ public class CMTTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
||||||
Session s3 = openSession();
|
Session s3 = openSession();
|
||||||
s3.createCriteria( "Item" ).addOrder( Order.asc( "description" ) )
|
s3.createQuery( "from Item order by description" ).setCacheable( true ).list();
|
||||||
.setCacheable( true ).list();
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
||||||
|
|
||||||
assertEquals( 0, sessionFactory().getStatistics().getSecondLevelCacheHitCount() );
|
assertEquals( 0, sessionFactory().getStatistics().getSecondLevelCacheHitCount() );
|
||||||
|
@ -337,8 +327,7 @@ public class CMTTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
assertEquals( 2, sessionFactory().getStatistics().getUpdateTimestampsCacheHitCount() );
|
assertEquals( 2, sessionFactory().getStatistics().getUpdateTimestampsCacheHitCount() );
|
||||||
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().resume( tx4 );
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().resume( tx4 );
|
||||||
List r4 = s4.createCriteria( "Item" ).addOrder( Order.asc( "description" ) )
|
List r4 = s4.createQuery( "from Item order by description" ).setCacheable( true ).list();
|
||||||
.setCacheable( true ).list();
|
|
||||||
assertEquals( r4.size(), 2 );
|
assertEquals( r4.size(), 2 );
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
||||||
|
|
||||||
|
@ -422,53 +411,6 @@ public class CMTTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||||
// i verified that is does currently in my debugger...
|
// i verified that is does currently in my debugger...
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testCurrentSessionWithIterate() throws Exception {
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
|
||||||
Session s = openSession();
|
|
||||||
Map item1 = new HashMap();
|
|
||||||
item1.put( "name", "Item - 1" );
|
|
||||||
item1.put( "description", "The first item" );
|
|
||||||
s.persist( "Item", item1 );
|
|
||||||
|
|
||||||
Map item2 = new HashMap();
|
|
||||||
item2.put( "name", "Item - 2" );
|
|
||||||
item2.put( "description", "The second item" );
|
|
||||||
s.persist( "Item", item2 );
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
|
||||||
|
|
||||||
// First, test iterating the partial iterator; iterate to past
|
|
||||||
// the first, but not the second, item
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
|
||||||
s = sessionFactory().getCurrentSession();
|
|
||||||
Iterator itr = s.createQuery( "from Item" ).iterate();
|
|
||||||
if ( !itr.hasNext() ) {
|
|
||||||
fail( "No results in iterator" );
|
|
||||||
}
|
|
||||||
itr.next();
|
|
||||||
if ( !itr.hasNext() ) {
|
|
||||||
fail( "Only one result in iterator" );
|
|
||||||
}
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
|
||||||
|
|
||||||
// Next, iterate the entire result
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
|
||||||
s = sessionFactory().getCurrentSession();
|
|
||||||
itr = s.createQuery( "from Item" ).iterate();
|
|
||||||
if ( !itr.hasNext() ) {
|
|
||||||
fail( "No results in iterator" );
|
|
||||||
}
|
|
||||||
while ( itr.hasNext() ) {
|
|
||||||
itr.next();
|
|
||||||
}
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
|
||||||
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
|
||||||
s = openSession();
|
|
||||||
s.createQuery( "delete from Item" ).executeUpdate();
|
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().commit();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCurrentSessionWithScroll() throws Exception {
|
public void testCurrentSessionWithScroll() throws Exception {
|
||||||
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
TestingJtaPlatformImpl.INSTANCE.getTransactionManager().begin();
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
/*
|
/*
|
||||||
* Hibernate, Relational Persistence for Idiomatic Java
|
* Hibernate, Relational Persistence for Idiomatic Java
|
||||||
*
|
*
|
||||||
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
|
* 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>.
|
* See the lgpl.txt file in the root directory or http://www.gnu.org/licenses/lgpl-2.1.html
|
||||||
*/
|
*/
|
||||||
package org.hibernate.test.criterion;
|
package org.hibernate.test.criteria;
|
||||||
|
|
||||||
import org.hibernate.IrrelevantEntity;
|
import org.hibernate.IrrelevantEntity;
|
||||||
import org.hibernate.SessionFactory;
|
import org.hibernate.SessionFactory;
|
|
@ -1,10 +1,10 @@
|
||||||
/*
|
/*
|
||||||
* Hibernate, Relational Persistence for Idiomatic Java
|
* Hibernate, Relational Persistence for Idiomatic Java
|
||||||
*
|
*
|
||||||
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
|
* 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>.
|
* See the lgpl.txt file in the root directory or http://www.gnu.org/licenses/lgpl-2.1.html
|
||||||
*/
|
*/
|
||||||
package org.hibernate.test.criterion;
|
package org.hibernate.test.criteria;
|
||||||
|
|
||||||
import javax.persistence.Column;
|
import javax.persistence.Column;
|
||||||
import javax.persistence.Entity;
|
import javax.persistence.Entity;
|
Loading…
Reference in New Issue