mirror of https://github.com/apache/openjpa.git
OPENJPA-703: Validate parameter values by their expected types.
git-svn-id: https://svn.apache.org/repos/asf/openjpa/trunk@740506 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
f9c94752d7
commit
ddec73796c
|
@ -405,7 +405,9 @@ public class ExpressionStoreQuery
|
||||||
throw new UserException(_loc.get("gap-query-param",
|
throw new UserException(_loc.get("gap-query-param",
|
||||||
new Object[]{q.getContext().getQueryString(), key,
|
new Object[]{q.getContext().getQueryString(), key,
|
||||||
userParams.size(), userParams}));
|
userParams.size(), userParams}));
|
||||||
arr[idx] = userParams.get(key);
|
Object value = userParams.get(key);
|
||||||
|
validateParameterValue(key, value, (Class)paramTypes.get(key));
|
||||||
|
arr[idx] = value;
|
||||||
}
|
}
|
||||||
return arr;
|
return arr;
|
||||||
}
|
}
|
||||||
|
@ -431,6 +433,24 @@ public class ExpressionStoreQuery
|
||||||
return low;
|
return low;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void validateParameterValue(Object key, Object value,
|
||||||
|
Class expected) {
|
||||||
|
if (expected == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (value == null) {
|
||||||
|
if (expected.isPrimitive())
|
||||||
|
throw new UserException(_loc.get("null-primitive-param",
|
||||||
|
key, expected));
|
||||||
|
} else {
|
||||||
|
Class actual = value.getClass();
|
||||||
|
boolean strict = true;
|
||||||
|
if (!Filters.canConvert(actual, expected, strict))
|
||||||
|
throw new UserException(_loc.get("param-value-mismatch",
|
||||||
|
new Object[]{key, expected, value, actual}));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public final Map getUpdates(StoreQuery q) {
|
public final Map getUpdates(StoreQuery q) {
|
||||||
return assertQueryExpression().updates;
|
return assertQueryExpression().updates;
|
||||||
}
|
}
|
||||||
|
|
|
@ -291,8 +291,10 @@ unbound-params: Cannot execute query; declared parameters "{0}" were not given \
|
||||||
extra-params: More parameters were passed to execute() than were declared: \
|
extra-params: More parameters were passed to execute() than were declared: \
|
||||||
{1} parameters were specified for query execution, but only {0} \
|
{1} parameters were specified for query execution, but only {0} \
|
||||||
parameters were declared in the query.
|
parameters were declared in the query.
|
||||||
null-primitive-param: Parameter "{0}" was declared with a primitive type, but \
|
null-primitive-param: Parameter "{0}" expects a value of primitive "{1}" \
|
||||||
has been given a null value.
|
but was given a null value.
|
||||||
|
param-value-mismatch: Parameter "{0}" expects a value of "{1}" but was given \
|
||||||
|
a value of "{2}" of "{3}".
|
||||||
merged-aggregate: This query on candidate type "{0}" with filter "{1}" \
|
merged-aggregate: This query on candidate type "{0}" with filter "{1}" \
|
||||||
involves combining the results of multiple sub-queries. However, because \
|
involves combining the results of multiple sub-queries. However, because \
|
||||||
this query is for aggregate data, OpenJPA cannot combine the sub-query \
|
this query is for aggregate data, OpenJPA cannot combine the sub-query \
|
||||||
|
|
|
@ -95,4 +95,36 @@ public class TestParameterProcessing extends SingleEMFTestCase {
|
||||||
assertEquals(1, result2.size());
|
assertEquals(1, result2.size());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testWrongParameterValueTypeThrowException() {
|
||||||
|
String jpql = "select p from Person p where p.firstName=:first"
|
||||||
|
+ " and p.age > :age";
|
||||||
|
EntityManager em = emf.createEntityManager();
|
||||||
|
|
||||||
|
OpenJPAQuery q1 = OpenJPAPersistence.cast(em.createQuery(jpql));
|
||||||
|
try {
|
||||||
|
List result1 = q1.setParameter("first", (short)40)
|
||||||
|
.setParameter("age", "John")
|
||||||
|
.getResultList();
|
||||||
|
fail("Expected to fail with wrong parameter value");
|
||||||
|
} catch (IllegalArgumentException e) {
|
||||||
|
// good
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testNullParameterValueForPrimitiveTypeThrowsException() {
|
||||||
|
String jpql = "select p from Person p where p.firstName=:first"
|
||||||
|
+ " and p.age > :age";
|
||||||
|
EntityManager em = emf.createEntityManager();
|
||||||
|
|
||||||
|
OpenJPAQuery q1 = OpenJPAPersistence.cast(em.createQuery(jpql));
|
||||||
|
try {
|
||||||
|
List result1 = q1.setParameter("first", "John")
|
||||||
|
.setParameter("age", null)
|
||||||
|
.getResultList();
|
||||||
|
fail("Expected to fail with null parameter value for primitives");
|
||||||
|
} catch (RuntimeException e) {
|
||||||
|
// good
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue