HHH-16471 Add test for issue
This commit is contained in:
parent
2c16e25a71
commit
b1a4890c3e
212
hibernate-core/src/test/java/org/hibernate/orm/test/cache/QueryCacheAndOneToManyTest.java
vendored
Normal file
212
hibernate-core/src/test/java/org/hibernate/orm/test/cache/QueryCacheAndOneToManyTest.java
vendored
Normal file
|
@ -0,0 +1,212 @@
|
||||||
|
package org.hibernate.orm.test.cache;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.hibernate.annotations.Cache;
|
||||||
|
import org.hibernate.annotations.CacheConcurrencyStrategy;
|
||||||
|
import org.hibernate.cfg.AvailableSettings;
|
||||||
|
import org.hibernate.jpa.HibernateHints;
|
||||||
|
|
||||||
|
import org.hibernate.testing.orm.junit.EntityManagerFactoryScope;
|
||||||
|
import org.hibernate.testing.orm.junit.JiraKey;
|
||||||
|
import org.hibernate.testing.orm.junit.Jpa;
|
||||||
|
import org.hibernate.testing.orm.junit.Setting;
|
||||||
|
import org.junit.jupiter.api.AfterEach;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import jakarta.persistence.Entity;
|
||||||
|
import jakarta.persistence.GeneratedValue;
|
||||||
|
import jakarta.persistence.Id;
|
||||||
|
import jakarta.persistence.JoinColumn;
|
||||||
|
import jakarta.persistence.ManyToOne;
|
||||||
|
import jakarta.persistence.Query;
|
||||||
|
import jakarta.persistence.Version;
|
||||||
|
import jakarta.persistence.criteria.CriteriaBuilder;
|
||||||
|
import jakarta.persistence.criteria.CriteriaQuery;
|
||||||
|
import jakarta.persistence.criteria.Root;
|
||||||
|
import jakarta.persistence.criteria.Subquery;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.AssertionsForClassTypes.assertThat;
|
||||||
|
|
||||||
|
@Jpa(
|
||||||
|
annotatedClasses = {
|
||||||
|
QueryCacheAndOneToManyTest.MyEntity1.class,
|
||||||
|
QueryCacheAndOneToManyTest.MyEntity2.class
|
||||||
|
}
|
||||||
|
,
|
||||||
|
properties = {
|
||||||
|
@Setting(name = AvailableSettings.USE_SECOND_LEVEL_CACHE, value = "true"),
|
||||||
|
@Setting(name = AvailableSettings.USE_QUERY_CACHE, value = "true")
|
||||||
|
}
|
||||||
|
)
|
||||||
|
@JiraKey("HHH-16471")
|
||||||
|
public class QueryCacheAndOneToManyTest {
|
||||||
|
|
||||||
|
@AfterEach
|
||||||
|
public void setUp(EntityManagerFactoryScope scope) {
|
||||||
|
scope.inTransaction(
|
||||||
|
entityManager -> {
|
||||||
|
entityManager.createQuery( "delete from MyEntity1" ).executeUpdate();
|
||||||
|
entityManager.createQuery( "delete from MyEntity2" ).executeUpdate();
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testQuery(EntityManagerFactoryScope scope) {
|
||||||
|
scope.inTransaction(
|
||||||
|
entityManager -> {
|
||||||
|
MyEntity2 entity2 = new MyEntity2();
|
||||||
|
entityManager.persist( entity2 );
|
||||||
|
|
||||||
|
entityManager.flush();
|
||||||
|
|
||||||
|
CriteriaBuilder builder = entityManager.getCriteriaBuilder();
|
||||||
|
|
||||||
|
CriteriaQuery<MyEntity1> criteria1 = builder.createQuery( MyEntity1.class );
|
||||||
|
Root<MyEntity1> root1 = criteria1.from( MyEntity1.class );
|
||||||
|
Subquery<MyEntity2> subquery2 = criteria1.subquery( MyEntity2.class );
|
||||||
|
Root<MyEntity2> subroot2 = subquery2.from( MyEntity2.class );
|
||||||
|
subquery2.select( subroot2 ).where( builder.equal( subroot2, entity2 ) );
|
||||||
|
criteria1.select( root1 ).where( root1.get( "ref" ).in( subquery2 ) );
|
||||||
|
|
||||||
|
List<MyEntity1> entity1s = entityManager.createQuery( criteria1 )
|
||||||
|
.setHint( HibernateHints.HINT_CACHEABLE, true )
|
||||||
|
.getResultList();
|
||||||
|
assertThat( entity1s.size() ).isEqualTo( 0 );
|
||||||
|
|
||||||
|
CriteriaQuery<MyEntity2> criteria2 = builder.createQuery( MyEntity2.class );
|
||||||
|
Root<MyEntity2> root2 = criteria2.from( MyEntity2.class );
|
||||||
|
criteria2.select( root2 ).where( builder.equal( root2, entity2 ) );
|
||||||
|
List<MyEntity2> entity2s = entityManager.createQuery( criteria2 )
|
||||||
|
.setHint( HibernateHints.HINT_CACHEABLE, true )
|
||||||
|
.getResultList();
|
||||||
|
assertThat( entity2s.size() ).isEqualTo( 1 );
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testQuery2(EntityManagerFactoryScope scope) {
|
||||||
|
scope.inTransaction(
|
||||||
|
entityManager -> {
|
||||||
|
MyEntity2 entity2 = new MyEntity2();
|
||||||
|
MyEntity1 entity1 = new MyEntity1();
|
||||||
|
entity1.setRef( entity2 );
|
||||||
|
entityManager.persist( entity2 );
|
||||||
|
entityManager.persist( entity1 );
|
||||||
|
|
||||||
|
entityManager.flush();
|
||||||
|
|
||||||
|
CriteriaBuilder builder = entityManager.getCriteriaBuilder();
|
||||||
|
|
||||||
|
CriteriaQuery<MyEntity1> criteria1 = builder.createQuery( MyEntity1.class );
|
||||||
|
Root<MyEntity1> root1 = criteria1.from( MyEntity1.class );
|
||||||
|
Subquery<MyEntity2> subquery2 = criteria1.subquery( MyEntity2.class );
|
||||||
|
Root<MyEntity2> subroot2 = subquery2.from( MyEntity2.class );
|
||||||
|
subquery2.select( subroot2 ).where( builder.equal( subroot2, entity2 ) );
|
||||||
|
criteria1.select( root1 ).where( root1.get( "ref" ).in( subquery2 ) );
|
||||||
|
|
||||||
|
List<MyEntity1> entities1s = entityManager.createQuery( criteria1 )
|
||||||
|
.setHint( HibernateHints.HINT_CACHEABLE, true )
|
||||||
|
.getResultList();
|
||||||
|
|
||||||
|
assertThat( entities1s.size() ).isEqualTo( 1 );
|
||||||
|
|
||||||
|
CriteriaQuery<MyEntity2> criteria2 = builder.createQuery( MyEntity2.class );
|
||||||
|
Root<MyEntity2> root2 = criteria2.from( MyEntity2.class );
|
||||||
|
criteria2.select( root2 ).where( builder.equal( root2, entity2 ) );
|
||||||
|
|
||||||
|
List<MyEntity2> entity2s = entityManager.createQuery( criteria2 )
|
||||||
|
.setHint( HibernateHints.HINT_CACHEABLE, true )
|
||||||
|
.getResultList();
|
||||||
|
assertThat( entity2s.size() ).isEqualTo( 1 );
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testQuery3(EntityManagerFactoryScope scope) {
|
||||||
|
scope.inTransaction(
|
||||||
|
entityManager -> {
|
||||||
|
MyEntity2 entity2 = new MyEntity2();
|
||||||
|
MyEntity1 entity1 = new MyEntity1();
|
||||||
|
entity1.setRef( entity2 );
|
||||||
|
entityManager.persist( entity2 );
|
||||||
|
entityManager.persist( entity1 );
|
||||||
|
|
||||||
|
entityManager.flush();
|
||||||
|
|
||||||
|
Query query = entityManager.createQuery( "select e1 from MyEntity1 e1 where e1.ref = :myEntity2" )
|
||||||
|
.setParameter( "myEntity2", entity2 )
|
||||||
|
.setHint( HibernateHints.HINT_CACHEABLE, true );
|
||||||
|
List results = query.getResultList();
|
||||||
|
assertThat( results.size() ).isEqualTo( 1 );
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity(name = "MyEntity1")
|
||||||
|
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
|
||||||
|
public static class MyEntity1 {
|
||||||
|
@Id
|
||||||
|
@GeneratedValue
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
@Version
|
||||||
|
private Long version;
|
||||||
|
|
||||||
|
@ManyToOne
|
||||||
|
@JoinColumn(name = "ref")
|
||||||
|
private MyEntity2 ref;
|
||||||
|
|
||||||
|
public MyEntity1() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(Long id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getVersion() {
|
||||||
|
return version;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setVersion(Long version) {
|
||||||
|
this.version = version;
|
||||||
|
}
|
||||||
|
|
||||||
|
public MyEntity2 getRef() {
|
||||||
|
return ref;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setRef(MyEntity2 ref) {
|
||||||
|
this.ref = ref;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity(name = "MyEntity2")
|
||||||
|
public static class MyEntity2 {
|
||||||
|
@Id
|
||||||
|
@GeneratedValue
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
public MyEntity2() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue