Author: pcl
Date: Thu Mar  8 01:34:25 2007
New Revision: 515986

URL: http://svn.apache.org/viewvc?view=rev&rev=515986
Log:
OPENJPA-46: TRUE and FALSE should be case-insensitive in JPQL

Added:
    
incubator/openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/persistence/simple/TestCaseInsensitiveKeywordsInJPQL.java
   (with props)
Modified:
    
incubator/openjpa/trunk/openjpa-kernel/src/main/jjtree/org/apache/openjpa/kernel/jpql/JPQL.jjt

Modified: 
incubator/openjpa/trunk/openjpa-kernel/src/main/jjtree/org/apache/openjpa/kernel/jpql/JPQL.jjt
URL: 
http://svn.apache.org/viewvc/incubator/openjpa/trunk/openjpa-kernel/src/main/jjtree/org/apache/openjpa/kernel/jpql/JPQL.jjt?view=diff&rev=515986&r1=515985&r2=515986
==============================================================================
--- 
incubator/openjpa/trunk/openjpa-kernel/src/main/jjtree/org/apache/openjpa/kernel/jpql/JPQL.jjt
 (original)
+++ 
incubator/openjpa/trunk/openjpa-kernel/src/main/jjtree/org/apache/openjpa/kernel/jpql/JPQL.jjt
 Thu Mar  8 01:34:25 2007
@@ -248,7 +248,6 @@
                | ((["0"-"9"])+ ".") (<EXPONENT>)? (["f","F","d","D"])?
                | ((["0"-"9"])+) (<EXPONENT>) (["f","F","d","D"])?
                | ((["0"-"9"])+) (<EXPONENT>)? (["f","F","d","D"])?) >
-       | < BOOLEAN_LITERAL: "TRUE" | "FALSE" | "true" | "false" >
        | < #EXPONENT: ["e","E"] (["+","-"])? (["0"-"9"])+ >
        | < STRING_LITERAL: "'"
          (("''" | ~["'"])
@@ -275,6 +274,11 @@
          )
          "'"
        >
+}
+
+TOKEN [ IGNORE_CASE ]: /* boolean literals can be case-insensitive */
+{
+       < BOOLEAN_LITERAL: "TRUE" | "FALSE" >
 }
 
 /* From the Java 1.0.2 specification */

Added: 
incubator/openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/persistence/simple/TestCaseInsensitiveKeywordsInJPQL.java
URL: 
http://svn.apache.org/viewvc/incubator/openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/persistence/simple/TestCaseInsensitiveKeywordsInJPQL.java?view=auto&rev=515986
==============================================================================
--- 
incubator/openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/persistence/simple/TestCaseInsensitiveKeywordsInJPQL.java
 (added)
+++ 
incubator/openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/persistence/simple/TestCaseInsensitiveKeywordsInJPQL.java
 Thu Mar  8 01:34:25 2007
@@ -0,0 +1,41 @@
+package org.apache.openjpa.persistence.simple;
+
+import javax.persistence.Query;
+import javax.persistence.EntityManager;
+
+import org.apache.openjpa.persistence.test.PersistenceTestCase;
+
+public class TestCaseInsensitiveKeywordsInJPQL
+    extends PersistenceTestCase {
+
+    public Class[] getEntityTypes() {
+        return new Class[] { AllFieldTypes.class };
+    }
+
+    public void testCaseInsensitiveBooleans() {
+        EntityManager em = emf.createEntityManager();
+        em.getTransaction().begin();
+
+        AllFieldTypes aft = new AllFieldTypes();
+        em.persist(aft);
+        aft.setBooleanField(true);
+
+        aft = new AllFieldTypes();
+        em.persist(aft);
+        aft.setBooleanField(false);
+
+        em.flush();
+
+        Query q = em.createQuery(
+            "select count(o) from AllFieldTypes o where o.booleanField = 
TrUe");
+        Number n = (Number) q.getSingleResult();
+        assertEquals(1, n.intValue());
+
+        q = em.createQuery("select count(o) from AllFieldTypes o "
+            + "where o.booleanField = falSe");
+        n = (Number) q.getSingleResult();
+        assertEquals(1, n.intValue());
+        
+        em.getTransaction().rollback();
+    }
+}
\ No newline at end of file

Propchange: 
incubator/openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/persistence/simple/TestCaseInsensitiveKeywordsInJPQL.java
------------------------------------------------------------------------------
    svn:eol-style = native


Reply via email to