HHH-16745 Add test for issue
This commit is contained in:
parent
ecc7dc1880
commit
b157ec35c6
|
@ -0,0 +1,209 @@
|
|||
package org.hibernate.orm.test.caching;
|
||||
|
||||
import org.hibernate.Hibernate;
|
||||
import org.hibernate.annotations.Cache;
|
||||
import org.hibernate.annotations.CacheConcurrencyStrategy;
|
||||
|
||||
import org.hibernate.testing.orm.junit.DomainModel;
|
||||
import org.hibernate.testing.orm.junit.Jira;
|
||||
import org.hibernate.testing.orm.junit.SessionFactory;
|
||||
import org.hibernate.testing.orm.junit.SessionFactoryScope;
|
||||
import org.junit.jupiter.api.AfterAll;
|
||||
import org.junit.jupiter.api.BeforeAll;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import jakarta.persistence.Cacheable;
|
||||
import jakarta.persistence.Entity;
|
||||
import jakarta.persistence.FetchType;
|
||||
import jakarta.persistence.GeneratedValue;
|
||||
import jakarta.persistence.Id;
|
||||
import jakarta.persistence.OneToOne;
|
||||
import jakarta.persistence.Version;
|
||||
|
||||
import static org.assertj.core.api.AssertionsForClassTypes.assertThat;
|
||||
|
||||
@DomainModel( annotatedClasses = {
|
||||
CachingAndVersionOneToOneLazyTest.Child.class,
|
||||
CachingAndVersionOneToOneLazyTest.Parent.class,
|
||||
CachingAndVersionOneToOneLazyTest.VersionedParent.class,
|
||||
} )
|
||||
@SessionFactory
|
||||
@Jira( "https://hibernate.atlassian.net/browse/HHH-16745" )
|
||||
public class CachingAndVersionOneToOneLazyTest {
|
||||
@BeforeAll
|
||||
public void setUp(SessionFactoryScope scope) {
|
||||
scope.inTransaction( session -> {
|
||||
final Child child = new Child( "child" );
|
||||
session.persist( new VersionedParent( "versioned_parent", child ) );
|
||||
session.persist( new Parent( "normal_parent", child ) );
|
||||
session.persist( child );
|
||||
} );
|
||||
}
|
||||
|
||||
@AfterAll
|
||||
public void tearDown(SessionFactoryScope scope) {
|
||||
scope.inTransaction( session -> {
|
||||
session.createMutationQuery( "delete from Child" ).executeUpdate();
|
||||
session.createMutationQuery( "delete from Parent" ).executeUpdate();
|
||||
session.createMutationQuery( "delete from VersionedParent" ).executeUpdate();
|
||||
} );
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSelectVersionedParent(SessionFactoryScope scope) {
|
||||
scope.inTransaction( session -> {
|
||||
final VersionedParent parent = session.createQuery(
|
||||
"select p from VersionedParent p",
|
||||
VersionedParent.class
|
||||
).getSingleResult();
|
||||
assertThat( parent.getData() ).isEqualTo( "versioned_parent" );
|
||||
assertThat( parent.getChild().getData() ).isEqualTo( "child" );
|
||||
assertThat( Hibernate.isInitialized( parent.getChild().getVersionedParent() ) ).isTrue();
|
||||
} );
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSelectNormalParent(SessionFactoryScope scope) {
|
||||
scope.inTransaction( session -> {
|
||||
final Parent parent = session.createQuery(
|
||||
"select p from Parent p",
|
||||
Parent.class
|
||||
).getSingleResult();
|
||||
assertThat( parent.getData() ).isEqualTo( "normal_parent" );
|
||||
assertThat( parent.getChild().getData() ).isEqualTo( "child" );
|
||||
assertThat( Hibernate.isInitialized( parent.getChild().getParent() ) ).isTrue();
|
||||
} );
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSelectChild(SessionFactoryScope scope) {
|
||||
scope.inTransaction( session -> {
|
||||
final Child domainId = session.createQuery(
|
||||
"select c from Child c",
|
||||
Child.class
|
||||
).getSingleResult();
|
||||
assertThat( domainId.getData() ).isEqualTo( "child" );
|
||||
assertThat( Hibernate.isInitialized( domainId.getVersionedParent() ) ).isFalse();
|
||||
assertThat( domainId.getVersionedParent().getData() ).isEqualTo( "versioned_parent" );
|
||||
assertThat( Hibernate.isInitialized( domainId.getParent() ) ).isFalse();
|
||||
assertThat( domainId.getParent().getData() ).isEqualTo( "normal_parent" );
|
||||
} );
|
||||
}
|
||||
|
||||
@Entity( name = "Parent" )
|
||||
public static class Parent {
|
||||
@Id
|
||||
@GeneratedValue
|
||||
private Long id;
|
||||
|
||||
@OneToOne( mappedBy = "parent" )
|
||||
private Child child;
|
||||
|
||||
private String data;
|
||||
|
||||
public Parent() {
|
||||
}
|
||||
|
||||
public Parent(String data, Child child) {
|
||||
this.data = data;
|
||||
this.child = child;
|
||||
child.setParent( this );
|
||||
}
|
||||
|
||||
public Long getId() {
|
||||
return id;
|
||||
}
|
||||
|
||||
public Child getChild() {
|
||||
return child;
|
||||
}
|
||||
|
||||
public String getData() {
|
||||
return data;
|
||||
}
|
||||
}
|
||||
|
||||
@Entity( name = "VersionedParent" )
|
||||
public static class VersionedParent {
|
||||
@Id
|
||||
@GeneratedValue
|
||||
private Long id;
|
||||
|
||||
@Version
|
||||
private Integer rowVersion;
|
||||
|
||||
@OneToOne( mappedBy = "versionedParent" )
|
||||
private Child child;
|
||||
|
||||
private String data;
|
||||
|
||||
public VersionedParent() {
|
||||
}
|
||||
|
||||
public VersionedParent(String data, Child child) {
|
||||
this.data = data;
|
||||
this.child = child;
|
||||
child.setVersionedParent( this );
|
||||
}
|
||||
|
||||
public Long getId() {
|
||||
return id;
|
||||
}
|
||||
|
||||
public Child getChild() {
|
||||
return child;
|
||||
}
|
||||
|
||||
public String getData() {
|
||||
return data;
|
||||
}
|
||||
}
|
||||
|
||||
@Entity( name = "Child" )
|
||||
@Cacheable
|
||||
@Cache( usage = CacheConcurrencyStrategy.READ_WRITE )
|
||||
public static class Child {
|
||||
@Id
|
||||
@GeneratedValue
|
||||
private Long id;
|
||||
|
||||
private String data;
|
||||
|
||||
@OneToOne( fetch = FetchType.LAZY )
|
||||
private VersionedParent versionedParent;
|
||||
|
||||
@OneToOne( fetch = FetchType.LAZY )
|
||||
private Parent parent;
|
||||
|
||||
public Child() {
|
||||
}
|
||||
|
||||
public Child(String data) {
|
||||
this.data = data;
|
||||
}
|
||||
|
||||
public Long getId() {
|
||||
return id;
|
||||
}
|
||||
|
||||
public VersionedParent getVersionedParent() {
|
||||
return versionedParent;
|
||||
}
|
||||
|
||||
public void setVersionedParent(VersionedParent versionedParent) {
|
||||
this.versionedParent = versionedParent;
|
||||
}
|
||||
|
||||
public Parent getParent() {
|
||||
return parent;
|
||||
}
|
||||
|
||||
public void setParent(Parent parent) {
|
||||
this.parent = parent;
|
||||
}
|
||||
|
||||
public String getData() {
|
||||
return data;
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue