Remove use of PASS_DISTINCT_THROUGH from distinct test
Property will be deleted in a subsequent commit
This commit is contained in:
parent
3f8a0b6776
commit
aa6035a9fd
|
@ -0,0 +1,148 @@
|
|||
/*
|
||||
* Hibernate, Relational Persistence for Idiomatic Java
|
||||
*
|
||||
* 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>.
|
||||
*/
|
||||
package org.hibernate.orm.test.distinct;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import org.hibernate.boot.SessionFactoryBuilder;
|
||||
|
||||
import org.hibernate.testing.TestForIssue;
|
||||
import org.hibernate.testing.jdbc.SQLStatementInterceptor;
|
||||
import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase;
|
||||
import org.junit.Test;
|
||||
|
||||
import jakarta.persistence.CascadeType;
|
||||
import jakarta.persistence.Column;
|
||||
import jakarta.persistence.Entity;
|
||||
import jakarta.persistence.Id;
|
||||
import jakarta.persistence.ManyToOne;
|
||||
import jakarta.persistence.NamedQueries;
|
||||
import jakarta.persistence.NamedQuery;
|
||||
import jakarta.persistence.OneToMany;
|
||||
|
||||
import static org.hibernate.testing.transaction.TransactionUtil.doInHibernate;
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
/**
|
||||
* @author Vlad Mihalcea
|
||||
*/
|
||||
@TestForIssue(jiraKey = "HHH-10965")
|
||||
public class SelectDistinctHqlTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||
|
||||
private static final String DISTINCT_NAMED_QUERY = "distinct";
|
||||
private SQLStatementInterceptor sqlStatementInterceptor;
|
||||
|
||||
@Override
|
||||
protected void configureSessionFactoryBuilder(SessionFactoryBuilder sfb) {
|
||||
sqlStatementInterceptor = new SQLStatementInterceptor( sfb );
|
||||
}
|
||||
|
||||
@Override
|
||||
protected Class<?>[] getAnnotatedClasses() {
|
||||
return new Class<?>[] {
|
||||
Person.class,
|
||||
Phone.class,
|
||||
};
|
||||
}
|
||||
|
||||
protected void prepareTest() {
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
Person person = new Person();
|
||||
person.id = 1L;
|
||||
session.persist( person );
|
||||
|
||||
person.addPhone( new Phone( "027-123-4567" ) );
|
||||
person.addPhone( new Phone( "028-234-9876" ) );
|
||||
} );
|
||||
}
|
||||
|
||||
@Override
|
||||
protected boolean isCleanupTestDataRequired() {
|
||||
return true;
|
||||
}
|
||||
|
||||
@Test
|
||||
public void test() {
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
sqlStatementInterceptor.getSqlQueries().clear();
|
||||
List<Person> persons = session.createQuery( "select distinct p from Person p" )
|
||||
.getResultList();
|
||||
String sqlQuery = sqlStatementInterceptor.getSqlQueries().getLast();
|
||||
assertEquals( 1, persons.size() );
|
||||
assertTrue( sqlQuery.contains( " distinct " ) );
|
||||
} );
|
||||
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
List<Person> persons = session.createQuery( "select p from Person p left join fetch p.phones " )
|
||||
.getResultList();
|
||||
// with Hibernate ORM 6 it is not necessary to use *distinct* to not duplicate the instances which own the association
|
||||
assertEquals( 1, persons.size() );
|
||||
} );
|
||||
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
sqlStatementInterceptor.getSqlQueries().clear();
|
||||
List<Person> persons = session.createQuery( "select distinct p from Person p left join fetch p.phones " )
|
||||
.getResultList();
|
||||
assertEquals( 1, persons.size() );
|
||||
String sqlQuery = sqlStatementInterceptor.getSqlQueries().getLast();
|
||||
assertTrue( sqlQuery.contains( " distinct " ) );
|
||||
} );
|
||||
}
|
||||
|
||||
@Test
|
||||
@TestForIssue(jiraKey = "HHH-13780")
|
||||
public void testNamedQueryDistinctPassThroughTrueWhenNotSpecified() {
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
sqlStatementInterceptor.getSqlQueries().clear();
|
||||
List<Person> persons =
|
||||
session.createNamedQuery( DISTINCT_NAMED_QUERY, Person.class )
|
||||
.setMaxResults( 5 )
|
||||
.getResultList();
|
||||
assertEquals( 1, persons.size() );
|
||||
String sqlQuery = sqlStatementInterceptor.getSqlQueries().getLast();
|
||||
assertTrue( sqlQuery.contains( " distinct " ) );
|
||||
} );
|
||||
}
|
||||
|
||||
@Entity(name = "Person")
|
||||
@NamedQueries({
|
||||
@NamedQuery(name = DISTINCT_NAMED_QUERY, query = "select distinct p from Person p left join fetch p.phones")
|
||||
})
|
||||
public static class Person {
|
||||
|
||||
@Id
|
||||
private Long id;
|
||||
|
||||
@OneToMany(mappedBy = "person", cascade = CascadeType.ALL, orphanRemoval = true)
|
||||
private List<Phone> phones = new ArrayList<>();
|
||||
|
||||
public void addPhone(Phone phone) {
|
||||
phones.add( phone );
|
||||
phone.person = this;
|
||||
}
|
||||
}
|
||||
|
||||
@Entity(name = "Phone")
|
||||
public static class Phone {
|
||||
|
||||
@Id
|
||||
@Column(name = "`number`")
|
||||
private String number;
|
||||
|
||||
@ManyToOne
|
||||
private Person person;
|
||||
|
||||
public Phone() {
|
||||
}
|
||||
|
||||
public Phone(String number) {
|
||||
this.number = number;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,236 +0,0 @@
|
|||
/*
|
||||
* Hibernate, Relational Persistence for Idiomatic Java
|
||||
*
|
||||
* 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>.
|
||||
*/
|
||||
package org.hibernate.test.distinct;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import jakarta.persistence.CascadeType;
|
||||
import jakarta.persistence.Column;
|
||||
import jakarta.persistence.Entity;
|
||||
import jakarta.persistence.Id;
|
||||
import jakarta.persistence.ManyToOne;
|
||||
import jakarta.persistence.OneToMany;
|
||||
import jakarta.persistence.NamedQueries;
|
||||
import jakarta.persistence.NamedQuery;
|
||||
import jakarta.persistence.QueryHint;
|
||||
|
||||
import org.hibernate.boot.SessionFactoryBuilder;
|
||||
import org.hibernate.jpa.QueryHints;
|
||||
|
||||
import org.hibernate.testing.TestForIssue;
|
||||
import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase;
|
||||
import org.hibernate.testing.jdbc.SQLStatementInterceptor;
|
||||
import org.junit.Test;
|
||||
|
||||
import static org.hibernate.testing.transaction.TransactionUtil.doInHibernate;
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
/**
|
||||
* @author Vlad Mihalcea
|
||||
*/
|
||||
@TestForIssue( jiraKey = "HHH-10965" )
|
||||
public class SelectDistinctHqlTest extends BaseNonConfigCoreFunctionalTestCase {
|
||||
|
||||
private static final String DISTINCT_PASSES_THROUGH_TRUE_NAMED_QUERY = "distinctPassesThroughTrue";
|
||||
private static final String DISTINCT_PASSES_THROUGH_FALSE_NAMED_QUERY = "distinctPassesThroughFalse";
|
||||
private static final String DISTINCT_PASSES_THROUGH_NOT_SPECIFIED_NAMED_QUERY = "distinctPassesThroughNotSpecified";
|
||||
private SQLStatementInterceptor sqlStatementInterceptor;
|
||||
|
||||
@Override
|
||||
protected void configureSessionFactoryBuilder(SessionFactoryBuilder sfb) {
|
||||
sqlStatementInterceptor = new SQLStatementInterceptor( sfb );
|
||||
}
|
||||
|
||||
@Override
|
||||
protected Class<?>[] getAnnotatedClasses() {
|
||||
return new Class<?>[] {
|
||||
Person.class,
|
||||
Phone.class,
|
||||
};
|
||||
}
|
||||
|
||||
protected void prepareTest() {
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
Person person = new Person();
|
||||
person.id = 1L;
|
||||
session.persist( person );
|
||||
|
||||
person.addPhone( new Phone( "027-123-4567" ) );
|
||||
person.addPhone( new Phone( "028-234-9876" ) );
|
||||
} );
|
||||
}
|
||||
|
||||
@Override
|
||||
protected boolean isCleanupTestDataRequired() {
|
||||
return true;
|
||||
}
|
||||
|
||||
@Test
|
||||
public void test() {
|
||||
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
sqlStatementInterceptor.getSqlQueries().clear();
|
||||
List<Person> persons = session.createQuery(
|
||||
"select distinct p from Person p" )
|
||||
.getResultList();
|
||||
String sqlQuery = sqlStatementInterceptor.getSqlQueries().getLast();
|
||||
assertTrue( sqlQuery.contains( " distinct " ) );
|
||||
} );
|
||||
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
sqlStatementInterceptor.getSqlQueries().clear();
|
||||
List<Person> persons = session.createQuery(
|
||||
"select distinct p from Person p" )
|
||||
.setHint( QueryHints.HINT_PASS_DISTINCT_THROUGH, false )
|
||||
.getResultList();
|
||||
String sqlQuery = sqlStatementInterceptor.getSqlQueries().getLast();
|
||||
assertFalse( sqlQuery.contains( " distinct " ) );
|
||||
} );
|
||||
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
List<Person> persons = session.createQuery(
|
||||
"select p from Person p left join fetch p.phones " )
|
||||
.getResultList();
|
||||
assertEquals(2, persons.size());
|
||||
} );
|
||||
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
sqlStatementInterceptor.getSqlQueries().clear();
|
||||
List<Person> persons = session.createQuery(
|
||||
"select distinct p from Person p left join fetch p.phones " )
|
||||
.getResultList();
|
||||
assertEquals(1, persons.size());
|
||||
String sqlQuery = sqlStatementInterceptor.getSqlQueries().getLast();
|
||||
assertTrue( sqlQuery.contains( " distinct " ) );
|
||||
} );
|
||||
}
|
||||
|
||||
@Test
|
||||
@TestForIssue( jiraKey = "HHH-11726" )
|
||||
public void testDistinctPassThroughFalse() {
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
sqlStatementInterceptor.getSqlQueries().clear();
|
||||
List<Person> persons = session.createQuery(
|
||||
"select distinct p from Person p left join fetch p.phones ")
|
||||
.setHint(QueryHints.HINT_PASS_DISTINCT_THROUGH, false)
|
||||
.setMaxResults(5)
|
||||
.getResultList();
|
||||
assertEquals(1, persons.size());
|
||||
String sqlQuery = sqlStatementInterceptor.getSqlQueries().getLast();
|
||||
assertFalse(sqlQuery.contains(" distinct "));
|
||||
});
|
||||
}
|
||||
|
||||
@Test
|
||||
@TestForIssue( jiraKey = "HHH-11726" )
|
||||
public void testDistinctPassThroughTrue() {
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
sqlStatementInterceptor.getSqlQueries().clear();
|
||||
List<Person> persons = session.createQuery(
|
||||
"select distinct p from Person p left join fetch p.phones ")
|
||||
.setHint(QueryHints.HINT_PASS_DISTINCT_THROUGH, true)
|
||||
.setMaxResults(5)
|
||||
.getResultList();
|
||||
assertEquals(1, persons.size());
|
||||
String sqlQuery = sqlStatementInterceptor.getSqlQueries().getLast();
|
||||
assertTrue(sqlQuery.contains(" distinct "));
|
||||
});
|
||||
}
|
||||
|
||||
@Test
|
||||
@TestForIssue(jiraKey = "HHH-13780")
|
||||
public void testNamedQueryDistinctPassThroughTrue() {
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
sqlStatementInterceptor.getSqlQueries().clear();
|
||||
List<Person> persons = session.createNamedQuery( DISTINCT_PASSES_THROUGH_TRUE_NAMED_QUERY, Person.class )
|
||||
.setMaxResults( 5 )
|
||||
.getResultList();
|
||||
assertEquals( 1, persons.size() );
|
||||
String sqlQuery = sqlStatementInterceptor.getSqlQueries().getLast();
|
||||
assertTrue( sqlQuery.contains( " distinct " ) );
|
||||
} );
|
||||
}
|
||||
|
||||
@Test
|
||||
@TestForIssue(jiraKey = "HHH-13780")
|
||||
public void testNamedQueryDistinctPassThroughTrueWhenNotSpecified() {
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
sqlStatementInterceptor.getSqlQueries().clear();
|
||||
List<Person> persons =
|
||||
session.createNamedQuery( DISTINCT_PASSES_THROUGH_NOT_SPECIFIED_NAMED_QUERY, Person.class )
|
||||
.setMaxResults( 5 )
|
||||
.getResultList();
|
||||
assertEquals( 1, persons.size() );
|
||||
String sqlQuery = sqlStatementInterceptor.getSqlQueries().getLast();
|
||||
assertTrue( sqlQuery.contains( " distinct " ) );
|
||||
} );
|
||||
}
|
||||
|
||||
@Test
|
||||
@TestForIssue(jiraKey = "HHH-13780")
|
||||
public void testNamedQueryDistinctPassThroughFalse() {
|
||||
doInHibernate( this::sessionFactory, session -> {
|
||||
sqlStatementInterceptor.getSqlQueries().clear();
|
||||
List<Person> persons =
|
||||
session.createNamedQuery( DISTINCT_PASSES_THROUGH_FALSE_NAMED_QUERY, Person.class )
|
||||
.setMaxResults( 5 )
|
||||
.getResultList();
|
||||
assertEquals( 1, persons.size() );
|
||||
String sqlQuery = sqlStatementInterceptor.getSqlQueries().getLast();
|
||||
assertFalse( sqlQuery.contains( " distinct " ) );
|
||||
} );
|
||||
}
|
||||
|
||||
@Entity(name = "Person")
|
||||
@NamedQueries({
|
||||
@NamedQuery(name = DISTINCT_PASSES_THROUGH_TRUE_NAMED_QUERY,
|
||||
query = "select distinct p from Person p left join fetch p.phones",
|
||||
hints = {
|
||||
@QueryHint(name = QueryHints.HINT_PASS_DISTINCT_THROUGH, value = "true")
|
||||
}),
|
||||
@NamedQuery(name = DISTINCT_PASSES_THROUGH_FALSE_NAMED_QUERY,
|
||||
query = "select distinct p from Person p left join fetch p.phones",
|
||||
hints = {
|
||||
@QueryHint(name = QueryHints.HINT_PASS_DISTINCT_THROUGH, value = "false")
|
||||
}),
|
||||
@NamedQuery(name = DISTINCT_PASSES_THROUGH_NOT_SPECIFIED_NAMED_QUERY,
|
||||
query = "select distinct p from Person p left join fetch p.phones")
|
||||
})
|
||||
public static class Person {
|
||||
|
||||
@Id
|
||||
private Long id;
|
||||
|
||||
@OneToMany(mappedBy = "person", cascade = CascadeType.ALL, orphanRemoval = true)
|
||||
private List<Phone> phones = new ArrayList<>();
|
||||
|
||||
public void addPhone(Phone phone) {
|
||||
phones.add( phone );
|
||||
phone.person = this;
|
||||
}
|
||||
}
|
||||
|
||||
@Entity(name = "Phone")
|
||||
public static class Phone {
|
||||
|
||||
@Id
|
||||
@Column(name = "`number`")
|
||||
private String number;
|
||||
|
||||
@ManyToOne
|
||||
private Person person;
|
||||
|
||||
public Phone() {
|
||||
}
|
||||
|
||||
public Phone(String number) {
|
||||
this.number = number;
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue