org.apache.jackrabbit.test.api.query.PredicatesTest Maven / Gradle / Ivy
/*
* 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.jackrabbit.test.api.query;
import javax.jcr.query.InvalidQueryException;
import javax.jcr.query.QueryManager;
import javax.jcr.RepositoryException;
import javax.jcr.Session;
/**
* Tests if queries with predicates are accepted. Test cases in this class only
* perform tests that check if the QueryManager accepts the query, but the tests
* will not execute the query and check its results.
*
*/
public class PredicatesTest extends AbstractQueryTest {
/**
* the node type of the root node
*/
private String nodeTypeName;
/**
* A read-only session
*/
private Session session;
/**
* the query manager of the session
*/
private QueryManager qm;
/**
* Sets up the test cases
*/
protected void setUp() throws Exception {
isReadOnly = true;
super.setUp();
session = getHelper().getReadOnlySession();
testRootNode = session.getRootNode().getNode(testPath);
nodeTypeName = session.getRootNode().getPrimaryNodeType().getName();
qm = session.getWorkspace().getQueryManager();
}
/**
* Releases the session acquired in setUp().
*/
protected void tearDown() throws Exception {
if (session != null) {
session.logout();
session = null;
}
qm = null;
super.tearDown();
}
/**
* Verifies that the value of a property can be searched
*
* @throws RepositoryException
*/
public void testEquality() throws RepositoryException {
String stmt =
xpathRoot + "/*[@" + jcrPrimaryType + "='" + nodeTypeName + "']";
try {
qm.createQuery(stmt, qsXPATH);
} catch (InvalidQueryException e) {
fail("invalid statement syntax for '" + stmt + "'");
}
}
/**
* Verifies that the or operator is accepted for properties's values
*
* @throws RepositoryException
*/
public void testCombinedOr() throws RepositoryException {
String stmt =
xpathRoot + "/*[@" + jcrPrimaryType + "='" + nodeTypeName
+ "' or @" + jcrPrimaryType + "='" + ntBase + "']";
try {
qm.createQuery(stmt, qsXPATH);
} catch (InvalidQueryException e) {
fail("invalid statement syntax for '" + stmt + "'");
}
}
/**
* Verifies that the or operator is accepted for a property name
*
* @throws RepositoryException
*/
public void testOr() throws RepositoryException {
String stmt =
xpathRoot + "/*[@" + jcrPrimaryType + " or @" + jcrMixinTypes + "]";
try {
qm.createQuery(stmt, qsXPATH);
} catch (InvalidQueryException e) {
fail("invalid statement syntax for '" + stmt + "'");
}
}
/**
* Verifies that the and operator is accepted for a property name
*
* @throws RepositoryException
*/
public void testAnd() throws RepositoryException {
String stmt =
xpathRoot + "/*[@" + jcrPrimaryType + " and @" + jcrMixinTypes + "]";
try {
qm.createQuery(stmt, qsXPATH);
} catch (InvalidQueryException e) {
fail("invalid statement syntax for '" + stmt + "'");
}
}
/**
* Verifies that the and operator is accepted for properties's values
*
* @throws RepositoryException
*/
public void testCombinedAnd() throws RepositoryException {
String stmt =
xpathRoot + "/*[@" + jcrPrimaryType + "='" + nodeTypeName
+ "' and @" + jcrPrimaryType + "='" + ntBase + "']";
try {
qm.createQuery(stmt, qsXPATH);
} catch (InvalidQueryException e) {
fail("invalid statement syntax for '" + stmt + "'");
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy