HHH-13001 Add test case
This commit is contained in:
parent
f401a0c7b3
commit
488916cca4
|
@ -0,0 +1,144 @@
|
||||||
|
/*
|
||||||
|
* 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.jpa.test.criteria.selectcase;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import javax.persistence.Entity;
|
||||||
|
import javax.persistence.Id;
|
||||||
|
import javax.persistence.Tuple;
|
||||||
|
import javax.persistence.criteria.CriteriaBuilder;
|
||||||
|
import javax.persistence.criteria.CriteriaQuery;
|
||||||
|
import javax.persistence.criteria.Predicate;
|
||||||
|
import javax.persistence.criteria.Root;
|
||||||
|
|
||||||
|
import org.hibernate.cfg.AvailableSettings;
|
||||||
|
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
||||||
|
import org.hibernate.query.criteria.LiteralHandlingMode;
|
||||||
|
|
||||||
|
import org.hibernate.testing.TestForIssue;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static org.hibernate.testing.transaction.TransactionUtil.doInJPA;
|
||||||
|
import static org.junit.Assert.assertNotNull;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests query rendering and execution
|
||||||
|
* when {@link CriteriaBuilder.Case} is present in the criteria
|
||||||
|
* and the {@code hibernate.criteria.literal_handling_mode} is set to {@literal bind}.
|
||||||
|
*
|
||||||
|
* In both cases we expect that between predicate parameter will be bound,
|
||||||
|
* but right hand literals of case expression will not.
|
||||||
|
*
|
||||||
|
* Having such query:
|
||||||
|
* "case when generatedAlias0.commits between :param0 and :param1 then 1 when generatedAlias0.commits between :param2 and :param3 then 2 else 3 end".
|
||||||
|
* And not:
|
||||||
|
* "case when generatedAlias0.commits between :param0 and :param1 then :param3 when generatedAlias0.commits between :param4 and :param5 then :param6 else :param7 end".
|
||||||
|
*
|
||||||
|
* @author Fabio Massimo Ercoli
|
||||||
|
*/
|
||||||
|
public class SelectCaseLiteralHandlingBindTest extends BaseEntityManagerFunctionalTestCase {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Class<?>[] getAnnotatedClasses() {
|
||||||
|
return new Class[] { Programmer.class };
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void selectCaseExpression() {
|
||||||
|
|
||||||
|
doInJPA( this::entityManagerFactory, entityManager -> {
|
||||||
|
CriteriaBuilder cb = entityManager.getCriteriaBuilder();
|
||||||
|
CriteriaQuery<Tuple> query = cb.createTupleQuery();
|
||||||
|
Root<Programmer> programmer = query.from( Programmer.class );
|
||||||
|
|
||||||
|
Predicate junior = cb.between( programmer.get( "commits" ), 0, 10 );
|
||||||
|
Predicate senior = cb.between( programmer.get( "commits" ), 11, 20 );
|
||||||
|
|
||||||
|
CriteriaBuilder.Case<Integer> selectCase = cb.selectCase();
|
||||||
|
selectCase.when( junior, 1 )
|
||||||
|
.when( senior, 2 )
|
||||||
|
.otherwise( 3 );
|
||||||
|
|
||||||
|
query.multiselect( programmer.get( "team" ), selectCase );
|
||||||
|
|
||||||
|
List<Tuple> resultList = entityManager.createQuery( query ).getResultList();
|
||||||
|
assertNotNull( resultList );
|
||||||
|
assertTrue( resultList.isEmpty() );
|
||||||
|
} );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@TestForIssue(jiraKey = "HHH-13001")
|
||||||
|
public void selectSumOnCaseExpression() {
|
||||||
|
|
||||||
|
doInJPA( this::entityManagerFactory, entityManager -> {
|
||||||
|
CriteriaBuilder cb = entityManager.getCriteriaBuilder();
|
||||||
|
CriteriaQuery<Tuple> query = cb.createTupleQuery();
|
||||||
|
Root<Programmer> programmer = query.from( Programmer.class );
|
||||||
|
|
||||||
|
Predicate junior = cb.between( programmer.get( "commits" ), 0, 10 );
|
||||||
|
Predicate senior = cb.between( programmer.get( "commits" ), 11, 20 );
|
||||||
|
|
||||||
|
CriteriaBuilder.Case<Integer> selectCase = cb.selectCase();
|
||||||
|
selectCase.when( junior, 1 )
|
||||||
|
.when( senior, 2 )
|
||||||
|
.otherwise( 3 );
|
||||||
|
|
||||||
|
query.multiselect( programmer.get( "team" ), cb.sum( selectCase ) )
|
||||||
|
.groupBy( programmer.get( "team" ) )
|
||||||
|
.orderBy( cb.asc( programmer.get( "team" ) ) );
|
||||||
|
|
||||||
|
List<Tuple> resultList = entityManager.createQuery( query ).getResultList();
|
||||||
|
assertNotNull( resultList );
|
||||||
|
assertTrue( resultList.isEmpty() );
|
||||||
|
} );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void whereCaseExpression() {
|
||||||
|
|
||||||
|
doInJPA( this::entityManagerFactory, entityManager -> {
|
||||||
|
CriteriaBuilder cb = entityManager.getCriteriaBuilder();
|
||||||
|
CriteriaQuery<Programmer> query = cb.createQuery(Programmer.class);
|
||||||
|
Root<Programmer> programmer = query.from( Programmer.class );
|
||||||
|
|
||||||
|
Predicate junior = cb.between( programmer.get( "commits" ), 0, 10 );
|
||||||
|
Predicate senior = cb.between( programmer.get( "commits" ), 11, 20 );
|
||||||
|
|
||||||
|
CriteriaBuilder.Case<Integer> selectCase = cb.selectCase();
|
||||||
|
selectCase.when( junior, 1 )
|
||||||
|
.when( senior, 2 )
|
||||||
|
.otherwise( 3 );
|
||||||
|
|
||||||
|
query.select( programmer ).where( cb.equal( selectCase, 5 ) );
|
||||||
|
|
||||||
|
List<Programmer> resultList = entityManager.createQuery( query ).getResultList();
|
||||||
|
assertNotNull( resultList );
|
||||||
|
assertTrue( resultList.isEmpty() );
|
||||||
|
} );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Map getConfig() {
|
||||||
|
Map config = super.getConfig();
|
||||||
|
config.put( AvailableSettings.CRITERIA_LITERAL_HANDLING_MODE, LiteralHandlingMode.BIND );
|
||||||
|
return config;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity(name = "Programmer")
|
||||||
|
public static class Programmer {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private Long id;
|
||||||
|
private String nick;
|
||||||
|
|
||||||
|
private String team;
|
||||||
|
private Integer commits;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue