OPENJPA-2260: Parenthesis-augmented parameters are improperly processed at EM level

git-svn-id: https://svn.apache.org/repos/asf/openjpa/trunk@1383100 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Jody Grassel 2012-09-10 20:27:56 +00:00
parent 1952ecd460
commit ef2065122a
2 changed files with 85 additions and 1 deletions

View File

@ -0,0 +1,79 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.openjpa.persistence.entitymanager;
import java.util.HashMap;
import java.util.Map;
import javax.persistence.EntityManager;
import org.apache.openjpa.persistence.EntityManagerImpl;
import org.apache.openjpa.persistence.datacache.common.apps.PObject;
import org.apache.openjpa.persistence.test.SingleEMFTestCase;
public class TestEntityManagerConfiguration extends SingleEMFTestCase {
public void setUp() throws Exception {
super.setUp(PObject.class);
}
public void testEMConfig001() {
Map propMap = new HashMap();
EntityManager em = emf.createEntityManager(propMap);
EntityManagerImpl eml = (EntityManagerImpl) em;
assertTrue(eml.getQuerySQLCache());
}
public void testEMConfig002() {
Map propMap = new HashMap();
propMap.put("openjpa.jdbc.QuerySQLCache", "true(EnableStatistics=true)");
EntityManager em = emf.createEntityManager(propMap);
EntityManagerImpl eml = (EntityManagerImpl) em;
assertTrue(eml.getQuerySQLCache());
}
public void testEMConfig003() {
Map propMap = new HashMap();
propMap.put("openjpa.jdbc.QuerySQLCache", "false");
EntityManager em = emf.createEntityManager(propMap);
EntityManagerImpl eml = (EntityManagerImpl) em;
assertFalse(eml.getQuerySQLCache());
}
public void testEMConfig004() {
Map propMap = new HashMap();
propMap.put("openjpa.jdbc.QuerySQLCache", "false(EnableStatistics=true)");
EntityManager em = emf.createEntityManager(propMap);
EntityManagerImpl eml = (EntityManagerImpl) em;
assertFalse(eml.getQuerySQLCache());
}
public void testEMConfig005() {
Map propMap = new HashMap();
propMap.put("openjpa.jdbc.QuerySQLCache", "notabool");
EntityManager em = emf.createEntityManager(propMap);
EntityManagerImpl eml = (EntityManagerImpl) em;
assertFalse(eml.getQuerySQLCache());
}
}

View File

@ -1854,7 +1854,12 @@ public class EntityManagerImpl
if ("null".equals(value)) {
return null;
} else {
return Strings.parse((String) value, targetType);
String val = (String) value;
int parenIndex = val.indexOf('(');
if (!String.class.equals(targetType) && (parenIndex > 0)) {
val = val.substring(0, parenIndex);
}
return Strings.parse(val, targetType);
}
} else if (value instanceof AutoDetachType) {
EnumSet<AutoDetachType> autoDetachFlags = EnumSet.noneOf(AutoDetachType.class);