You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@chemistry.apache.org by ju...@apache.org on 2011/04/01 13:59:47 UTC
svn commit: r1087664 [3/3] - in /chemistry/opencmis/trunk:
chemistry-opencmis-client/chemistry-opencmis-client-bindings/src/test/java/org/apache/chemistry/opencmis/client/bindings/framework/
chemistry-opencmis-server/chemistry-opencmis-server-jcr/ chem...
Added: chemistry/opencmis/trunk/chemistry-opencmis-server/chemistry-opencmis-server-jcr/src/test/java/org/apache/chemistry/opencmis/jcr/query/XPathBuilderTest.java
URL: http://svn.apache.org/viewvc/chemistry/opencmis/trunk/chemistry-opencmis-server/chemistry-opencmis-server-jcr/src/test/java/org/apache/chemistry/opencmis/jcr/query/XPathBuilderTest.java?rev=1087664&view=auto
==============================================================================
--- chemistry/opencmis/trunk/chemistry-opencmis-server/chemistry-opencmis-server-jcr/src/test/java/org/apache/chemistry/opencmis/jcr/query/XPathBuilderTest.java (added)
+++ chemistry/opencmis/trunk/chemistry-opencmis-server/chemistry-opencmis-server-jcr/src/test/java/org/apache/chemistry/opencmis/jcr/query/XPathBuilderTest.java Fri Apr 1 11:59:46 2011
@@ -0,0 +1,253 @@
+/*
+ * 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.chemistry.opencmis.jcr.query;
+
+import org.antlr.runtime.RecognitionException;
+import org.apache.chemistry.opencmis.commons.exceptions.CmisInvalidArgumentException;
+import org.apache.chemistry.opencmis.commons.exceptions.CmisNotSupportedException;
+import org.apache.chemistry.opencmis.jcr.JcrTypeManager;
+import org.apache.chemistry.opencmis.jcr.util.ISO8601;
+import org.apache.chemistry.opencmis.server.support.query.CalendarHelper;
+import org.apache.chemistry.opencmis.server.support.query.QueryObject;
+import org.apache.chemistry.opencmis.server.support.query.QueryUtil;
+import org.junit.Test;
+
+import java.io.IOException;
+import java.util.Arrays;
+import java.util.GregorianCalendar;
+import java.util.Iterator;
+import java.util.List;
+
+import static org.junit.Assert.*;
+
+public class XPathBuilderTest {
+
+ @Test
+ public void testValidQuery() throws IOException, RecognitionException {
+ check("select * from cmis:document",
+ null,
+ list(),
+ null);
+
+ check("select * from cmis:document where cmis:isLatestVersion='foo'",
+ "cmis:isLatestVersion = 'foo'",
+ list(),
+ null);
+
+ check("select * from cmis:document where cmis:isLatestVersion LIKE 'foo'",
+ "jcr:like(cmis:isLatestVersion, 'foo')",
+ list(),
+ null);
+
+ check("select * from cmis:document where cmis:isLatestVersion NOT LIKE 'foo'",
+ "not(jcr:like(cmis:isLatestVersion, 'foo'))",
+ list(),
+ null);
+
+ check("select * from cmis:document where cmis:isLatestVersion='foo' AND cmis:name<>'baz'",
+ "cmis:isLatestVersion = 'foo' and cmis:name != 'baz'",
+ list(),
+ null);
+
+ check("select * from cmis:document where NOT (cmis:isLatestVersion>'foo' OR cmis:name< 1.0)",
+ "not((cmis:isLatestVersion > 'foo' or cmis:name < 1.0))",
+ list(),
+ null);
+
+ check("select * from cmis:document where cmis:name = 'foo' or cmis:objectId = 'baz' and cmis:createdBy = 'bar'",
+ "(cmis:name = 'foo' or cmis:objectId = 'baz' and cmis:createdBy = 'bar')",
+ list(),
+ null);
+
+ check("select * from cmis:document where cmis:name = 'foo' and cmis:objectId = 'baz' or cmis:createdBy = 'bar'",
+ "(cmis:name = 'foo' and cmis:objectId = 'baz' or cmis:createdBy = 'bar')",
+ list(),
+ null);
+
+ check("select * from cmis:document where cmis:name = 'foo' and (cmis:objectId = 'baz' or cmis:createdBy = 'bar')",
+ "cmis:name = 'foo' and (cmis:objectId = 'baz' or cmis:createdBy = 'bar')",
+ list(),
+ null);
+
+ check("select * from cmis:document where IN_FOLDER('folderId')",
+ "folderId/",
+ list("folderId/"),
+ false);
+
+ check("select * from cmis:document where not(not(IN_FOLDER('folderId')))",
+ "true()",
+ list("folderId/"),
+ false);
+
+ check("select * from cmis:document where IN_TREE('folderId')",
+ "folderId//",
+ list("folderId//"),
+ false);
+
+ check("select * from cmis:document where not(not(IN_TREE('folderId')))",
+ "true()",
+ list("folderId//"),
+ false);
+
+ check("select * from cmis:document where IN_FOLDER('folderId') AND cmis:name <= 1",
+ "cmis:name <= 1",
+ list("folderId/"),
+ false);
+
+ check("select * from cmis:document where IN_TREE('folderId') AND cmis:name >= 'name' AND cmis:name = TRUE",
+ "cmis:name >= 'name' and cmis:name = true",
+ list("folderId//"),
+ false);
+
+ GregorianCalendar date = new GregorianCalendar();
+ check("select * from cmis:document where NOT(NOT IN_FOLDER('folderId') OR cmis:name = TIMESTAMP '" +
+ CalendarHelper.toString(date) + "')",
+ "not(cmis:name = xs:dateTime('" + ISO8601.format(date) + "'))",
+ list("folderId/"),
+ false);
+
+ check("select * from cmis:document where cmis:name IS NULL",
+ "cmis:name",
+ list(),
+ null);
+
+ check("select * from cmis:document where cmis:name IS NOT NULL",
+ "not(cmis:name)",
+ list(),
+ null);
+
+ check("select * from cmis:document where CONTAINS('foo')",
+ "jcr:contains(., 'foo')",
+ list(),
+ null);
+ }
+
+ @Test
+ public void testTooSpecificQuery() throws RecognitionException, IOException {
+ check("select * from cmis:document where NOT IN_FOLDER('folderId')",
+ "false()",
+ list("folderId/"),
+ true);
+
+ check("select * from cmis:document where NOT(NOT IN_FOLDER('folderId') AND cmis:name = 'name')",
+ "true()",
+ list("folderId/"),
+ null);
+
+ check("select * from cmis:document where IN_FOLDER('folderId') OR cmis:name = 'name'",
+ "true()",
+ list("folderId/"),
+ null);
+
+ check("select * from cmis:document where NOT(IN_FOLDER('folderId') AND cmis:name = 'name')",
+ "not(cmis:name = 'name')",
+ list("folderId/"),
+ true);
+
+ check("select * from cmis:document where IN_FOLDER('folder1Id') OR IN_TREE('folder2Id')",
+ "true()",
+ list("folder1Id/", "folder2Id//"),
+ false);
+
+ check("select * from cmis:document where IN_FOLDER('folder1Id') AND NOT IN_TREE('folder2Id')",
+ "false()",
+ list("folder1Id/", "folder2Id//"),
+ false);
+ }
+
+ @Test
+ public void testNotImplemented() throws IOException, RecognitionException {
+ try {
+ execute("select * from cmis:document where cmis:name in (1,2,3)");
+ fail();
+ }
+ catch (CmisNotSupportedException expected) {}
+
+ try {
+ execute("select * from cmis:document where 'foo' = ANY cmis:name");
+ fail();
+ }
+ catch (CmisNotSupportedException expected) {}
+ }
+
+ @Test
+ public void testInvalidQuery() throws IOException, RecognitionException {
+ try {
+ execute("");
+ fail();
+ }
+ catch (CmisInvalidArgumentException expected) {}
+
+ try {
+ execute("select * from cmis:something");
+ fail();
+ }
+ catch (CmisInvalidArgumentException expected) {}
+
+ try {
+ execute("select * from cmis:document WHERE");
+ fail();
+ }
+ catch (CmisInvalidArgumentException expected) {}
+
+ try {
+ execute("select * from cmis:document WHERE cmis:something = 'foo'");
+ fail();
+ }
+ catch (CmisInvalidArgumentException expected) {}
+ }
+
+ //------------------------------------------< private >---
+
+ private static List<String> list(String... elements) {
+ return Arrays.asList(elements);
+ }
+
+ private static XPathBuilder execute(String statement) throws RecognitionException, IOException {
+ QueryUtil queryUtil = new QueryUtil();
+ QueryObject queryObject = new QueryObject(new JcrTypeManager());
+ ParseTreeWalker<XPathBuilder> parseTreeWalker = new ParseTreeWalker<XPathBuilder>(new EvaluatorXPath());
+ queryUtil.traverseStatementAndCatchExc(statement, queryObject, parseTreeWalker);
+ return parseTreeWalker.getResult();
+ }
+
+ private static void check(String query, String result, List<String> folderPredicates, Boolean evaluation)
+ throws IOException, RecognitionException {
+
+ XPathBuilder queryBuilder = execute(query);
+ if (result == null) {
+ assertEquals(null, queryBuilder);
+ }
+ else {
+ assertEquals(result, queryBuilder.xPath());
+
+ Iterator<XPathBuilder> folderPredicatesBuilder = queryBuilder.folderPredicates().iterator();
+ for (String folderPredicate : folderPredicates) {
+ assertTrue(folderPredicatesBuilder.hasNext());
+ assertEquals(folderPredicate, folderPredicatesBuilder.next().xPath());
+ }
+ assertFalse(folderPredicatesBuilder.hasNext());
+
+ assertEquals(evaluation, queryBuilder.eval(false));
+ }
+
+ }
+
+}