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:
Pinaki Poddar 2009-02-03 23:18:54 +00:00
parent f9c94752d7
commit ddec73796c
3 changed files with 58 additions and 4 deletions

View File

@ -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;
} }

View File

@ -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 \

View File

@ -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
}
}
} }