HHH-18610 Add test for issue

This commit is contained in:
Andrea Boriero 2024-10-01 09:52:59 +02:00 committed by Andrea Boriero
parent 8b517c50f3
commit cd47e91900
1 changed files with 456 additions and 0 deletions

View File

@ -0,0 +1,456 @@
/*
* SPDX-License-Identifier: LGPL-2.1-or-later
* Copyright Red Hat Inc. and Hibernate Authors
*/
package org.hibernate.orm.test.inheritance;
import jakarta.persistence.CascadeType;
import jakarta.persistence.Column;
import jakarta.persistence.DiscriminatorColumn;
import jakarta.persistence.DiscriminatorType;
import jakarta.persistence.DiscriminatorValue;
import jakarta.persistence.Embeddable;
import jakarta.persistence.Entity;
import jakarta.persistence.Id;
import jakarta.persistence.Inheritance;
import jakarta.persistence.InheritanceType;
import jakarta.persistence.JoinColumn;
import jakarta.persistence.ManyToOne;
import jakarta.persistence.OneToMany;
import jakarta.persistence.OneToOne;
import jakarta.persistence.Table;
import org.hibernate.testing.orm.junit.DomainModel;
import org.hibernate.testing.orm.junit.JiraKey;
import org.hibernate.testing.orm.junit.SessionFactory;
import org.hibernate.testing.orm.junit.SessionFactoryScope;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;
import static org.hamcrest.MatcherAssert.assertThat;
import static org.hamcrest.Matchers.contains;
import static org.hamcrest.Matchers.instanceOf;
import static org.hamcrest.core.Is.is;
@JiraKey("HHH-18610")
@DomainModel(
annotatedClasses = {
SingleTableNativeQueryTest.Toy.class,
SingleTableNativeQueryTest.Color.class,
SingleTableNativeQueryTest.Family.class,
SingleTableNativeQueryTest.Person.class,
SingleTableNativeQueryTest.Child.class,
SingleTableNativeQueryTest.Man.class,
SingleTableNativeQueryTest.Woman.class
}
)
@SessionFactory
public class SingleTableNativeQueryTest {
@BeforeEach
public void setUp(SessionFactoryScope scope) {
scope.inTransaction(
session -> {
Toy marioToy;
Toy fidgetSpinner;
Man john;
Woman jane;
Child susan;
Child mark;
Family family;
List<Child> children;
List<Person> familyMembers;
marioToy = new Toy( 1L, "Super Mario retro Mushroom" );
fidgetSpinner = new Toy( 2L, "Fidget Spinner" );
john = new Man( "John", "Riding Roller Coasters" );
jane = new Woman( "Jane", "Hippotherapist" );
susan = new Child( "Susan", marioToy );
mark = new Child( "Mark", fidgetSpinner );
family = new Family( "McCloud" );
children = new ArrayList<>( Arrays.asList( susan, mark ) );
familyMembers = Arrays.asList( john, jane, susan, mark );
session.persist( marioToy );
session.persist( fidgetSpinner );
jane.setColor( new Color( "pink" ) );
jane.setHusband( john );
jane.setChildren( children );
john.setColor( new Color( "blue" ) );
john.setWife( jane );
john.setChildren( children );
for ( Child child : children ) {
child.setFather( john );
child.setMother( jane );
}
for ( Person person : familyMembers ) {
family.add( person );
}
session.persist( family );
} );
}
@AfterEach
public void tearDown(SessionFactoryScope scope) {
scope.getSessionFactory().getSchemaManager().truncateMappedObjects();
}
@Test
public void itShouldGetPersons(SessionFactoryScope scope) {
scope.inTransaction(
session -> {
List<Object> results = session.createNativeQuery( "select {p.*} from person p order by p.name",
Object.class ).addEntity( "p", Person.class ).list();
assertThat( results.stream().map( p -> ((Person) p).getName() ).collect( Collectors.toList() ),
contains( "Jane", "John", "Mark", "Susan" ) );
}
);
}
@Test
public void itShouldGetWife(SessionFactoryScope scope) {
scope.inTransaction(
session -> {
List<Object[]> results = session.createNativeQuery(
"select {m.*}, {w.*} from person m left join person w on m.wife_name = w.name where m.TYPE = 'MAN'",
Object[].class )
.addEntity( "m", Person.class )
.addEntity( "w", Person.class )
.list();
assertThat( results.size(), is( 1 ) );
assertThat( results.get( 0 )[0], instanceOf( Man.class ) );
assertThat( ((Man) results.get( 0 )[0]).getName(), is( "John" ) );
assertThat( results.get( 0 )[1], instanceOf( Woman.class ) );
assertThat( ((Woman) results.get( 0 )[1]).getName(), is( "Jane" ) );
}
);
}
@Test
public void itShouldGetFamilyMembers(SessionFactoryScope scope) {
scope.inTransaction(
session -> {
List<Object> results = session.createNativeQuery( "select {f.*} from family f", Object.class )
.addEntity( "f", Family.class ).list();
Family family = (Family) results.get( 0 );
List<Person> members = family.getMembers();
assertThat( members.size(), is( 4 ) );
}
);
}
@Embeddable
public static class Color {
@Column(name = "color")
private String attributes;
public Color() {
}
public Color(final String attributes) {
this.attributes = attributes;
}
public String getAttributes() {
return attributes;
}
public void setAttributes(final String attributes) {
this.attributes = attributes;
}
}
@Entity(name = "Family")
@Table(name = "family")
public static class Family {
@Id
private String name;
@OneToMany(mappedBy = "familyName", cascade = CascadeType.ALL, orphanRemoval = true)
private List<Person> members = new ArrayList<>();
public Family() {
}
public Family(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public List<Person> getMembers() {
return members;
}
public void setMembers(List<Person> members) {
this.members = members;
}
public void add(Person person) {
person.setFamilyName( this );
members.add( person );
}
@Override
public String toString() {
return "Family [name=" + name + "]";
}
}
@Entity(name = "Person")
@Table(name = "person")
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name = "TYPE", discriminatorType = DiscriminatorType.STRING)
public static class Person {
@Id
private String name;
@ManyToOne
private Family familyName;
public Person() {
}
public Person(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Family getFamilyName() {
return familyName;
}
public void setFamilyName(Family familyName) {
this.familyName = familyName;
}
@Override
public String toString() {
return name;
}
}
@Entity(name = "Toy")
@Table(name = "toy")
public static class Toy {
@Id
private Long id;
private String name;
@OneToMany(mappedBy = "favoriteThing", cascade = CascadeType.ALL, orphanRemoval = true)
List<Child> favorite = new ArrayList<>();
public Toy() {
}
public Toy(final Long id, final String name) {
this.id = id;
this.name = name;
}
public Long getId() {
return id;
}
public void setId(final Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(final String name) {
this.name = name;
}
}
@Entity(name = "Child")
@DiscriminatorValue("CHILD")
public static class Child extends Person {
@ManyToOne
@JoinColumn(name = "fav_toy")
private Toy favoriteThing;
@ManyToOne
private Woman mother;
@ManyToOne
private Man father;
public Child() {
}
public Child(String name, Toy favouriteThing) {
super( name );
this.favoriteThing = favouriteThing;
}
public Toy getFavoriteThing() {
return favoriteThing;
}
public void setFavoriteThing(Toy favouriteThing) {
this.favoriteThing = favouriteThing;
}
public Man getFather() {
return father;
}
public void setFather(Man father) {
this.father = father;
}
public Woman getMother() {
return mother;
}
public void setMother(Woman mother) {
this.mother = mother;
}
}
@Entity(name = "Man")
@DiscriminatorValue("MAN")
public static class Man extends Person {
private Color color;
@Column(name = "fav_hobby")
private String favoriteThing;
@OneToOne
private Woman wife;
@OneToMany(mappedBy = "father")
private List<Child> children = new ArrayList<>();
public Man() {
}
public Man(String name, String favoriteThing) {
super( name );
this.favoriteThing = favoriteThing;
}
public String getFavoriteThing() {
return favoriteThing;
}
public void setFavoriteThing(String favoriteThing) {
this.favoriteThing = favoriteThing;
}
public Woman getWife() {
return wife;
}
public void setWife(Woman wife) {
this.wife = wife;
}
public List<Child> getChildren() {
return children;
}
public void setChildren(List<Child> children) {
this.children = children;
}
public Color getColor() {
return color;
}
public void setColor(final Color color) {
this.color = color;
}
}
@Entity(name = "Woman")
@DiscriminatorValue("WOMAN")
public static class Woman extends Person {
private Color color;
private String job;
@OneToOne
private Man husband;
@OneToMany(mappedBy = "mother")
private List<Child> children = new ArrayList<>();
public Woman() {
}
public Woman(String name, String job) {
super( name );
this.job = job;
}
public String getJob() {
return job;
}
public void setJob(String job) {
this.job = job;
}
public Man getHusband() {
return husband;
}
public void setHusband(Man husband) {
this.husband = husband;
}
public List<Child> getChildren() {
return children;
}
public void setChildren(List<Child> children) {
this.children = children;
}
public Color getColor() {
return color;
}
public void setColor(final Color color) {
this.color = color;
}
}
}