mirror of https://github.com/apache/openjpa.git
OPENJPA-1015. Enforce column width for testcases
git-svn-id: https://svn.apache.org/repos/asf/openjpa/trunk@779361 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
fcebb24e61
commit
3464d8e9b8
|
@ -52,9 +52,10 @@ public class XMLDefPropMixedFieldAccess2 {
|
||||||
|
|
||||||
public boolean equals(Object obj) {
|
public boolean equals(Object obj) {
|
||||||
if (obj instanceof XMLDefPropMixedFieldAccess2) {
|
if (obj instanceof XMLDefPropMixedFieldAccess2) {
|
||||||
XMLDefPropMixedFieldAccess2 dpmfa = (XMLDefPropMixedFieldAccess2)obj;
|
XMLDefPropMixedFieldAccess2 dpmfa =
|
||||||
return getId() == dpmfa.getId() &&
|
(XMLDefPropMixedFieldAccess2) obj;
|
||||||
getStrField().equals(dpmfa.getStrProp());
|
return getId() == dpmfa.getId()
|
||||||
|
&& getStrField().equals(dpmfa.getStrProp());
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,12 +7,14 @@ package org.apache.openjpa.persistence.criteria;
|
||||||
import javax.persistence.metamodel.Attribute;
|
import javax.persistence.metamodel.Attribute;
|
||||||
import javax.persistence.metamodel.List;
|
import javax.persistence.metamodel.List;
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.criteria.CompUser.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
|
value=org.apache.openjpa.persistence.criteria.CompUser.class)
|
||||||
public class CompUser_ {
|
public class CompUser_ {
|
||||||
public static volatile Attribute<CompUser,Address> address;
|
public static volatile Attribute<CompUser,Address> address;
|
||||||
public static volatile Attribute<CompUser,Integer> age;
|
public static volatile Attribute<CompUser,Integer> age;
|
||||||
public static volatile Attribute<CompUser,String> computerName;
|
public static volatile Attribute<CompUser,String> computerName;
|
||||||
public static volatile Attribute<CompUser,CompUser.CreditRating> creditRating;
|
public static volatile Attribute<CompUser,
|
||||||
|
CompUser.CreditRating> creditRating;
|
||||||
public static volatile Attribute<CompUser,String> name;
|
public static volatile Attribute<CompUser,String> name;
|
||||||
public static volatile List<CompUser,String> nicknames;
|
public static volatile List<CompUser,String> nicknames;
|
||||||
public static volatile Attribute<CompUser,Integer> userid;
|
public static volatile Attribute<CompUser,Integer> userid;
|
||||||
|
|
|
@ -50,7 +50,8 @@ public class CreditCard {
|
||||||
return transactionHistory;
|
return transactionHistory;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setTransactionHistory(List<TransactionHistory> transactionHistory) {
|
public void setTransactionHistory(List<TransactionHistory>
|
||||||
|
transactionHistory) {
|
||||||
this.transactionHistory = transactionHistory;
|
this.transactionHistory = transactionHistory;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,5 +22,6 @@ public class Customer_ {
|
||||||
public static volatile Attribute<Customer,String> name;
|
public static volatile Attribute<Customer,String> name;
|
||||||
public static volatile Set<Customer,Order> orders;
|
public static volatile Set<Customer,Order> orders;
|
||||||
public static volatile Attribute<Customer,Integer> status;
|
public static volatile Attribute<Customer,Integer> status;
|
||||||
public static volatile Attribute<Customer,Customer.CreditRating> creditRating;
|
public static volatile Attribute<Customer,Customer.CreditRating>
|
||||||
|
creditRating;
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,8 @@ public class Employee_ {
|
||||||
public static volatile Attribute<Employee,Contact> contactInfo;
|
public static volatile Attribute<Employee,Contact> contactInfo;
|
||||||
public static volatile Attribute<Employee,Department> department;
|
public static volatile Attribute<Employee,Department> department;
|
||||||
public static volatile Attribute<Employee,Integer> empId;
|
public static volatile Attribute<Employee,Integer> empId;
|
||||||
public static volatile Attribute<Employee,FrequentFlierPlan> frequentFlierPlan;
|
public static volatile Attribute<Employee,FrequentFlierPlan>
|
||||||
|
frequentFlierPlan;
|
||||||
public static volatile Attribute<Employee,Manager> manager;
|
public static volatile Attribute<Employee,Manager> manager;
|
||||||
public static volatile Attribute<Employee,String> name;
|
public static volatile Attribute<Employee,String> name;
|
||||||
public static volatile Attribute<Employee,Integer> rating;
|
public static volatile Attribute<Employee,Integer> rating;
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
package org.apache.openjpa.persistence.criteria;
|
package org.apache.openjpa.persistence.criteria;
|
||||||
|
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.criteria.FemaleUser.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
|
value=org.apache.openjpa.persistence.criteria.FemaleUser.class)
|
||||||
public class FemaleUser_ extends CompUser_ {
|
public class FemaleUser_ extends CompUser_ {
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,7 +6,8 @@ package org.apache.openjpa.persistence.criteria;
|
||||||
|
|
||||||
import javax.persistence.metamodel.Attribute;
|
import javax.persistence.metamodel.Attribute;
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.criteria.FrequentFlierPlan.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
|
value=org.apache.openjpa.persistence.criteria.FrequentFlierPlan.class)
|
||||||
public class FrequentFlierPlan_ {
|
public class FrequentFlierPlan_ {
|
||||||
public static volatile Attribute<FrequentFlierPlan,Integer> annualMiles;
|
public static volatile Attribute<FrequentFlierPlan,Integer> annualMiles;
|
||||||
public static volatile Attribute<FrequentFlierPlan,String> id;
|
public static volatile Attribute<FrequentFlierPlan,String> id;
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
package org.apache.openjpa.persistence.criteria;
|
package org.apache.openjpa.persistence.criteria;
|
||||||
|
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.criteria.MaleUser.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
|
value=org.apache.openjpa.persistence.criteria.MaleUser.class)
|
||||||
public class MaleUser_ extends CompUser_ {
|
public class MaleUser_ extends CompUser_ {
|
||||||
}
|
}
|
||||||
|
|
|
@ -163,8 +163,11 @@ public class TestCriteria extends SingleEMFTestCase {
|
||||||
DomainObject c = qb.createQueryDefinition(Customer.class);
|
DomainObject c = qb.createQueryDefinition(Customer.class);
|
||||||
DomainObject o = c.join("orders");
|
DomainObject o = c.join("orders");
|
||||||
DomainObject a = c.join("address");
|
DomainObject a = c.join("address");
|
||||||
o.where(a.get("state").equal("CA").and(a.get("county").equal("Santa Clara")));
|
o.where(a.get("state").equal("CA").and(
|
||||||
o.select(o.get("quantity"), o.get("cost").times(1.08), a.get("zipCode"));
|
a.get("county").equal("Santa Clara")));
|
||||||
|
o
|
||||||
|
.select(o.get("quantity"), o.get("cost").times(1.08), a
|
||||||
|
.get("zipCode"));
|
||||||
|
|
||||||
String jpql = "select o.quantity, o.cost*1.08, a.zipCode" +
|
String jpql = "select o.quantity, o.cost*1.08, a.zipCode" +
|
||||||
" from Customer c join c.orders o join c.address a" +
|
" from Customer c join c.orders o join c.address a" +
|
||||||
|
@ -199,8 +202,8 @@ public class TestCriteria extends SingleEMFTestCase {
|
||||||
DomainObject o = qb.createQueryDefinition(Order.class);
|
DomainObject o = qb.createQueryDefinition(Order.class);
|
||||||
DomainObject l = o.join("lineItems");
|
DomainObject l = o.join("lineItems");
|
||||||
DomainObject c = o.join("customer");
|
DomainObject c = o.join("customer");
|
||||||
c.where(c.get("lastName").equal("Smith").and(c.get("firstName").equal("John")))
|
c.where(c.get("lastName").equal("Smith").and(c.get("firstName").
|
||||||
.select(l.get("price").sum());
|
equal("John"))).select(l.get("price").sum());
|
||||||
|
|
||||||
String jpql = "select SUM(l.price)" +
|
String jpql = "select SUM(l.price)" +
|
||||||
" from Order o join o.lineItems l JOIN o.customer c" +
|
" from Order o join o.lineItems l JOIN o.customer c" +
|
||||||
|
@ -310,10 +313,10 @@ public class TestCriteria extends SingleEMFTestCase {
|
||||||
order.get("count")));
|
order.get("count")));
|
||||||
|
|
||||||
|
|
||||||
String jpql = "SELECT NEW org.apache.openjpa.persistence.criteria.Customer"
|
String jpql =
|
||||||
|
"SELECT NEW org.apache.openjpa.persistence.criteria.Customer"
|
||||||
+ "(c.id, c.status, o.count)"
|
+ "(c.id, c.status, o.count)"
|
||||||
+ " FROM Customer c JOIN c.orders o"
|
+ " FROM Customer c JOIN c.orders o" + " WHERE o.count > 100";
|
||||||
+ " WHERE o.count > 100";
|
|
||||||
compare(jpql, q);
|
compare(jpql, q);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -321,9 +324,10 @@ public class TestCriteria extends SingleEMFTestCase {
|
||||||
QueryDefinition q = qb.createQueryDefinition();
|
QueryDefinition q = qb.createQueryDefinition();
|
||||||
DomainObject v = q.addRoot(VideoStore.class);
|
DomainObject v = q.addRoot(VideoStore.class);
|
||||||
DomainObject i = v.join("videoInventory");
|
DomainObject i = v.join("videoInventory");
|
||||||
q.where(v.get("location").get("zipCode").equal("94301")
|
q.where(v.get("location").get("zipCode").equal("94301").and(
|
||||||
.and(i.value().greaterThan(0)));
|
i.value().greaterThan(0)));
|
||||||
q.select(v.get("location").get("street"), i.key().get("title"), i.value());
|
q.select(v.get("location").get("street"), i.key().get("title"), i
|
||||||
|
.value());
|
||||||
|
|
||||||
String jpql = "SELECT v.location.street, KEY(v2).title, VALUE(v2)"
|
String jpql = "SELECT v.location.street, KEY(v2).title, VALUE(v2)"
|
||||||
+ " FROM VideoStore v JOIN v.videoInventory v2"
|
+ " FROM VideoStore v JOIN v.videoInventory v2"
|
||||||
|
@ -431,7 +435,8 @@ public class TestCriteria extends SingleEMFTestCase {
|
||||||
|
|
||||||
public void testCreateSubquery() {
|
public void testCreateSubquery() {
|
||||||
DomainObject customer = qb.createQueryDefinition(Customer.class);
|
DomainObject customer = qb.createQueryDefinition(Customer.class);
|
||||||
DomainObject order = qb.createSubqueryDefinition(customer.get("orders"));
|
DomainObject order =
|
||||||
|
qb.createSubqueryDefinition(customer.get("orders"));
|
||||||
customer.where(order.select(order.get("cost").avg()).greaterThan(100));
|
customer.where(order.select(order.get("cost").avg()).greaterThan(100));
|
||||||
|
|
||||||
String jpql = "SELECT c "
|
String jpql = "SELECT c "
|
||||||
|
@ -466,10 +471,11 @@ public class TestCriteria extends SingleEMFTestCase {
|
||||||
DomainObject e = qb.createQueryDefinition(Employee.class);
|
DomainObject e = qb.createQueryDefinition(Employee.class);
|
||||||
DomainObject f = e.join("frequentFlierPlan");
|
DomainObject f = e.join("frequentFlierPlan");
|
||||||
Expression c =
|
Expression c =
|
||||||
e.generalCase().when(f.get("annualMiles").greaterThan(50000)).then("Platinum")
|
e.generalCase().when(f.get("annualMiles").greaterThan(50000)).then(
|
||||||
.when(f.get("annualMiles").greaterThan(25000)).then("Gold")
|
"Platinum").when(f.get("annualMiles").greaterThan(25000)).then(
|
||||||
.elseCase("XYZ");
|
"Gold").elseCase("XYZ");
|
||||||
e.select(e.get("name"), f.get("name"), e.concat(c,e.literal("Frequent Flyer")));
|
e.select(e.get("name"), f.get("name"), e.concat(c, e
|
||||||
|
.literal("Frequent Flyer")));
|
||||||
|
|
||||||
String jpql = "SELECT e.name, f.name, CONCAT("
|
String jpql = "SELECT e.name, f.name, CONCAT("
|
||||||
+ " CASE WHEN f.annualMiles > 50000 THEN 'Platinum'"
|
+ " CASE WHEN f.annualMiles > 50000 THEN 'Platinum'"
|
||||||
|
@ -482,13 +488,15 @@ public class TestCriteria extends SingleEMFTestCase {
|
||||||
|
|
||||||
public void testCorrelatedSubquerySpecialCase1() {
|
public void testCorrelatedSubquerySpecialCase1() {
|
||||||
DomainObject o = qb.createQueryDefinition(Order.class);
|
DomainObject o = qb.createQueryDefinition(Order.class);
|
||||||
DomainObject a = qb.createSubqueryDefinition(o.get("customer").get("accounts"));
|
DomainObject a = qb.createSubqueryDefinition(o.get("customer").
|
||||||
|
get("accounts"));
|
||||||
o.select(o)
|
o.select(o)
|
||||||
.where(o.literal(10000).lessThan(a.select(a.get("balance")).all()));
|
.where(o.literal(10000).lessThan(a.select(a.get("balance")).all()));
|
||||||
|
|
||||||
String jpql = "select o from Order o"
|
String jpql =
|
||||||
+ " where 10000 < ALL "
|
"select o from Order o" + " where 10000 < ALL "
|
||||||
+ " (select a.balance from o.customer c join o.customer.accounts a)";
|
+ " (select a.balance from o.customer c "
|
||||||
|
+ "join o.customer.accounts a)";
|
||||||
|
|
||||||
compare(jpql, o);
|
compare(jpql, o);
|
||||||
}
|
}
|
||||||
|
|
|
@ -153,8 +153,9 @@ public class TestMetaModelTypesafeCriteria extends CriteriaTest {
|
||||||
|
|
||||||
@AllowFailure
|
@AllowFailure
|
||||||
public void testFetchJoins() {
|
public void testFetchJoins() {
|
||||||
String jpql = "SELECT d FROM Department LEFT JOIN FETCH d.employees " +
|
String jpql =
|
||||||
"WHERE d.deptNo = 1";
|
"SELECT d FROM Department LEFT JOIN FETCH d.employees "
|
||||||
|
+ "WHERE d.deptNo = 1";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
Root<Department> d = q.from(Department.class);
|
Root<Department> d = q.from(Department.class);
|
||||||
d.fetch(department_.getSet("employees", Employee.class), JoinType.LEFT);
|
d.fetch(department_.getSet("employees", Employee.class), JoinType.LEFT);
|
||||||
|
@ -174,10 +175,10 @@ public class TestMetaModelTypesafeCriteria extends CriteriaTest {
|
||||||
Join<Contact, Phone> phone = emp.join(
|
Join<Contact, Phone> phone = emp.join(
|
||||||
employee_.getAttribute("contactInfo", Contact.class)).
|
employee_.getAttribute("contactInfo", Contact.class)).
|
||||||
join(contact_.getList("phones", Phone.class));
|
join(contact_.getList("phones", Phone.class));
|
||||||
q.where(cb.equal(emp.get(employee_.getAttribute("contactInfo",
|
q.where(cb.equal(emp.get(
|
||||||
Contact.class)).
|
employee_.getAttribute("contactInfo", Contact.class)).get(
|
||||||
get(contact_.getAttribute("address", Address.class)).
|
contact_.getAttribute("address", Address.class)).get(
|
||||||
get(address_.getAttribute("zipCode", String.class)), "95054"));
|
address_.getAttribute("zipCode", String.class)), "95054"));
|
||||||
q.select(phone.get(phone_.getAttribute("vendor", String.class)));
|
q.select(phone.get(phone_.getAttribute("vendor", String.class)));
|
||||||
|
|
||||||
assertEquivalence(q, jpql);
|
assertEquivalence(q, jpql);
|
||||||
|
@ -348,9 +349,10 @@ public class TestMetaModelTypesafeCriteria extends CriteriaTest {
|
||||||
|
|
||||||
@AllowFailure
|
@AllowFailure
|
||||||
public void testSelectList() {
|
public void testSelectList() {
|
||||||
String jpql = "SELECT v.location.street, KEY(i).title, VALUE(i) FROM " +
|
String jpql =
|
||||||
"VideoStore v JOIN v.videoInventory i WHERE v.location.zipCode = " +
|
"SELECT v.location.street, KEY(i).title, VALUE(i) FROM "
|
||||||
"'94301' AND VALUE(i) > 0";
|
+ "VideoStore v JOIN v.videoInventory i "
|
||||||
|
+ "WHERE v.location.zipCode = " + "'94301' AND VALUE(i) > 0";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
Root<VideoStore> v = q.from(VideoStore.class);
|
Root<VideoStore> v = q.from(VideoStore.class);
|
||||||
MapJoin<VideoStore, Movie, Integer> inv = v.join(videoStore_.getMap(
|
MapJoin<VideoStore, Movie, Integer> inv = v.join(videoStore_.getMap(
|
||||||
|
@ -370,7 +372,8 @@ public class TestMetaModelTypesafeCriteria extends CriteriaTest {
|
||||||
"Customer c JOIN c.orders o WHERE o.quantity > 100";
|
"Customer c JOIN c.orders o WHERE o.quantity > 100";
|
||||||
q = cb.create();
|
q = cb.create();
|
||||||
Root<Customer> c = q.from(Customer.class);
|
Root<Customer> c = q.from(Customer.class);
|
||||||
Join<Customer, Order> o = c.join(customer_.getSet("orders", Order.class));
|
Join<Customer, Order> o =
|
||||||
|
c.join(customer_.getSet("orders", Order.class));
|
||||||
q.where(cb.gt(o.get(order_.getAttribute("quantity", Integer.class)),
|
q.where(cb.gt(o.get(order_.getAttribute("quantity", Integer.class)),
|
||||||
100));
|
100));
|
||||||
q.select(cb.select(CustomerDetails.class,
|
q.select(cb.select(CustomerDetails.class,
|
||||||
|
@ -413,8 +416,10 @@ public class TestMetaModelTypesafeCriteria extends CriteriaTest {
|
||||||
|
|
||||||
assertEquivalence(q, jpql);
|
assertEquivalence(q, jpql);
|
||||||
|
|
||||||
jpql = "SELECT emp FROM Employee emp WHERE emp.salary > ALL (" +
|
jpql =
|
||||||
"SELECT m.salary FROM Manager m WHERE m.department = emp.department)";
|
"SELECT emp FROM Employee emp WHERE emp.salary > ALL ("
|
||||||
|
+ "SELECT m.salary FROM Manager m WHERE m.department ="
|
||||||
|
+ " emp.department)";
|
||||||
q = cb.create();
|
q = cb.create();
|
||||||
Root<Employee> emp1 = q.from(Employee.class);
|
Root<Employee> emp1 = q.from(Employee.class);
|
||||||
q.select(emp1);
|
q.select(emp1);
|
||||||
|
|
|
@ -297,7 +297,8 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
Root<CompUser> c = q.from(CompUser.class);
|
Root<CompUser> c = q.from(CompUser.class);
|
||||||
Parameter<String> param = cb.parameter(String.class);
|
Parameter<String> param = cb.parameter(String.class);
|
||||||
q.where(cb.equal(c.get(CompUser_.address).get(Address_.country), null));
|
q.where(cb.equal(c.get(CompUser_.address).get(Address_.country),
|
||||||
|
null));
|
||||||
q.select(c.get(CompUser_.name));
|
q.select(c.get(CompUser_.name));
|
||||||
assertEquivalence(q, query);
|
assertEquivalence(q, query);
|
||||||
List result = em.createQuery(q).getResultList();
|
List result = em.createQuery(q).getResultList();
|
||||||
|
@ -534,7 +535,8 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
|
|
||||||
@AllowFailure
|
@AllowFailure
|
||||||
public void testTrimFunc1() {
|
public void testTrimFunc1() {
|
||||||
String query = "select Trim(e.computerName) From CompUser e WHERE e.name='Shannon '";
|
String query = "select Trim(e.computerName) From CompUser e " +
|
||||||
|
"WHERE e.name='Shannon '";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
q = cb.create();
|
q = cb.create();
|
||||||
Root<CompUser> e = q.from(CompUser.class);
|
Root<CompUser> e = q.from(CompUser.class);
|
||||||
|
@ -572,7 +574,8 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
|
|
||||||
@AllowFailure
|
@AllowFailure
|
||||||
public void testLowerFunc2() {
|
public void testLowerFunc2() {
|
||||||
String query = "select e.age From CompUser e where LOWER(e.name) ='ugo'";
|
String query = "select e.age From CompUser e where LOWER(e.name)" +
|
||||||
|
" ='ugo'";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
q = cb.create();
|
q = cb.create();
|
||||||
Root<CompUser> e = q.from(CompUser.class);
|
Root<CompUser> e = q.from(CompUser.class);
|
||||||
|
@ -815,7 +818,8 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
// can not do TYPE with parameter in the IN clause
|
// can not do TYPE with parameter in the IN clause
|
||||||
@AllowFailure
|
@AllowFailure
|
||||||
public void testTypeExpression1() {
|
public void testTypeExpression1() {
|
||||||
String query = "SELECT e FROM CompUser e where TYPE(e) in (?1, ?2) ORDER By e.name";
|
String query = "SELECT e FROM CompUser e where TYPE(e) in (?1, ?2) " +
|
||||||
|
"ORDER By e.name";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
q = cb.create();
|
q = cb.create();
|
||||||
Root<CompUser> e = q.from(CompUser.class);
|
Root<CompUser> e = q.from(CompUser.class);
|
||||||
|
@ -883,7 +887,8 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
|
|
||||||
@AllowFailure
|
@AllowFailure
|
||||||
public void testTypeExpression6() {
|
public void testTypeExpression6() {
|
||||||
String query = "SELECT e FROM CompUser e where TYPE(e) not in (MaleUser, FemaleUser)";
|
String query = "SELECT e FROM CompUser e where TYPE(e) not in " +
|
||||||
|
"(MaleUser, FemaleUser)";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
q = cb.create();
|
q = cb.create();
|
||||||
Root<CompUser> e = q.from(CompUser.class);
|
Root<CompUser> e = q.from(CompUser.class);
|
||||||
|
@ -1115,11 +1120,14 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
public void testGeneralCaseExpression3() {
|
public void testGeneralCaseExpression3() {
|
||||||
String query = " select e.name, "
|
String query = " select e.name, "
|
||||||
+ "CASE WHEN e.age = 11 THEN "
|
+ "CASE WHEN e.age = 11 THEN "
|
||||||
+ "org.apache.openjpa.persistence.criteria.CompUser$CreditRating.POOR"
|
+ "org.apache.openjpa.persistence.criteria.CompUser$" +
|
||||||
|
"CreditRating.POOR"
|
||||||
+ " WHEN e.age = 35 THEN "
|
+ " WHEN e.age = 35 THEN "
|
||||||
+ "org.apache.openjpa.persistence.criteria.CompUser$CreditRating.GOOD"
|
+ "org.apache.openjpa.persistence.criteria.CompUser$" +
|
||||||
|
"CreditRating.GOOD"
|
||||||
+ " ELSE "
|
+ " ELSE "
|
||||||
+ "org.apache.openjpa.persistence.criteria.CompUser$CreditRating.EXCELLENT"
|
+ "org.apache.openjpa.persistence.criteria.CompUser$" +
|
||||||
|
"CreditRating.EXCELLENT"
|
||||||
+ " END FROM CompUser e ORDER BY e.age";
|
+ " END FROM CompUser e ORDER BY e.age";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
Root<CompUser> e = q.from(CompUser.class);
|
Root<CompUser> e = q.from(CompUser.class);
|
||||||
|
@ -1145,11 +1153,14 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
+ "where e.creditRating = "
|
+ "where e.creditRating = "
|
||||||
+ "(select "
|
+ "(select "
|
||||||
+ "CASE WHEN e1.age = 11 THEN "
|
+ "CASE WHEN e1.age = 11 THEN "
|
||||||
+ "org.apache.openjpa.persistence.criteria.CompUser$CreditRating.POOR"
|
+ "org.apache.openjpa.persistence.criteria.CompUser$" +
|
||||||
|
"CreditRating.POOR"
|
||||||
+ " WHEN e1.age = 35 THEN "
|
+ " WHEN e1.age = 35 THEN "
|
||||||
+ "org.apache.openjpa.persistence.criteria.CompUser$CreditRating.GOOD"
|
+ "org.apache.openjpa.persistence.criteria.CompUser$" +
|
||||||
|
"CreditRating.GOOD"
|
||||||
+ " ELSE "
|
+ " ELSE "
|
||||||
+ "org.apache.openjpa.persistence.criteria.CompUser$CreditRating.EXCELLENT"
|
+ "org.apache.openjpa.persistence.criteria.CompUser$" +
|
||||||
|
"CreditRating.EXCELLENT"
|
||||||
+ " END from CompUser e1"
|
+ " END from CompUser e1"
|
||||||
+ " where e.userid = e1.userid) ORDER BY e.age";
|
+ " where e.userid = e1.userid) ORDER BY e.age";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
|
@ -1340,7 +1351,8 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
@AllowFailure
|
@AllowFailure
|
||||||
public void testSubquery10() {
|
public void testSubquery10() {
|
||||||
String query = "select o.id from Order o where o.quantity >"
|
String query = "select o.id from Order o where o.quantity >"
|
||||||
+ " (select sum(o2.quantity) from Customer c, in(c.orders) o2) ";
|
+ " (select sum(o2.quantity) from Customer c, "
|
||||||
|
+ "in(c.orders) o2) ";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
Root<Order> o = q.from(Order.class);
|
Root<Order> o = q.from(Order.class);
|
||||||
q.select(o.get(Order_.id));
|
q.select(o.get(Order_.id));
|
||||||
|
@ -1358,7 +1370,8 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
public void testSubquery11() {
|
public void testSubquery11() {
|
||||||
String query = "select o.id from Order o where o.quantity between"
|
String query = "select o.id from Order o where o.quantity between"
|
||||||
+ " (select avg(o2.quantity) from Customer c, in(c.orders) o2)"
|
+ " (select avg(o2.quantity) from Customer c, in(c.orders) o2)"
|
||||||
+ " and (select min(o2.quantity) from Customer c, in(c.orders) o2)";
|
+ " and (select min(o2.quantity) from Customer c, in(c.orders)"
|
||||||
|
+ " o2)";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
Root<Order> o = q.from(Order.class);
|
Root<Order> o = q.from(Order.class);
|
||||||
q.select(o.get(Order_.id));
|
q.select(o.get(Order_.id));
|
||||||
|
@ -1380,8 +1393,10 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
|
|
||||||
@AllowFailure
|
@AllowFailure
|
||||||
public void testSubquery12() {
|
public void testSubquery12() {
|
||||||
String query = "select o.id from Customer c, in(c.orders)o "
|
String query =
|
||||||
+ "where o.quantity > (select sum(o2.quantity) from c.orders o2)";
|
"select o.id from Customer c, in(c.orders)o "
|
||||||
|
+ "where o.quantity > (select sum(o2.quantity)"
|
||||||
|
+ " from c.orders o2)";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
Root<Customer> c = q.from(Customer.class);
|
Root<Customer> c = q.from(Customer.class);
|
||||||
SetJoin<Customer, Order> o = c.join(Customer_.orders);
|
SetJoin<Customer, Order> o = c.join(Customer_.orders);
|
||||||
|
@ -1431,7 +1446,8 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
|
|
||||||
Subquery<Integer> sq = q.subquery(Integer.class);
|
Subquery<Integer> sq = q.subquery(Integer.class);
|
||||||
Root<Magazine> m2 = sq.from(Magazine.class);
|
Root<Magazine> m2 = sq.from(Magazine.class);
|
||||||
q.where(cb.equal(m.get(Magazine_.id), sq.select(cb.max(m2.get(Magazine_.id)))));
|
q.where(cb.equal(m.get(Magazine_.id), sq.select(cb.max(m2
|
||||||
|
.get(Magazine_.id)))));
|
||||||
|
|
||||||
Subquery<Integer> sq2 = q.subquery(Integer.class);
|
Subquery<Integer> sq2 = q.subquery(Integer.class);
|
||||||
Root<Magazine> m3 = sq2.from(Magazine.class);
|
Root<Magazine> m3 = sq2.from(Magazine.class);
|
||||||
|
@ -1439,18 +1455,17 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
sq2.where(cb.equal(m3.get(Magazine_.idPublisher).get(Publisher_.id),
|
sq2.where(cb.equal(m3.get(Magazine_.idPublisher).get(Publisher_.id),
|
||||||
p.get(Publisher_.id)));
|
p.get(Publisher_.id)));
|
||||||
|
|
||||||
sq.where(
|
sq.where(cb.and(cb.equal(m2.get(Magazine_.idPublisher).get(
|
||||||
cb.and(
|
Publisher_.id), p.get(Publisher_.id)), cb.equal(m2
|
||||||
cb.equal(m2.get(Magazine_.idPublisher).get(Publisher_.id), p.get(Publisher_.id)),
|
.get(Magazine_.datePublished), sq2.select(cb.max(m3
|
||||||
cb.equal(m2.get(Magazine_.datePublished), sq2.select(cb.max(m3.get(Magazine_.id))))
|
.get(Magazine_.id))))));
|
||||||
)
|
|
||||||
);
|
|
||||||
assertEquivalence(q, query);
|
assertEquivalence(q, query);
|
||||||
}
|
}
|
||||||
|
|
||||||
// outstanding problem subqueries:
|
// outstanding problem subqueries:
|
||||||
// "select o from Order o where o.amount > (select count(o) from Order o)",
|
// "select o from Order o where o.amount > (select count(o) from Order o)",
|
||||||
// "select o from Order o where o.amount > (select count(o2) from Order o2)",
|
// "select o from Order o where o.amount > (select count(o2) from Order o2)
|
||||||
|
//",
|
||||||
// "select c from Customer c left join c.orders p where not exists"
|
// "select c from Customer c left join c.orders p where not exists"
|
||||||
// + " (select o2 from c.orders o2 where o2 = o",
|
// + " (select o2 from c.orders o2 where o2 = o",
|
||||||
|
|
||||||
|
@ -1486,7 +1501,8 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
public void testSubquery16() {
|
public void testSubquery16() {
|
||||||
String query = "select o1.oid from Order o1 where o1.quantity > "
|
String query = "select o1.oid from Order o1 where o1.quantity > "
|
||||||
+ " (select o.quantity*2 from LineItem i, Order o"
|
+ " (select o.quantity*2 from LineItem i, Order o"
|
||||||
+ " where i.quantity > 10 and o.quantity > 1000 and i.id = o.id)";
|
+ " where i.quantity > 10 and o.quantity > 1000 and i.id = " +
|
||||||
|
"o.id)";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
Root<Order> o1 = q.from(Order.class);
|
Root<Order> o1 = q.from(Order.class);
|
||||||
q.select(o1.get(Order_.id));
|
q.select(o1.get(Order_.id));
|
||||||
|
@ -1546,7 +1562,8 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
@AllowFailure
|
@AllowFailure
|
||||||
public void testSubquery19() {
|
public void testSubquery19() {
|
||||||
String query = "select o.id from Order o where o.quantity >"
|
String query = "select o.id from Order o where o.quantity >"
|
||||||
+ " (select SQRT(o.quantity) from Order o where o.delivered = true)";
|
+ " (select SQRT(o.quantity) from Order o where o.delivered" +
|
||||||
|
" = true)";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
Root<Order> o = q.from(Order.class);
|
Root<Order> o = q.from(Order.class);
|
||||||
q.select(o.get(Order_.id));
|
q.select(o.get(Order_.id));
|
||||||
|
@ -1584,11 +1601,14 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
String query = "select c from Customer c where c.creditRating ="
|
String query = "select c from Customer c where c.creditRating ="
|
||||||
+ " (select "
|
+ " (select "
|
||||||
+ " CASE WHEN o2.quantity > 10 THEN "
|
+ " CASE WHEN o2.quantity > 10 THEN "
|
||||||
+ "org.apache.openjpa.persistence.criteria.Customer$CreditRating.POOR"
|
+ "org.apache.openjpa.persistence.criteria.Customer$" +
|
||||||
|
"CreditRating.POOR"
|
||||||
+ " WHEN o2.quantity = 10 THEN "
|
+ " WHEN o2.quantity = 10 THEN "
|
||||||
+ "org.apache.openjpa.persistence.criteria.Customer$CreditRating.GOOD "
|
+ "org.apache.openjpa.persistence.criteria.Customer$" +
|
||||||
|
"CreditRating.GOOD "
|
||||||
+ " ELSE "
|
+ " ELSE "
|
||||||
+ "org.apache.openjpa.persistence.criteria.Customer$CreditRating.EXCELLENT "
|
+ "org.apache.openjpa.persistence.criteria.Customer$" +
|
||||||
|
"CreditRating.EXCELLENT "
|
||||||
+ " END from Order o2"
|
+ " END from Order o2"
|
||||||
+ " where c.id = o2.customer.id)";
|
+ " where c.id = o2.customer.id)";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
|
@ -1597,14 +1617,16 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
|
|
||||||
Subquery<String> sq = q.subquery(String.class);
|
Subquery<String> sq = q.subquery(String.class);
|
||||||
Root<Order> o2 = sq.from(Order.class);
|
Root<Order> o2 = sq.from(Order.class);
|
||||||
sq.where(cb.equal(c.get(Customer_.id), o2.get(Order_.customer).get(Customer_.id)));
|
sq.where(cb.equal(c.get(Customer_.id), o2.get(Order_.customer).get(
|
||||||
|
Customer_.id)));
|
||||||
|
|
||||||
q.where(cb.equal(c.get(Customer_.creditRating),
|
q.where(cb.equal(c.get(Customer_.creditRating),
|
||||||
//sq.select(
|
//sq.select(
|
||||||
cb.selectCase()
|
cb.selectCase().when(cb.gt(o2.get(Order_.quantity), 10),
|
||||||
.when(cb.gt(o2.get(Order_.quantity), 10), Customer.CreditRating.POOR)
|
Customer.CreditRating.POOR).when(
|
||||||
.when(cb.equal(o2.get(Order_.quantity), 10), Customer.CreditRating.GOOD)
|
cb.equal(o2.get(Order_.quantity), 10),
|
||||||
.otherwise(Customer.CreditRating.EXCELLENT)
|
Customer.CreditRating.GOOD).otherwise(
|
||||||
|
Customer.CreditRating.EXCELLENT)
|
||||||
// )
|
// )
|
||||||
));
|
));
|
||||||
assertEquivalence(q, query);
|
assertEquivalence(q, query);
|
||||||
|
@ -1615,14 +1637,17 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
public void testSubquery22() {
|
public void testSubquery22() {
|
||||||
String query = "select c from Customer c "
|
String query = "select c from Customer c "
|
||||||
+ "where c.creditRating = (select COALESCE (c1.creditRating, "
|
+ "where c.creditRating = (select COALESCE (c1.creditRating, "
|
||||||
+ "org.apache.openjpa.persistence.criteria.Customer$CreditRating.POOR) "
|
+ "org.apache.openjpa.persistence.criteria.Customer$" +
|
||||||
+ "from Customer c1 where c1.name = 'Famzy') order by c.name DESC";
|
"CreditRating.POOR) "
|
||||||
|
+ "from Customer c1 where c1.name = 'Famzy') order by c.name " +
|
||||||
|
"DESC";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
Root<Customer> c = q.from(Customer.class);
|
Root<Customer> c = q.from(Customer.class);
|
||||||
q.select(c);
|
q.select(c);
|
||||||
q.orderBy(cb.desc(c.get(Customer_.name)));
|
q.orderBy(cb.desc(c.get(Customer_.name)));
|
||||||
|
|
||||||
Subquery<Customer.CreditRating> sq = q.subquery(Customer.CreditRating.class);
|
Subquery<Customer.CreditRating> sq =
|
||||||
|
q.subquery(Customer.CreditRating.class);
|
||||||
Root<Customer> c1 = sq.from(Customer.class);
|
Root<Customer> c1 = sq.from(Customer.class);
|
||||||
sq.where(cb.equal(c1.get(Customer_.name), "Famzy"));
|
sq.where(cb.equal(c1.get(Customer_.name), "Famzy"));
|
||||||
|
|
||||||
|
@ -1634,16 +1659,20 @@ public class TestTypeSafeCondExpression extends CriteriaTest {
|
||||||
|
|
||||||
@AllowFailure
|
@AllowFailure
|
||||||
public void testSubquery23() {
|
public void testSubquery23() {
|
||||||
String query = "select c from Customer c "
|
String query =
|
||||||
|
"select c from Customer c "
|
||||||
+ "where c.creditRating = (select NULLIF (c1.creditRating, "
|
+ "where c.creditRating = (select NULLIF (c1.creditRating, "
|
||||||
+ "org.apache.openjpa.persistence.criteria.Customer$CreditRating.POOR) "
|
+ "org.apache.openjpa.persistence.criteria."
|
||||||
+ "from Customer c1 where c1.name = 'Famzy') order by c.name DESC";
|
+ "Customer$CreditRating.POOR) "
|
||||||
|
+ "from Customer c1 where c1.name = 'Famzy') "
|
||||||
|
+ "order by c.name DESC";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
Root<Customer> c = q.from(Customer.class);
|
Root<Customer> c = q.from(Customer.class);
|
||||||
q.select(c);
|
q.select(c);
|
||||||
q.orderBy(cb.desc(c.get(Customer_.name)));
|
q.orderBy(cb.desc(c.get(Customer_.name)));
|
||||||
|
|
||||||
Subquery<Customer.CreditRating> sq = q.subquery(Customer.CreditRating.class);
|
Subquery<Customer.CreditRating> sq =
|
||||||
|
q.subquery(Customer.CreditRating.class);
|
||||||
Root<Customer> c1 = sq.from(Customer.class);
|
Root<Customer> c1 = sq.from(Customer.class);
|
||||||
sq.where(cb.equal(c1.get(Customer_.name), "Famzy"));
|
sq.where(cb.equal(c1.get(Customer_.name), "Famzy"));
|
||||||
|
|
||||||
|
|
|
@ -121,7 +121,8 @@ public class TestTypesafeCriteria extends CriteriaTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testInPredicateWithPath() {
|
public void testInPredicateWithPath() {
|
||||||
String jpql = "select a from Account a where a.owner.name in ('X','Y','Z')";
|
String jpql =
|
||||||
|
"select a from Account a where a.owner.name in ('X','Y','Z')";
|
||||||
CriteriaQuery c = cb.create();
|
CriteriaQuery c = cb.create();
|
||||||
Root<Account> account = c.from(Account.class);
|
Root<Account> account = c.from(Account.class);
|
||||||
c.where(cb.in(account.get(Account_.owner).get(Person_.name)).value("X")
|
c.where(cb.in(account.get(Account_.owner).get(Person_.name)).value("X")
|
||||||
|
@ -130,7 +131,8 @@ public class TestTypesafeCriteria extends CriteriaTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testBinaryPredicate() {
|
public void testBinaryPredicate() {
|
||||||
String jpql = "select a from Account a where a.balance>100 and a.balance<200";
|
String jpql =
|
||||||
|
"select a from Account a where a.balance>100 and a.balance<200";
|
||||||
|
|
||||||
CriteriaQuery c = cb.create();
|
CriteriaQuery c = cb.create();
|
||||||
Root<Account> account = c.from(Account.class);
|
Root<Account> account = c.from(Account.class);
|
||||||
|
@ -154,7 +156,8 @@ public class TestTypesafeCriteria extends CriteriaTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testBetweenExpression() {
|
public void testBetweenExpression() {
|
||||||
String jpql = "select a from Account a where a.balance between 100 and 200";
|
String jpql =
|
||||||
|
"select a from Account a where a.balance between 100 and 200";
|
||||||
|
|
||||||
CriteriaQuery c = cb.create();
|
CriteriaQuery c = cb.create();
|
||||||
Root<Account> account = c.from(Account.class);
|
Root<Account> account = c.from(Account.class);
|
||||||
|
@ -238,7 +241,8 @@ public class TestTypesafeCriteria extends CriteriaTest {
|
||||||
|
|
||||||
@AllowFailure(message = "Key expression not implemented")
|
@AllowFailure(message = "Key expression not implemented")
|
||||||
public void testKeyExpression() {
|
public void testKeyExpression() {
|
||||||
String jpql = "SELECT i.name, p FROM Item i JOIN i.photos p WHERE KEY(p) "
|
String jpql =
|
||||||
|
"SELECT i.name, p FROM Item i JOIN i.photos p WHERE KEY(p) "
|
||||||
+ "LIKE '%egret%'";
|
+ "LIKE '%egret%'";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
Root<Item> item = q.from(Item.class);
|
Root<Item> item = q.from(Item.class);
|
||||||
|
@ -274,60 +278,61 @@ public class TestTypesafeCriteria extends CriteriaTest {
|
||||||
assertEquivalence(q, jpql);
|
assertEquivalence(q, jpql);
|
||||||
}
|
}
|
||||||
|
|
||||||
@AllowFailure(message = "broken")
|
// @AllowFailure(message = "broken")
|
||||||
public void testExpressionInProjection() {
|
// public void testExpressionInProjection() {
|
||||||
String jpql = "SELECT o.quantity, o.totalCost*1.08 AS taxedCost, "
|
// String jpql = "SELECT o.quantity, o.totalCost*1.08 AS taxedCost, "
|
||||||
+ "a.zipCode FROM Customer c JOIN c.orders o JOIN c.address a "
|
// + "a.zipCode FROM Customer c JOIN c.orders o JOIN c.address a"
|
||||||
+ "WHERE a.state = 'CA' AND a.county = 'Santa Clara'";
|
// + "WHERE a.state = 'CA' AND a.county = 'Santa Clara'";
|
||||||
CriteriaQuery q = cb.create();
|
// CriteriaQuery q = cb.create();
|
||||||
Root<Customer> cust = q.from(Customer.class);
|
// Root<Customer> cust = q.from(Customer.class);
|
||||||
Join<Customer, Order> order = cust.join(Customer_.orders);
|
// Join<Customer, Order> order = cust.join(Customer_.orders);
|
||||||
Join<Customer, Address> address = cust.join(Customer_.address);
|
// Join<Customer, Address> address = cust.join(Customer_.address);
|
||||||
q.where(cb.equal(address.get(Address_.state), "CA"), cb.equal(address
|
// q.where(cb.equal(address.get(Address_.state), "CA"), cb.equal(address
|
||||||
.get(Address_.county), "Santa Clara"));
|
// .get(Address_.county), "Santa Clara"));
|
||||||
q.select(order.get(Order_.quantity), cb.prod(order
|
// q.select(order.get(Order_.quantity), cb.prod(order
|
||||||
.get(Order_.totalCost), 1.08), address.get(Address_.zipCode));
|
// .get(Order_.totalCost), 1.08), address.get(Address_.zipCode));
|
||||||
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
|
// }
|
||||||
|
|
||||||
assertEquivalence(q, jpql);
|
// @AllowFailure(message =
|
||||||
}
|
// "Type expression was working with Fay. Now refactored and broken")
|
||||||
|
// public void testTypeExpression() {
|
||||||
|
// String jpql = "SELECT TYPE(e) FROM Employee e WHERE TYPE(e) <> Exempt";
|
||||||
|
// CriteriaQuery q = cb.create();
|
||||||
|
// Root<Employee> emp = q.from(Employee.class);
|
||||||
|
// q.select(emp.type()).where(cb.notEqual(emp.type(), Exempt.class));
|
||||||
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
|
// }
|
||||||
|
|
||||||
@AllowFailure(message = "Type expression was working with Fay. Now refactored and broken")
|
// @AllowFailure(message = "Index expression not implemented")
|
||||||
public void testTypeExpression() {
|
// public void testIndexExpressionAndLietral() {
|
||||||
String jpql = "SELECT TYPE(e) FROM Employee e WHERE TYPE(e) <> Exempt";
|
// String jpql = "SELECT w.name FROM Course c JOIN c.studentWaitList w "
|
||||||
CriteriaQuery q = cb.create();
|
// + "WHERE c.name = 'Calculus' AND INDEX(w) = 0";
|
||||||
Root<Employee> emp = q.from(Employee.class);
|
// CriteriaQuery q = cb.create();
|
||||||
q.select(emp.type()).where(cb.notEqual(emp.type(), Exempt.class));
|
// Root<Course> course = q.from(Course.class);
|
||||||
|
// ListJoin<Course, Student> w = course.join(Course_.studentWaitList);
|
||||||
|
// q.where(cb.equal(course.get(Course_.name), "Calculus"),
|
||||||
|
// cb.equal(w.index(), 0)).select(w.get(Student_.name));
|
||||||
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
|
// }
|
||||||
|
|
||||||
assertEquivalence(q, jpql);
|
// @AllowFailure(message = "SQL for Criteria has extra join")
|
||||||
}
|
// public void testAggregateInProjection() {
|
||||||
|
// String jpql = "SELECT SUM(i.price) FROM Order o JOIN o.lineItems i JOIN "
|
||||||
@AllowFailure(message = "Index expression not implemented")
|
// + "o.customer c WHERE c.lastName = 'Smith' AND c.firstName = 'John'";
|
||||||
public void testIndexExpressionAndLietral() {
|
// CriteriaQuery q = cb.create();
|
||||||
String jpql = "SELECT w.name FROM Course c JOIN c.studentWaitList w "
|
// Root<Order> o = q.from(Order.class);
|
||||||
+ "WHERE c.name = 'Calculus' AND INDEX(w) = 0";
|
// Join<Order, LineItem> i = o.join(Order_.lineItems);
|
||||||
CriteriaQuery q = cb.create();
|
// Join<Order, Customer> c = o.join(Order_.customer);
|
||||||
Root<Course> course = q.from(Course.class);
|
// q.where(cb.equal(c.get(Customer_.lastName), "Smith"), cb.equal(c
|
||||||
ListJoin<Course, Student> w = course.join(Course_.studentWaitList);
|
// .get(Customer_.firstName), "John"));
|
||||||
q.where(cb.equal(course.get(Course_.name), "Calculus"),
|
// q.select(cb.sum(i.get(LineItem_.price)));
|
||||||
cb.equal(w.index(), 0)).select(w.get(Student_.name));
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
assertEquivalence(q, jpql);
|
// }
|
||||||
}
|
|
||||||
|
|
||||||
@AllowFailure(message = "SQL for Criteria has extra join")
|
|
||||||
public void testAggregateInProjection() {
|
|
||||||
String jpql = "SELECT SUM(i.price) FROM Order o JOIN o.lineItems i JOIN "
|
|
||||||
+ "o.customer c WHERE c.lastName = 'Smith' AND c.firstName = 'John'";
|
|
||||||
CriteriaQuery q = cb.create();
|
|
||||||
Root<Order> o = q.from(Order.class);
|
|
||||||
Join<Order, LineItem> i = o.join(Order_.lineItems);
|
|
||||||
Join<Order, Customer> c = o.join(Order_.customer);
|
|
||||||
q.where(cb.equal(c.get(Customer_.lastName), "Smith"), cb.equal(c
|
|
||||||
.get(Customer_.firstName), "John"));
|
|
||||||
q.select(cb.sum(i.get(LineItem_.price)));
|
|
||||||
|
|
||||||
assertEquivalence(q, jpql);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testSizeExpression() {
|
public void testSizeExpression() {
|
||||||
String jpql = "SELECT SIZE(d.employees) FROM Department d "
|
String jpql = "SELECT SIZE(d.employees) FROM Department d "
|
||||||
|
@ -341,8 +346,10 @@ public class TestTypesafeCriteria extends CriteriaTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testCaseExpression() {
|
public void testCaseExpression() {
|
||||||
String jpql = "SELECT e.name, CASE WHEN e.rating = 1 THEN e.salary * 1.1 "
|
String jpql =
|
||||||
+ "WHEN e.rating = 2 THEN e.salary * 1.2 ELSE e.salary * 1.01 END "
|
"SELECT e.name, CASE WHEN e.rating = 1 THEN e.salary * 1.1 "
|
||||||
|
+ "WHEN e.rating = 2 THEN e.salary * 1.2 ELSE e.salary * "
|
||||||
|
+ "1.01 END "
|
||||||
+ "FROM Employee e WHERE e.department.name = 'Engineering'";
|
+ "FROM Employee e WHERE e.department.name = 'Engineering'";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
Root<Employee> e = q.from(Employee.class);
|
Root<Employee> e = q.from(Employee.class);
|
||||||
|
@ -358,60 +365,60 @@ public class TestTypesafeCriteria extends CriteriaTest {
|
||||||
assertEquivalence(q, jpql);
|
assertEquivalence(q, jpql);
|
||||||
}
|
}
|
||||||
|
|
||||||
@AllowFailure(message = "Extra Joins created")
|
// @AllowFailure(message = "Extra Joins created")
|
||||||
public void testExpression1() {
|
// public void testExpression1() {
|
||||||
String jpql = "SELECT o.quantity, o.totalCost*1.08 AS taxedCost, "
|
// String jpql = "SELECT o.quantity, o.totalCost*1.08 AS taxedCost, "
|
||||||
+ "a.zipCode FROM Customer c JOIN c.orders o JOIN c.address a "
|
// + "a.zipCode FROM Customer c JOIN c.orders o JOIN c.address a "
|
||||||
+ "WHERE a.state = 'CA' AND a.county = 'Santa Clara'";
|
// + "WHERE a.state = 'CA' AND a.county = 'Santa Clara'";
|
||||||
CriteriaQuery q = cb.create();
|
// CriteriaQuery q = cb.create();
|
||||||
Root<Customer> cust = q.from(Customer.class);
|
// Root<Customer> cust = q.from(Customer.class);
|
||||||
Join<Customer, Order> order = cust.join(Customer_.orders);
|
// Join<Customer, Order> order = cust.join(Customer_.orders);
|
||||||
Join<Customer, Address> address = cust.join(Customer_.address);
|
// Join<Customer, Address> address = cust.join(Customer_.address);
|
||||||
q.where(cb.equal(address.get(Address_.state), "CA"), cb.equal(address
|
// q.where(cb.equal(address.get(Address_.state), "CA"), cb.equal(address
|
||||||
.get(Address_.county), "Santa Clara"));
|
// .get(Address_.county), "Santa Clara"));
|
||||||
q.select(order.get(Order_.quantity), cb.prod(order
|
// q.select(order.get(Order_.quantity), cb.prod(order
|
||||||
.get(Order_.totalCost), 1.08), address.get(Address_.zipCode));
|
// .get(Order_.totalCost), 1.08), address.get(Address_.zipCode));
|
||||||
|
//
|
||||||
assertEquivalence(q, jpql);
|
// assertEquivalence(q, jpql);
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
@AllowFailure(message = "Type expression in projection not implemented")
|
// @AllowFailure(message = "Type expression in projection not implemented")
|
||||||
public void testExpression2() {
|
// public void testExpression2() {
|
||||||
String jpql = "SELECT TYPE(e) FROM Employee e WHERE TYPE(e) <> Exempt";
|
// String jpql = "SELECT TYPE(e) FROM Employee e WHERE TYPE(e) <> Exempt";
|
||||||
CriteriaQuery q = cb.create();
|
// CriteriaQuery q = cb.create();
|
||||||
Root<Employee> emp = q.from(Employee.class);
|
// Root<Employee> emp = q.from(Employee.class);
|
||||||
q.select(emp.type()).where(cb.notEqual(emp.type(), Exempt.class));
|
// q.select(emp.type()).where(cb.notEqual(emp.type(), Exempt.class));
|
||||||
|
//
|
||||||
assertEquivalence(q, jpql);
|
// assertEquivalence(q, jpql);
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
@AllowFailure(message = "Index expression not implemented")
|
// @AllowFailure(message = "Index expression not implemented")
|
||||||
public void testExpression3() {
|
// public void testExpression3() {
|
||||||
String jpql = "SELECT w.name FROM Course c JOIN c.studentWaitList w "
|
// String jpql = "SELECT w.name FROM Course c JOIN c.studentWaitList w "
|
||||||
+ "WHERE c.name = 'Calculus' AND INDEX(w) = 0";
|
// + "WHERE c.name = 'Calculus' AND INDEX(w) = 0";
|
||||||
CriteriaQuery q = cb.create();
|
// CriteriaQuery q = cb.create();
|
||||||
Root<Course> course = q.from(Course.class);
|
// Root<Course> course = q.from(Course.class);
|
||||||
ListJoin<Course, Student> w = course.join(Course_.studentWaitList);
|
// ListJoin<Course, Student> w = course.join(Course_.studentWaitList);
|
||||||
q.where(cb.equal(course.get(Course_.name), "Calculus"),
|
// q.where(cb.equal(course.get(Course_.name), "Calculus"),
|
||||||
cb.equal(w.index(), 0)).select(w.get(Student_.name));
|
// cb.equal(w.index(), 0)).select(w.get(Student_.name));
|
||||||
|
//
|
||||||
assertEquivalence(q, jpql);
|
// assertEquivalence(q, jpql);
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
@AllowFailure(message = "Generates extra Join")
|
// @AllowFailure(message = "Generates extra Join")
|
||||||
public void testExpression4() {
|
// public void testExpression4() {
|
||||||
String jpql = "SELECT SUM(i.price) FROM Order o JOIN o.lineItems i JOIN "
|
// String jpql = "SELECT SUM(i.price) FROM Order o JOIN o.lineItems i JOIN "
|
||||||
+ "o.customer c WHERE c.lastName = 'Smith' AND c.firstName = 'John'";
|
// + "o.customer c WHERE c.lastName = 'Smith' AND c.firstName = 'John'";
|
||||||
CriteriaQuery q = cb.create();
|
// CriteriaQuery q = cb.create();
|
||||||
Root<Order> o = q.from(Order.class);
|
// Root<Order> o = q.from(Order.class);
|
||||||
Join<Order, LineItem> i = o.join(Order_.lineItems);
|
// Join<Order, LineItem> i = o.join(Order_.lineItems);
|
||||||
Join<Order, Customer> c = o.join(Order_.customer);
|
// Join<Order, Customer> c = o.join(Order_.customer);
|
||||||
q.where(cb.equal(c.get(Customer_.lastName), "Smith"), cb.equal(c
|
// q.where(cb.equal(c.get(Customer_.lastName), "Smith"), cb.equal(c
|
||||||
.get(Customer_.firstName), "John"));
|
// .get(Customer_.firstName), "John"));
|
||||||
q.select(cb.sum(i.get(LineItem_.price)));
|
// q.select(cb.sum(i.get(LineItem_.price)));
|
||||||
|
//
|
||||||
assertEquivalence(q, jpql);
|
// assertEquivalence(q, jpql);
|
||||||
}
|
// }
|
||||||
|
|
||||||
public void testExpression5() {
|
public void testExpression5() {
|
||||||
String jpql = "SELECT SIZE(d.employees) FROM Department d "
|
String jpql = "SELECT SIZE(d.employees) FROM Department d "
|
||||||
|
@ -427,7 +434,8 @@ public class TestTypesafeCriteria extends CriteriaTest {
|
||||||
public void testGeneralCaseExpression() {
|
public void testGeneralCaseExpression() {
|
||||||
String jpql = "SELECT e.name, CASE "
|
String jpql = "SELECT e.name, CASE "
|
||||||
+ "WHEN e.rating = 1 THEN e.salary * 1.1 "
|
+ "WHEN e.rating = 1 THEN e.salary * 1.1 "
|
||||||
+ "WHEN e.rating = 2 THEN e.salary * 1.2 ELSE e.salary * 1.01 END "
|
+ "WHEN e.rating = 2 THEN e.salary * 1.2 ELSE e.salary * "
|
||||||
|
+ "1.01 END "
|
||||||
+ "FROM Employee e WHERE e.department.name = 'Engineering'";
|
+ "FROM Employee e WHERE e.department.name = 'Engineering'";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
Root<Employee> e = q.from(Employee.class);
|
Root<Employee> e = q.from(Employee.class);
|
||||||
|
@ -519,21 +527,21 @@ public class TestTypesafeCriteria extends CriteriaTest {
|
||||||
assertEquivalence(q, jpql, new Object[] { 1 });
|
assertEquivalence(q, jpql, new Object[] { 1 });
|
||||||
}
|
}
|
||||||
|
|
||||||
@AllowFailure(message="add QuotedNumbersInQueries=true otherwise AbstractExpressionBuilder.convertTypes() compliants")
|
// @AllowFailure(message="add QuotedNumbersInQueries=true otherwise " +
|
||||||
public void testParameters4() {
|
// "AbstractExpressionBuilder.convertTypes() compliants")
|
||||||
String jpql = "SELECT c FROM Customer c Where c.status = ?1 AND "
|
// public void testParameters4() {
|
||||||
+ "c.name = ?2";
|
// String jpql = "SELECT c FROM Customer c Where c.status = ?1 AND "
|
||||||
CriteriaQuery q = cb.create();
|
// + "c.name = ?2";
|
||||||
Root<Customer> c = q.from(Customer.class);
|
// CriteriaQuery q = cb.create();
|
||||||
Parameter<Integer> param1 = cb.parameter(Integer.class);
|
// Root<Customer> c = q.from(Customer.class);
|
||||||
Parameter<Integer> param2 = cb.parameter(Integer.class);
|
// Parameter<Integer> param1 = cb.parameter(Integer.class);
|
||||||
q.select(c).where(
|
// Parameter<Integer> param2 = cb.parameter(Integer.class);
|
||||||
cb.and(cb.equal(c.get(Customer_.status), param1), cb.equal(c
|
// q.select(c).where(
|
||||||
.get(Customer_.name), param2)));
|
// cb.and(cb.equal(c.get(Customer_.status), param1), cb.equal(c
|
||||||
assertEquivalence(q, jpql, new Object[] { 1, "test" });
|
// .get(Customer_.name), param2)));
|
||||||
}
|
// assertEquivalence(q, jpql, new Object[] { 1, "test" });
|
||||||
|
// }
|
||||||
|
|
||||||
// @AllowFailure(message = "")
|
|
||||||
public void testParameters5() {
|
public void testParameters5() {
|
||||||
String jpql = "SELECT c FROM Customer c Where c.status IN (:coll)";
|
String jpql = "SELECT c FROM Customer c Where c.status IN (:coll)";
|
||||||
CriteriaQuery q = cb.create();
|
CriteriaQuery q = cb.create();
|
||||||
|
@ -548,136 +556,138 @@ public class TestTypesafeCriteria extends CriteriaTest {
|
||||||
// {vals});
|
// {vals});
|
||||||
}
|
}
|
||||||
|
|
||||||
@AllowFailure(message="Value() expression not implemented")
|
// @AllowFailure(message="Value() expression not implemented")
|
||||||
public void testSelectList1() {
|
// public void testSelectList1() {
|
||||||
String jpql = "SELECT v.location.street, KEY(i).title, VALUE(i) FROM "
|
// String jpql = "SELECT v.location.street, KEY(i).title, VALUE(i) FROM "
|
||||||
+ "VideoStore v JOIN v.videoInventory i WHERE v.location.zipCode = "
|
// + "VideoStore v JOIN v.videoInventory i WHERE v.location.zipCode = "
|
||||||
+ "'94301' AND VALUE(i) > 0";
|
// + "'94301' AND VALUE(i) > 0";
|
||||||
CriteriaQuery q = cb.create();
|
// CriteriaQuery q = cb.create();
|
||||||
Root<VideoStore> v = q.from(VideoStore.class);
|
// Root<VideoStore> v = q.from(VideoStore.class);
|
||||||
MapJoin<VideoStore, Movie, Integer> inv = v
|
// MapJoin<VideoStore, Movie, Integer> inv = v
|
||||||
.join(VideoStore_.videoInventory);
|
// .join(VideoStore_.videoInventory);
|
||||||
q.where(cb.equal(v.get(VideoStore_.location).get(Address_.zipCode),
|
// q.where(cb.equal(v.get(VideoStore_.location).get(Address_.zipCode),
|
||||||
"94301"), cb.gt(inv.value(), 0));
|
// "94301"), cb.gt(inv.value(), 0));
|
||||||
q.select(v.get(VideoStore_.location).get(Address_.street), inv.key()
|
// q.select(v.get(VideoStore_.location).get(Address_.street), inv.key()
|
||||||
.get(Movie_.title), inv.value());
|
// .get(Movie_.title), inv.value());
|
||||||
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// @AllowFailure(message="new() in projection is broken")
|
||||||
|
// public void testSelectList2() {
|
||||||
|
// String jpql =
|
||||||
|
// "SELECT NEW CustomerDetails(c.id, c.status, o.quantity) FROM "
|
||||||
|
// + "Customer c JOIN c.orders o WHERE o.quantity > 100";
|
||||||
|
// CriteriaQuery q = cb.create();
|
||||||
|
// Root<Customer> c = q.from(Customer.class);
|
||||||
|
// Join<Customer, Order> o = c.join(Customer_.orders);
|
||||||
|
// q.where(cb.gt(o.get(Order_.quantity), 100));
|
||||||
|
// q.select(cb.select(CustomerDetails.class, c.get(Customer_.id), c
|
||||||
|
// .get(Customer_.status), o.get(Order_.quantity)));
|
||||||
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
|
// }
|
||||||
|
|
||||||
assertEquivalence(q, jpql);
|
// @AllowFailure(message="Subqueries not implemented")
|
||||||
}
|
// public void testSubqueries1() {
|
||||||
|
// String jpql = "SELECT goodCustomer FROM Customer goodCustomer WHERE "
|
||||||
@AllowFailure(message="new() in projection is broken")
|
// + "goodCustomer.balanceOwed < (SELECT AVG(c.balanceOwed) "
|
||||||
public void testSelectList2() {
|
// + " FROM "
|
||||||
String jpql = "SELECT NEW CustomerDetails(c.id, c.status, o.quantity) FROM "
|
// + "Customer c)";
|
||||||
+ "Customer c JOIN c.orders o WHERE o.quantity > 100";
|
// CriteriaQuery q = cb.create();
|
||||||
CriteriaQuery q = cb.create();
|
// Root<Customer> goodCustomer = q.from(Customer.class);
|
||||||
Root<Customer> c = q.from(Customer.class);
|
// Subquery<Double> sq = q.subquery(Double.class);
|
||||||
Join<Customer, Order> o = c.join(Customer_.orders);
|
// Root<Customer> c = sq.from(Customer.class);
|
||||||
q.where(cb.gt(o.get(Order_.quantity), 100));
|
// q.where(cb.lt(goodCustomer.get(Customer_.balanceOwed), sq.select(cb
|
||||||
q.select(cb.select(CustomerDetails.class, c.get(Customer_.id), c
|
// .avg(c.get(Customer_.balanceOwed)))));
|
||||||
.get(Customer_.status), o.get(Order_.quantity)));
|
// q.select(goodCustomer);
|
||||||
|
//
|
||||||
assertEquivalence(q, jpql);
|
// assertEquivalence(q, jpql);
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
@AllowFailure(message="Subqueries not implemented")
|
// @AllowFailure(message="Subqueries not implemented")
|
||||||
public void testSubqueries1() {
|
// public void testSubqueries2() {
|
||||||
String jpql = "SELECT goodCustomer FROM Customer goodCustomer WHERE "
|
// String jpql = "SELECT DISTINCT emp FROM Employee emp WHERE EXISTS ("
|
||||||
+ "goodCustomer.balanceOwed < (SELECT AVG(c.balanceOwed) FROM "
|
// + "SELECT spouseEmp FROM Employee spouseEmp WHERE spouseEmp ="
|
||||||
+ "Customer c)";
|
// + " emp.spouse)";
|
||||||
CriteriaQuery q = cb.create();
|
// CriteriaQuery q = cb.create();
|
||||||
Root<Customer> goodCustomer = q.from(Customer.class);
|
// Root<Employee> emp = q.from(Employee.class);
|
||||||
Subquery<Double> sq = q.subquery(Double.class);
|
// Subquery<Employee> sq = q.subquery(Employee.class);
|
||||||
Root<Customer> c = sq.from(Customer.class);
|
// Root<Employee> spouseEmp = sq.from(Employee.class);
|
||||||
q.where(cb.lt(goodCustomer.get(Customer_.balanceOwed), sq.select(cb
|
// sq.select(spouseEmp);
|
||||||
.avg(c.get(Customer_.balanceOwed)))));
|
// sq.where(cb.equal(spouseEmp, emp.get(Employee_.spouse)));
|
||||||
q.select(goodCustomer);
|
// q.where(cb.exists(sq));
|
||||||
|
// q.select(emp).distinct(true);
|
||||||
assertEquivalence(q, jpql);
|
//
|
||||||
}
|
// assertEquivalence(q, jpql);
|
||||||
|
// }
|
||||||
@AllowFailure(message="Subqueries not implemented")
|
//
|
||||||
public void testSubqueries2() {
|
// @AllowFailure(message="Subqueries not implemented")
|
||||||
String jpql = "SELECT DISTINCT emp FROM Employee emp WHERE EXISTS ("
|
// public void testSubqueries3() {
|
||||||
+ "SELECT spouseEmp FROM Employee spouseEmp WHERE spouseEmp = "
|
// String jpql = "SELECT emp FROM Employee emp WHERE emp.salary > ALL ("
|
||||||
+ "emp.spouse)";
|
// + "SELECT m.salary FROM Manager m WHERE m.department = "
|
||||||
CriteriaQuery q = cb.create();
|
// + "emp.department)";
|
||||||
Root<Employee> emp = q.from(Employee.class);
|
// CriteriaQuery q = cb.create();
|
||||||
Subquery<Employee> sq = q.subquery(Employee.class);
|
// Root<Employee> emp = q.from(Employee.class);
|
||||||
Root<Employee> spouseEmp = sq.from(Employee.class);
|
// q.select(emp);
|
||||||
sq.select(spouseEmp);
|
// Subquery<BigDecimal> sq = q.subquery(BigDecimal.class);
|
||||||
sq.where(cb.equal(spouseEmp, emp.get(Employee_.spouse)));
|
// Root<Manager> m = sq.from(Manager.class);
|
||||||
q.where(cb.exists(sq));
|
// sq.select(m.get(Manager_.salary));
|
||||||
q.select(emp).distinct(true);
|
// sq.where(cb.equal(m.get(Manager_.department), emp
|
||||||
|
// .get(Employee_.department)));
|
||||||
assertEquivalence(q, jpql);
|
// q.where(cb.gt(emp.get(Employee_.salary), cb.all(sq)));
|
||||||
}
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
@AllowFailure(message="Subqueries not implemented")
|
// }
|
||||||
public void testSubqueries3() {
|
//
|
||||||
String jpql = "SELECT emp FROM Employee emp WHERE emp.salary > ALL ("
|
// @AllowFailure(message="Subqueries not implemented")
|
||||||
+ "SELECT m.salary FROM Manager m WHERE m.department = "
|
// public void testSubqueries4() {
|
||||||
+ "emp.department)";
|
// String jpql = "SELECT c FROM Customer c WHERE "
|
||||||
CriteriaQuery q = cb.create();
|
// + "(SELECT COUNT(o) FROM c.orders o) > 10";
|
||||||
Root<Employee> emp = q.from(Employee.class);
|
// CriteriaQuery q = cb.create();
|
||||||
q.select(emp);
|
// Root<Customer> c1 = q.from(Customer.class);
|
||||||
Subquery<BigDecimal> sq = q.subquery(BigDecimal.class);
|
// q.select(c1);
|
||||||
Root<Manager> m = sq.from(Manager.class);
|
// Subquery<Long> sq3 = q.subquery(Long.class);
|
||||||
sq.select(m.get(Manager_.salary));
|
// Root<Customer> c2 = sq3.correlate(c1);
|
||||||
sq.where(cb.equal(m.get(Manager_.department), emp
|
// Join<Customer, Order> o = c2.join(Customer_.orders);
|
||||||
.get(Employee_.department)));
|
// q.where(cb.gt(sq3.select(cb.count(o)), 10));
|
||||||
q.where(cb.gt(emp.get(Employee_.salary), cb.all(sq)));
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
assertEquivalence(q, jpql);
|
// }
|
||||||
}
|
//
|
||||||
|
// @AllowFailure(message="Subqueries not implemented")
|
||||||
@AllowFailure(message="Subqueries not implemented")
|
// public void testSubqueries5() {
|
||||||
public void testSubqueries4() {
|
// String jpql = "SELECT o FROM Order o WHERE 10000 < ALL ("
|
||||||
String jpql = "SELECT c FROM Customer c WHERE "
|
// + "SELECT a.balance FROM o.customer c JOIN c.accounts a)";
|
||||||
+ "(SELECT COUNT(o) FROM c.orders o) > 10";
|
// CriteriaQuery q = cb.create();
|
||||||
CriteriaQuery q = cb.create();
|
// Root<Order> o = q.from(Order.class);
|
||||||
Root<Customer> c1 = q.from(Customer.class);
|
// q.select(o);
|
||||||
q.select(c1);
|
// Subquery<Integer> sq = q.subquery(Integer.class);
|
||||||
Subquery<Long> sq3 = q.subquery(Long.class);
|
// Root<Order> osq = sq.correlate(o);
|
||||||
Root<Customer> c2 = sq3.correlate(c1);
|
// Join<Order, Customer> c = osq.join(Order_.customer);
|
||||||
Join<Customer, Order> o = c2.join(Customer_.orders);
|
// Join<Customer, Account> a = c.join(Customer_.accounts);
|
||||||
q.where(cb.gt(sq3.select(cb.count(o)), 10));
|
// sq.select(a.get(Account_.balance));
|
||||||
|
// q.where(cb.lt(cb.literal(10000), cb.all(sq)));
|
||||||
assertEquivalence(q, jpql);
|
//
|
||||||
}
|
// assertEquivalence(q, jpql);
|
||||||
|
// }
|
||||||
@AllowFailure(message="Subqueries not implemented")
|
//
|
||||||
public void testSubqueries5() {
|
// @AllowFailure(message="Subqueries not implemented")
|
||||||
String jpql = "SELECT o FROM Order o WHERE 10000 < ALL ("
|
// public void testSubqueries6() {
|
||||||
+ "SELECT a.balance FROM o.customer c JOIN c.accounts a)";
|
// String jpql = "SELECT o FROM Order o JOIN o.customer c WHERE 10000 < "
|
||||||
CriteriaQuery q = cb.create();
|
// + "ALL (SELECT a.balance FROM c.accounts a)";
|
||||||
Root<Order> o = q.from(Order.class);
|
// CriteriaQuery q = cb.create();
|
||||||
q.select(o);
|
// Root<Order> o = q.from(Order.class);
|
||||||
Subquery<Integer> sq = q.subquery(Integer.class);
|
// q.select(o);
|
||||||
Root<Order> osq = sq.correlate(o);
|
// Join<Order, Customer> c = o.join(Order_.customer);
|
||||||
Join<Order, Customer> c = osq.join(Order_.customer);
|
// Subquery<Integer> sq = q.subquery(Integer.class);
|
||||||
Join<Customer, Account> a = c.join(Customer_.accounts);
|
// Join<Order, Customer> csq = sq.correlate(c);
|
||||||
sq.select(a.get(Account_.balance));
|
// Join<Customer, Account> a = csq.join(Customer_.accounts);
|
||||||
q.where(cb.lt(cb.literal(10000), cb.all(sq)));
|
// sq.select(a.get(Account_.balance));
|
||||||
|
// q.where(cb.lt(cb.literal(10000), cb.all(sq)));
|
||||||
assertEquivalence(q, jpql);
|
//
|
||||||
}
|
// assertEquivalence(q, jpql);
|
||||||
|
// }
|
||||||
@AllowFailure(message="Subqueries not implemented")
|
|
||||||
public void testSubqueries6() {
|
|
||||||
String jpql = "SELECT o FROM Order o JOIN o.customer c WHERE 10000 < "
|
|
||||||
+ "ALL (SELECT a.balance FROM c.accounts a)";
|
|
||||||
CriteriaQuery q = cb.create();
|
|
||||||
Root<Order> o = q.from(Order.class);
|
|
||||||
q.select(o);
|
|
||||||
Join<Order, Customer> c = o.join(Order_.customer);
|
|
||||||
Subquery<Integer> sq = q.subquery(Integer.class);
|
|
||||||
Join<Order, Customer> csq = sq.correlate(c);
|
|
||||||
Join<Customer, Account> a = csq.join(Customer_.accounts);
|
|
||||||
sq.select(a.get(Account_.balance));
|
|
||||||
q.where(cb.lt(cb.literal(10000), cb.all(sq)));
|
|
||||||
|
|
||||||
assertEquivalence(q, jpql);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testGroupByAndHaving() {
|
public void testGroupByAndHaving() {
|
||||||
String jpql = "SELECT c.status, AVG(c.filledOrderCount), COUNT(c) FROM "
|
String jpql = "SELECT c.status, AVG(c.filledOrderCount), COUNT(c) FROM "
|
||||||
|
@ -692,135 +702,137 @@ public class TestTypesafeCriteria extends CriteriaTest {
|
||||||
assertEquivalence(q, jpql);
|
assertEquivalence(q, jpql);
|
||||||
}
|
}
|
||||||
|
|
||||||
@AllowFailure(message="AbstractExpressionExecutor.assertNotContainer() not happy")
|
// @AllowFailure(message="AbstractExpressionExecutor.assertNotContainer()
|
||||||
public void testOrdering() {
|
// not happy")
|
||||||
String jpql = "SELECT c FROM Customer c JOIN c.orders o "
|
// public void testOrdering() {
|
||||||
+ "JOIN c.address a WHERE a.state = 'CA' ORDER BY o.quantity DESC, "
|
// String jpql = "SELECT c FROM Customer c JOIN c.orders o "
|
||||||
+ "o.totalCost";
|
// + "JOIN c.address a WHERE a.state = 'CA' ORDER BY o.quantity DESC, "
|
||||||
CriteriaQuery q = cb.create();
|
// + "o.totalCost";
|
||||||
Root<Customer> c = q.from(Customer.class);
|
// CriteriaQuery q = cb.create();
|
||||||
Join<Customer, Order> o = c.join(Customer_.orders);
|
// Root<Customer> c = q.from(Customer.class);
|
||||||
Join<Customer, Address> a = c.join(Customer_.address);
|
// Join<Customer, Order> o = c.join(Customer_.orders);
|
||||||
q.where(cb.equal(a.get(Address_.state), "CA"));
|
// Join<Customer, Address> a = c.join(Customer_.address);
|
||||||
q.orderBy(cb.desc(o.get(Order_.quantity)), cb.asc(o
|
// q.where(cb.equal(a.get(Address_.state), "CA"));
|
||||||
.get(Order_.totalCost)));
|
// q.orderBy(cb.desc(o.get(Order_.quantity)), cb.asc(o
|
||||||
q.select(o);
|
// .get(Order_.totalCost)));
|
||||||
|
// q.select(o);
|
||||||
assertEquivalence(q, jpql);
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
jpql = "SELECT o.quantity, a.zipCode FROM Customer c JOIN c.orders "
|
//
|
||||||
+ "JOIN c.address a WHERE a.state = 'CA' ORDER BY o.quantity, "
|
// jpql = "SELECT o.quantity, a.zipCode FROM Customer c JOIN c.orders "
|
||||||
+ "a.zipCode";
|
// + "JOIN c.address a WHERE a.state = 'CA' ORDER BY o.quantity, "
|
||||||
q = cb.create();
|
// + "a.zipCode";
|
||||||
Root<Customer> c1 = q.from(Customer.class);
|
// q = cb.create();
|
||||||
Join<Customer, Order> o1 = c1.join(Customer_.orders);
|
// Root<Customer> c1 = q.from(Customer.class);
|
||||||
Join<Customer, Address> a1 = c1.join(Customer_.address);
|
// Join<Customer, Order> o1 = c1.join(Customer_.orders);
|
||||||
q.where(cb.equal(a1.get(Address_.state), "CA"));
|
// Join<Customer, Address> a1 = c1.join(Customer_.address);
|
||||||
q.orderBy(cb.asc(o1.get(Order_.quantity)), cb.asc(a1
|
// q.where(cb.equal(a1.get(Address_.state), "CA"));
|
||||||
.get(Address_.zipCode)));
|
// q.orderBy(cb.asc(o1.get(Order_.quantity)), cb.asc(a1
|
||||||
q.select(o1.get(Order_.quantity), a1.get(Address_.zipCode));
|
// .get(Address_.zipCode)));
|
||||||
|
// q.select(o1.get(Order_.quantity), a1.get(Address_.zipCode));
|
||||||
assertEquivalence(q, jpql);
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
jpql = "SELECT o.quantity, o.cost * 1.08 AS taxedCost, a.zipCode "
|
//
|
||||||
+ "FROM Customer c JOIN c.orders o JOIN c.address a "
|
// jpql = "SELECT o.quantity, o.cost * 1.08 AS taxedCost, a.zipCode "
|
||||||
+ "WHERE a.state = 'CA' AND a.county = 'Santa Clara' "
|
// + "FROM Customer c JOIN c.orders o JOIN c.address a "
|
||||||
+ "ORDER BY o.quantity, taxedCost, a.zipCode";
|
// + "WHERE a.state = 'CA' AND a.county = 'Santa Clara' "
|
||||||
q = cb.create();
|
// + "ORDER BY o.quantity, taxedCost, a.zipCode";
|
||||||
Root<Customer> c2 = q.from(Customer.class);
|
// q = cb.create();
|
||||||
Join<Customer, Order> o2 = c2.join(Customer_.orders);
|
// Root<Customer> c2 = q.from(Customer.class);
|
||||||
Join<Customer, Address> a2 = c2.join(Customer_.address);
|
// Join<Customer, Order> o2 = c2.join(Customer_.orders);
|
||||||
q.where(cb.equal(a.get(Address_.state), "CA"), cb.equal(a
|
// Join<Customer, Address> a2 = c2.join(Customer_.address);
|
||||||
.get(Address_.county), "Santa Clara"));
|
// q.where(cb.equal(a.get(Address_.state), "CA"), cb.equal(a
|
||||||
q.orderBy(cb.asc(o.get(Order_.quantity)), cb.asc(cb.prod(
|
// .get(Address_.county), "Santa Clara"));
|
||||||
o.get(Order_.totalCost), 1.08)),
|
// q.orderBy(cb.asc(o.get(Order_.quantity)), cb.asc(cb.prod(
|
||||||
cb.asc(a.get(Address_.zipCode)));
|
// o.get(Order_.totalCost), 1.08)),
|
||||||
q.select(o.get(Order_.quantity), cb.prod(
|
// cb.asc(a.get(Address_.zipCode)));
|
||||||
o.get(Order_.totalCost), 1.08), a.get(Address_.zipCode));
|
// q.select(o.get(Order_.quantity), cb.prod(
|
||||||
|
// o.get(Order_.totalCost), 1.08), a.get(Address_.zipCode));
|
||||||
assertEquivalence(q, jpql);
|
//
|
||||||
}
|
// assertEquivalence(q, jpql);
|
||||||
|
// }
|
||||||
@AllowFailure(message="AbstractExpressionExecutor.assertNotContainer() not happy")
|
//
|
||||||
public void testOrdering1() {
|
// @AllowFailure(message="AbstractExpressionExecutor.assertNotContainer()"+
|
||||||
String jpql = "SELECT o FROM Customer c JOIN c.orders o "
|
// "not happy")
|
||||||
+ "JOIN c.address a WHERE a.state = 'CA' ORDER BY o.quantity DESC, "
|
// public void testOrdering1() {
|
||||||
+ "o.totalCost";
|
// String jpql = "SELECT o FROM Customer c JOIN c.orders o "
|
||||||
CriteriaQuery q = cb.create();
|
// + "JOIN c.address a WHERE a.state = 'CA' ORDER BY o.quantity DESC, "
|
||||||
Root<Customer> c = q.from(Customer.class);
|
// + "o.totalCost";
|
||||||
Join<Customer, Order> o = c.join(Customer_.orders);
|
// CriteriaQuery q = cb.create();
|
||||||
Join<Customer, Address> a = c.join(Customer_.address);
|
// Root<Customer> c = q.from(Customer.class);
|
||||||
q.where(cb.equal(a.get(Address_.state), "CA"));
|
// Join<Customer, Order> o = c.join(Customer_.orders);
|
||||||
q.orderBy(cb.desc(o.get(Order_.quantity)), cb.asc(o
|
// Join<Customer, Address> a = c.join(Customer_.address);
|
||||||
.get(Order_.totalCost)));
|
// q.where(cb.equal(a.get(Address_.state), "CA"));
|
||||||
q.select(o);
|
// q.orderBy(cb.desc(o.get(Order_.quantity)), cb.asc(o
|
||||||
|
// .get(Order_.totalCost)));
|
||||||
assertEquivalence(q, jpql);
|
// q.select(o);
|
||||||
}
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
@AllowFailure(message="The JPQL is broken!")
|
// }
|
||||||
public void testOrdering2() {
|
//
|
||||||
String jpql = "SELECT o.quantity, a.zipCode FROM Customer c "
|
// @AllowFailure(message="The JPQL is broken!")
|
||||||
+ "JOIN c.orders JOIN c.address a WHERE a.state = 'CA' "
|
// public void testOrdering2() {
|
||||||
+ "ORDER BY o.quantity, a.zipCode";
|
// String jpql = "SELECT o.quantity, a.zipCode FROM Customer c "
|
||||||
CriteriaQuery q = cb.create();
|
// + "JOIN c.orders JOIN c.address a WHERE a.state = 'CA' "
|
||||||
Root<Customer> c = q.from(Customer.class);
|
// + "ORDER BY o.quantity, a.zipCode";
|
||||||
Join<Customer, Order> o = c.join(Customer_.orders);
|
// CriteriaQuery q = cb.create();
|
||||||
Join<Customer, Address> a = c.join(Customer_.address);
|
// Root<Customer> c = q.from(Customer.class);
|
||||||
q.where(cb.equal(a.get(Address_.state), "CA"));
|
// Join<Customer, Order> o = c.join(Customer_.orders);
|
||||||
q.orderBy(cb.asc(o.get(Order_.quantity)), cb.asc(a
|
// Join<Customer, Address> a = c.join(Customer_.address);
|
||||||
.get(Address_.zipCode)));
|
// q.where(cb.equal(a.get(Address_.state), "CA"));
|
||||||
q.select(o.get(Order_.quantity), a.get(Address_.zipCode));
|
// q.orderBy(cb.asc(o.get(Order_.quantity)), cb.asc(a
|
||||||
|
// .get(Address_.zipCode)));
|
||||||
assertEquivalence(q, jpql);
|
// q.select(o.get(Order_.quantity), a.get(Address_.zipCode));
|
||||||
}
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
@AllowFailure(message="QueryExpression.ordering not initialized")
|
// }
|
||||||
public void testOrdering3() {
|
//
|
||||||
String jpql = "SELECT o.quantity, o.totalCost * 1.08 AS taxedCost, "
|
// @AllowFailure(message="QueryExpression.ordering not initialized")
|
||||||
+ "a.zipCode FROM Customer c JOIN c.orders o JOIN c.address a "
|
// public void testOrdering3() {
|
||||||
+ "WHERE a.state = 'CA' AND a.county = 'Santa Clara' "
|
// String jpql = "SELECT o.quantity, o.totalCost * 1.08 AS taxedCost, "
|
||||||
+ "ORDER BY o.quantity, taxedCost, a.zipCode";
|
// + "a.zipCode FROM Customer c JOIN c.orders o JOIN c.address a "
|
||||||
CriteriaQuery q = cb.create();
|
// + "WHERE a.state = 'CA' AND a.county = 'Santa Clara' "
|
||||||
Root<Customer> c = q.from(Customer.class);
|
// + "ORDER BY o.quantity, taxedCost, a.zipCode";
|
||||||
Join<Customer, Order> o = c.join(Customer_.orders);
|
// CriteriaQuery q = cb.create();
|
||||||
Join<Customer, Address> a = c.join(Customer_.address);
|
// Root<Customer> c = q.from(Customer.class);
|
||||||
q.where(cb.equal(a.get(Address_.state), "CA"), cb.equal(a
|
// Join<Customer, Order> o = c.join(Customer_.orders);
|
||||||
.get(Address_.county), "Santa Clara"));
|
// Join<Customer, Address> a = c.join(Customer_.address);
|
||||||
q.orderBy(cb.asc(o.get(Order_.quantity)), cb.asc(cb.prod(
|
// q.where(cb.equal(a.get(Address_.state), "CA"), cb.equal(a
|
||||||
o.get(Order_.totalCost), 1.08)),
|
// .get(Address_.county), "Santa Clara"));
|
||||||
cb.asc(a.get(Address_.zipCode)));
|
// q.orderBy(cb.asc(o.get(Order_.quantity)), cb.asc(cb.prod(
|
||||||
q.select(o.get(Order_.quantity), cb.prod(
|
// o.get(Order_.totalCost), 1.08)),
|
||||||
o.get(Order_.totalCost), 1.08), a.get(Address_.zipCode));
|
// cb.asc(a.get(Address_.zipCode)));
|
||||||
|
// q.select(o.get(Order_.quantity), cb.prod(
|
||||||
assertEquivalence(q, jpql);
|
// o.get(Order_.totalCost), 1.08), a.get(Address_.zipCode));
|
||||||
}
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
|
// }
|
||||||
@AllowFailure(message="QueryExpression.ordering not initialized")
|
//
|
||||||
public void testOrdering4() {
|
//
|
||||||
String jpql = "SELECT c FROM Customer c "
|
// @AllowFailure(message="QueryExpression.ordering not initialized")
|
||||||
+ "ORDER BY c.name DESC, c.status";
|
// public void testOrdering4() {
|
||||||
CriteriaQuery q = cb.create();
|
// String jpql = "SELECT c FROM Customer c "
|
||||||
Root<Customer> c = q.from(Customer.class);
|
// + "ORDER BY c.name DESC, c.status";
|
||||||
q.orderBy(cb.desc(c.get(Customer_.name)), cb.asc(c
|
// CriteriaQuery q = cb.create();
|
||||||
.get(Customer_.status)));
|
// Root<Customer> c = q.from(Customer.class);
|
||||||
q.select(c);
|
// q.orderBy(cb.desc(c.get(Customer_.name)), cb.asc(c
|
||||||
|
// .get(Customer_.status)));
|
||||||
assertEquivalence(q, jpql);
|
// q.select(c);
|
||||||
}
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
@AllowFailure(message="QueryExpression.ordering not initialized")
|
// }
|
||||||
public void testOrdering5() {
|
//
|
||||||
String jpql = "SELECT c.firstName, c.lastName, c.balanceOwed "
|
// @AllowFailure(message="QueryExpression.ordering not initialized")
|
||||||
+ "FROM Customer c ORDER BY c.name DESC, c.status";
|
// public void testOrdering5() {
|
||||||
CriteriaQuery q = cb.create();
|
// String jpql = "SELECT c.firstName, c.lastName, c.balanceOwed "
|
||||||
Root<Customer> c = q.from(Customer.class);
|
// + "FROM Customer c ORDER BY c.name DESC, c.status";
|
||||||
q.orderBy(cb.desc(c.get(Customer_.name)), cb.asc(c
|
// CriteriaQuery q = cb.create();
|
||||||
.get(Customer_.status)));
|
// Root<Customer> c = q.from(Customer.class);
|
||||||
q.select(c.get(Customer_.firstName), c.get(Customer_.lastName), c
|
// q.orderBy(cb.desc(c.get(Customer_.name)), cb.asc(c
|
||||||
.get(Customer_.balanceOwed));
|
// .get(Customer_.status)));
|
||||||
|
// q.select(c.get(Customer_.firstName), c.get(Customer_.lastName), c
|
||||||
assertEquivalence(q, jpql);
|
// .get(Customer_.balanceOwed));
|
||||||
}
|
//
|
||||||
|
// assertEquivalence(q, jpql);
|
||||||
|
// }
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
package org.apache.openjpa.persistence.criteria;
|
package org.apache.openjpa.persistence.criteria;
|
||||||
|
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.criteria.Transaction.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
|
value=org.apache.openjpa.persistence.criteria.Transaction.class)
|
||||||
public class Transaction_ {
|
public class Transaction_ {
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,7 +61,8 @@ public class EntityF {
|
||||||
|
|
||||||
@ElementCollection
|
@ElementCollection
|
||||||
@MapKeyColumn(name = "\"mapKey\"")
|
@MapKeyColumn(name = "\"mapKey\"")
|
||||||
private Map<String, String> delimCollectionMap = new HashMap<String, String>();
|
private Map<String, String> delimCollectionMap =
|
||||||
|
new HashMap<String, String>();
|
||||||
|
|
||||||
public EntityF(String name) {
|
public EntityF(String name) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
|
|
|
@ -335,8 +335,10 @@ public class TestFieldRange extends BaseKernelTest {
|
||||||
|
|
||||||
System.out.println("i1 : " + i1 + "\ni2 : " + i2);
|
System.out.println("i1 : " + i1 + "\ni2 : " + i2);
|
||||||
|
|
||||||
//CR346162. In this CR, it was stated that @Temporal(DATE) fields will be equal for year, month, day but not for hours,
|
// CR346162. In this CR, it was stated that @Temporal(DATE) fields will
|
||||||
//minutes, seconds. So, we removed the time check and checked only for the equality of day, month and year
|
// be equal for year, month, day but not for hours,
|
||||||
|
// minutes, seconds. So, we removed the time check and checked only for
|
||||||
|
// the equality of day, month and year
|
||||||
|
|
||||||
/* assertEquals("Field type Date: "
|
/* assertEquals("Field type Date: "
|
||||||
+ testDate.getTime() + "!="
|
+ testDate.getTime() + "!="
|
||||||
|
@ -349,11 +351,12 @@ public class TestFieldRange extends BaseKernelTest {
|
||||||
if ((testDateDay != retrievedObjectDay) ||
|
if ((testDateDay != retrievedObjectDay) ||
|
||||||
(testDateMonth != retrievedObjectMonth) ||
|
(testDateMonth != retrievedObjectMonth) ||
|
||||||
(testDateYear != retrievedObjectYear)) {
|
(testDateYear != retrievedObjectYear)) {
|
||||||
Assert.fail(
|
Assert
|
||||||
"Field type Date not stored properly. One or more of the components of the date (day, month or year) do not match. \n" +
|
.fail("Field type Date not stored properly. One or more of "
|
||||||
" Value that should be stored : " + testDate.toGMTString() +
|
+ "the components of the date (day, month or year) "
|
||||||
". \nValue that is actually" +
|
+ "do not match. \n" + " Value that should be stored : "
|
||||||
"stored : " + retrievedObject.getTestDate().toGMTString());
|
+ testDate.toGMTString() + ". \nValue that is actually"
|
||||||
|
+ "stored : " + retrievedObject.getTestDate().toGMTString());
|
||||||
}
|
}
|
||||||
//assertEquals ("Field type Object", testObject,
|
//assertEquals ("Field type Object", testObject,
|
||||||
//retrievedObject.getTestObject ());
|
//retrievedObject.getTestObject ());
|
||||||
|
|
|
@ -6,7 +6,8 @@ package org.apache.openjpa.persistence.meta;
|
||||||
|
|
||||||
import javax.persistence.metamodel.Attribute;
|
import javax.persistence.metamodel.Attribute;
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.meta.ArrayMember.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
|
value=org.apache.openjpa.persistence.meta.ArrayMember.class)
|
||||||
public class ArrayMember_ {
|
public class ArrayMember_ {
|
||||||
public static volatile Attribute<ArrayMember,Byte[]> Array;
|
public static volatile Attribute<ArrayMember,Byte[]> Array;
|
||||||
public static volatile Attribute<ArrayMember,byte[]> array;
|
public static volatile Attribute<ArrayMember,byte[]> array;
|
||||||
|
|
|
@ -6,8 +6,10 @@ package org.apache.openjpa.persistence.meta;
|
||||||
|
|
||||||
import javax.persistence.metamodel.Attribute;
|
import javax.persistence.metamodel.Attribute;
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.meta.Embed0.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
|
value=org.apache.openjpa.persistence.meta.Embed0.class)
|
||||||
public class Embed0_ {
|
public class Embed0_ {
|
||||||
public static volatile Attribute<Embed0,ImplicitFieldAccessSubclass> entity1;
|
public static volatile Attribute<Embed0,ImplicitFieldAccessSubclass>
|
||||||
|
entity1;
|
||||||
public static volatile Attribute<Embed0,Long> f1;
|
public static volatile Attribute<Embed0,Long> f1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,7 +6,8 @@ package org.apache.openjpa.persistence.meta;
|
||||||
|
|
||||||
import javax.persistence.metamodel.Attribute;
|
import javax.persistence.metamodel.Attribute;
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.meta.Embed1.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
|
value = org.apache.openjpa.persistence.meta.Embed1.class)
|
||||||
public class Embed1_ {
|
public class Embed1_ {
|
||||||
public static volatile Attribute<Embed1,ImplicitFieldAccessBase> entity0;
|
public static volatile Attribute<Embed1,ImplicitFieldAccessBase> entity0;
|
||||||
public static volatile Attribute<Embed1,String> f1;
|
public static volatile Attribute<Embed1,String> f1;
|
||||||
|
|
|
@ -6,10 +6,13 @@ package org.apache.openjpa.persistence.meta;
|
||||||
|
|
||||||
import javax.persistence.metamodel.Attribute;
|
import javax.persistence.metamodel.Attribute;
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.meta.ExplicitFieldAccessMixed.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
|
value=org.apache.openjpa.persistence.meta.ExplicitFieldAccessMixed.class)
|
||||||
public class ExplicitFieldAccessMixed_ {
|
public class ExplicitFieldAccessMixed_ {
|
||||||
public static volatile Attribute<ExplicitFieldAccessMixed,Long> f1;
|
public static volatile Attribute<ExplicitFieldAccessMixed,Long> f1;
|
||||||
public static volatile Attribute<ExplicitFieldAccessMixed,Integer> f2;
|
public static volatile Attribute<ExplicitFieldAccessMixed,Integer> f2;
|
||||||
public static volatile Attribute<ExplicitFieldAccessMixed,ImplicitFieldAccessBase> f4;
|
public static volatile Attribute<ExplicitFieldAccessMixed,
|
||||||
public static volatile Attribute<ExplicitFieldAccessMixed,ImplicitFieldAccessBase> f5;
|
ImplicitFieldAccessBase> f4;
|
||||||
|
public static volatile Attribute<ExplicitFieldAccessMixed,
|
||||||
|
ImplicitFieldAccessBase> f5;
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,10 +6,13 @@ package org.apache.openjpa.persistence.meta;
|
||||||
|
|
||||||
import javax.persistence.metamodel.Attribute;
|
import javax.persistence.metamodel.Attribute;
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.meta.ExplicitFieldAccess.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
|
value=org.apache.openjpa.persistence.meta.ExplicitFieldAccess.class)
|
||||||
public class ExplicitFieldAccess_ {
|
public class ExplicitFieldAccess_ {
|
||||||
public static volatile Attribute<ExplicitFieldAccess,Long> f1;
|
public static volatile Attribute<ExplicitFieldAccess,Long> f1;
|
||||||
public static volatile Attribute<ExplicitFieldAccess,Integer> f2;
|
public static volatile Attribute<ExplicitFieldAccess,Integer> f2;
|
||||||
public static volatile Attribute<ExplicitFieldAccess,ImplicitFieldAccessBase> f4;
|
public static volatile Attribute<ExplicitFieldAccess,
|
||||||
public static volatile Attribute<ExplicitFieldAccess,ImplicitFieldAccessBase> f5;
|
ImplicitFieldAccessBase> f4;
|
||||||
|
public static volatile Attribute<ExplicitFieldAccess,
|
||||||
|
ImplicitFieldAccessBase> f5;
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,11 +6,14 @@ package org.apache.openjpa.persistence.meta;
|
||||||
|
|
||||||
import javax.persistence.metamodel.Attribute;
|
import javax.persistence.metamodel.Attribute;
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.meta.ExplicitPropertyAccessMixed.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
|
value=org.apache.openjpa.persistence.meta.ExplicitPropertyAccessMixed.class)
|
||||||
public class ExplicitPropertyAccessMixed_ {
|
public class ExplicitPropertyAccessMixed_ {
|
||||||
public static volatile Attribute<ExplicitPropertyAccessMixed,String> f1;
|
public static volatile Attribute<ExplicitPropertyAccessMixed,String> f1;
|
||||||
public static volatile Attribute<ExplicitPropertyAccessMixed,ImplicitFieldAccessBase> f3;
|
public static volatile Attribute<ExplicitPropertyAccessMixed,
|
||||||
|
ImplicitFieldAccessBase> f3;
|
||||||
public static volatile Attribute<ExplicitPropertyAccessMixed,Integer> f4;
|
public static volatile Attribute<ExplicitPropertyAccessMixed,Integer> f4;
|
||||||
public static volatile Attribute<ExplicitPropertyAccessMixed,Short> f5;
|
public static volatile Attribute<ExplicitPropertyAccessMixed,Short> f5;
|
||||||
public static volatile Attribute<ExplicitPropertyAccessMixed,ImplicitFieldAccessBase> f6;
|
public static volatile Attribute<ExplicitPropertyAccessMixed,
|
||||||
|
ImplicitFieldAccessBase> f6;
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,11 +6,14 @@ package org.apache.openjpa.persistence.meta;
|
||||||
|
|
||||||
import javax.persistence.metamodel.Attribute;
|
import javax.persistence.metamodel.Attribute;
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.meta.ExplicitPropertyAccess.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
|
value = org.apache.openjpa.persistence.meta.ExplicitPropertyAccess.class)
|
||||||
public class ExplicitPropertyAccess_ {
|
public class ExplicitPropertyAccess_ {
|
||||||
public static volatile Attribute<ExplicitPropertyAccess, String> f1;
|
public static volatile Attribute<ExplicitPropertyAccess, String> f1;
|
||||||
public static volatile Attribute<ExplicitPropertyAccess, String> f3;
|
public static volatile Attribute<ExplicitPropertyAccess, String> f3;
|
||||||
public static volatile Attribute<ExplicitPropertyAccess, String> f4;
|
public static volatile Attribute<ExplicitPropertyAccess, String> f4;
|
||||||
public static volatile Attribute<ExplicitPropertyAccess,ImplicitFieldAccessBase> f5;
|
public static volatile Attribute<ExplicitPropertyAccess,
|
||||||
public static volatile Attribute<ExplicitPropertyAccess,ImplicitFieldAccessBase> f6;
|
ImplicitFieldAccessBase> f5;
|
||||||
|
public static volatile Attribute<ExplicitPropertyAccess,
|
||||||
|
ImplicitFieldAccessBase> f6;
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,7 +42,8 @@ import javax.persistence.Transient;
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@Entity
|
@Entity
|
||||||
public class ImplicitFieldAccessBase extends ImplicitFieldAccessMappedSuperclass {
|
public class ImplicitFieldAccessBase extends
|
||||||
|
ImplicitFieldAccessMappedSuperclass {
|
||||||
private String f0;
|
private String f0;
|
||||||
private int primitiveInt;
|
private int primitiveInt;
|
||||||
private Integer boxedInt;
|
private Integer boxedInt;
|
||||||
|
|
|
@ -10,15 +10,24 @@ import javax.persistence.metamodel.List;
|
||||||
import javax.persistence.metamodel.Map;
|
import javax.persistence.metamodel.Map;
|
||||||
import javax.persistence.metamodel.Set;
|
import javax.persistence.metamodel.Set;
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.meta.ImplicitFieldAccessBase.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
public class ImplicitFieldAccessBase_ extends ImplicitFieldAccessMappedSuperclass_ {
|
value=org.apache.openjpa.persistence.meta.ImplicitFieldAccessBase.class)
|
||||||
|
public class ImplicitFieldAccessBase_ extends
|
||||||
|
ImplicitFieldAccessMappedSuperclass_ {
|
||||||
public static volatile Attribute<ImplicitFieldAccessBase, Integer> boxedInt;
|
public static volatile Attribute<ImplicitFieldAccessBase, Integer> boxedInt;
|
||||||
public static volatile Collection<ImplicitFieldAccessBase,ExplicitFieldAccess> collectionRelation;
|
public static volatile Collection<ImplicitFieldAccessBase,
|
||||||
|
ExplicitFieldAccess> collectionRelation;
|
||||||
public static volatile Attribute<ImplicitFieldAccessBase, String> f0;
|
public static volatile Attribute<ImplicitFieldAccessBase, String> f0;
|
||||||
public static volatile List<ImplicitFieldAccessBase,ExplicitFieldAccess> listRelation;
|
public static volatile List<ImplicitFieldAccessBase, ExplicitFieldAccess>
|
||||||
public static volatile Map<ImplicitFieldAccessBase,Integer,ExplicitFieldAccess> mapRelationKeyBasic;
|
listRelation;
|
||||||
public static volatile Map<ImplicitFieldAccessBase,ExplicitPropertyAccess,ExplicitFieldAccess> mapRelationKeyPC;
|
public static volatile Map<ImplicitFieldAccessBase, Integer,
|
||||||
public static volatile Attribute<ImplicitFieldAccessBase,ExplicitFieldAccess> one2oneRelation;
|
ExplicitFieldAccess> mapRelationKeyBasic;
|
||||||
public static volatile Attribute<ImplicitFieldAccessBase,Integer> primitiveInt;
|
public static volatile Map<ImplicitFieldAccessBase, ExplicitPropertyAccess,
|
||||||
public static volatile Set<ImplicitFieldAccessBase,ExplicitFieldAccess> setRelation;
|
ExplicitFieldAccess> mapRelationKeyPC;
|
||||||
|
public static volatile Attribute<ImplicitFieldAccessBase,
|
||||||
|
ExplicitFieldAccess> one2oneRelation;
|
||||||
|
public static volatile Attribute<ImplicitFieldAccessBase,
|
||||||
|
Integer> primitiveInt;
|
||||||
|
public static volatile Set<ImplicitFieldAccessBase,
|
||||||
|
ExplicitFieldAccess> setRelation;
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,8 +7,12 @@ package org.apache.openjpa.persistence.meta;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import javax.persistence.metamodel.Attribute;
|
import javax.persistence.metamodel.Attribute;
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.meta.ImplicitFieldAccessMappedSuperclass.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
|
value=org.apache.openjpa.persistence.meta.
|
||||||
|
ImplicitFieldAccessMappedSuperclass.class)
|
||||||
public class ImplicitFieldAccessMappedSuperclass_ {
|
public class ImplicitFieldAccessMappedSuperclass_ {
|
||||||
public static volatile Attribute<ImplicitFieldAccessMappedSuperclass,Date> createTime;
|
public static volatile Attribute<ImplicitFieldAccessMappedSuperclass,Date>
|
||||||
public static volatile Attribute<ImplicitFieldAccessMappedSuperclass,Long> id;
|
createTime;
|
||||||
|
public static volatile Attribute<ImplicitFieldAccessMappedSuperclass,Long>
|
||||||
|
id;
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,8 +7,11 @@ package org.apache.openjpa.persistence.meta;
|
||||||
import javax.persistence.metamodel.Attribute;
|
import javax.persistence.metamodel.Attribute;
|
||||||
import javax.persistence.metamodel.Map;
|
import javax.persistence.metamodel.Map;
|
||||||
|
|
||||||
@javax.persistence.metamodel.TypesafeMetamodel(value=org.apache.openjpa.persistence.meta.ImplicitFieldAccessSubclass.class)
|
@javax.persistence.metamodel.TypesafeMetamodel(
|
||||||
|
value=org.apache.openjpa.persistence.meta.ImplicitFieldAccessSubclass.class)
|
||||||
public class ImplicitFieldAccessSubclass_ extends ImplicitFieldAccessBase_ {
|
public class ImplicitFieldAccessSubclass_ extends ImplicitFieldAccessBase_ {
|
||||||
public static volatile Attribute<ImplicitFieldAccessSubclass,ImplicitFieldAccessBase> base;
|
public static volatile Attribute<ImplicitFieldAccessSubclass,
|
||||||
public static volatile Map<ImplicitFieldAccessSubclass,Embed0,ExplicitPropertyAccess> mapRelationKeyEmbedded;
|
ImplicitFieldAccessBase> base;
|
||||||
|
public static volatile Map<ImplicitFieldAccessSubclass,Embed0,
|
||||||
|
ExplicitPropertyAccess> mapRelationKeyEmbedded;
|
||||||
}
|
}
|
||||||
|
|
|
@ -280,7 +280,8 @@ public class TestQuery extends SliceTestCase {
|
||||||
assertEquals("Even", SlicePersistence.getSlice(c));
|
assertEquals("Even", SlicePersistence.getSlice(c));
|
||||||
|
|
||||||
// While all Manufacturers are stored in "Odd" slice.
|
// While all Manufacturers are stored in "Odd" slice.
|
||||||
List makers = em.createQuery("select m from Manufacturer m").getResultList();
|
List makers =
|
||||||
|
em.createQuery("select m from Manufacturer m").getResultList();
|
||||||
assertFalse(makers.isEmpty());
|
assertFalse(makers.isEmpty());
|
||||||
for (Object m : makers)
|
for (Object m : makers)
|
||||||
assertEquals("Odd", SlicePersistence.getSlice(m));
|
assertEquals("Odd", SlicePersistence.getSlice(m));
|
||||||
|
|
|
@ -278,7 +278,8 @@ public class TestQueryMultiThreaded extends SliceTestCase {
|
||||||
/**
|
/**
|
||||||
* This test is currently retired.
|
* This test is currently retired.
|
||||||
*
|
*
|
||||||
* @see <A HREF="https://issues.apache.org/jira/browse/OPENJPA-1044">OPENJPA-1044</A>
|
* @see <A HREF="https://issues.apache.org/jira/browse/OPENJPA-1044">
|
||||||
|
* OPENJPA-1044</A>
|
||||||
* for details.
|
* for details.
|
||||||
*/
|
*/
|
||||||
public void xtestQueryParameterEntity() {
|
public void xtestQueryParameterEntity() {
|
||||||
|
|
2
pom.xml
2
pom.xml
|
@ -706,6 +706,7 @@
|
||||||
<configLocation>${checkstyle.config.location}</configLocation>
|
<configLocation>${checkstyle.config.location}</configLocation>
|
||||||
<failsOnError>true</failsOnError>
|
<failsOnError>true</failsOnError>
|
||||||
<consoleOutput>true</consoleOutput>
|
<consoleOutput>true</consoleOutput>
|
||||||
|
<includeTestSourceDirectory>true</includeTestSourceDirectory>
|
||||||
</configuration>
|
</configuration>
|
||||||
</execution>
|
</execution>
|
||||||
</executions>
|
</executions>
|
||||||
|
@ -744,6 +745,7 @@
|
||||||
<artifactId>maven-checkstyle-plugin</artifactId>
|
<artifactId>maven-checkstyle-plugin</artifactId>
|
||||||
<configuration>
|
<configuration>
|
||||||
<configLocation>${checkstyle.config.location}</configLocation>
|
<configLocation>${checkstyle.config.location}</configLocation>
|
||||||
|
<includeTestSourceDirectory>true</includeTestSourceDirectory>
|
||||||
</configuration>
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
</plugins>
|
</plugins>
|
||||||
|
|
Loading…
Reference in New Issue