|
Apache CXF example source code file (FiqlParserTest.java)
This example Apache CXF source code file (FiqlParserTest.java) is included in the DevDaily.com
"Java Source Code
Warehouse" project. The intent of this project is to help you "Learn Java by Example" TM.
The Apache CXF FiqlParserTest.java source code
/**
* 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.cxf.jaxrs.ext.search;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import javax.xml.datatype.DatatypeFactory;
import org.junit.Assert;
import org.junit.Ignore;
import org.junit.Test;
public class FiqlParserTest extends Assert {
private FiqlParser<Condition> parser = new FiqlParser(Condition.class);
@Test(expected = FiqlParseException.class)
public void testCompareWrongComparator() throws FiqlParseException {
parser.parse("name>booba");
}
@Test(expected = FiqlParseException.class)
public void testCompareMissingName() throws FiqlParseException {
parser.parse("==30");
}
@Test(expected = FiqlParseException.class)
public void testCompareMissingValue() throws FiqlParseException {
parser.parse("name=gt=");
}
@Test
public void testCompareValueTextSpaces() throws FiqlParseException {
parser.parse("name=gt=some text");
}
@Test(expected = FiqlParseException.class)
public void testCompareNameTextSpaces() throws FiqlParseException {
parser.parse("some name=gt=text");
}
@Test(expected = FiqlParseException.class)
public void testDanglingOperator() throws FiqlParseException {
parser.parse("name==a;(level==10;),");
}
@Test
public void testMultilevelExpression() throws FiqlParseException {
parser.parse("name==a;(level==10,(name!=b;name!=c;(level=gt=10)))");
}
@Test
public void testMultilevelExpression2() throws FiqlParseException {
parser.parse("((name==a;level==10),name!=b;name!=c);level=gt=10");
}
@Test
public void testRedundantBrackets() throws FiqlParseException {
parser.parse("name==a;((((level==10))))");
}
@Test
public void testAndOfOrs() throws FiqlParseException {
parser.parse("(name==a,name==b);(level=gt=0,level=lt=10)");
}
@Test
public void testOrOfAnds() throws FiqlParseException {
parser.parse("(name==a;name==b),(level=gt=0;level=lt=10)");
}
@Test(expected = FiqlParseException.class)
public void testUnmatchedBracket() throws FiqlParseException {
parser.parse("name==a;(name!=b;(level==10,(name!=b))");
}
@Test(expected = FiqlParseException.class)
public void testUnmatchedBracket2() throws FiqlParseException {
parser.parse("name==bbb;))()level==111");
}
@Test(expected = FiqlParseException.class)
public void testMissingComparison() throws FiqlParseException {
parser.parse("name==bbb;,level==111");
}
@Test(expected = FiqlParseException.class)
public void testSetterMissing() throws FiqlParseException {
parser.parse("noSuchSetter==xxx");
}
@Test(expected = FiqlParseException.class)
public void testSetterWrongType() throws FiqlParseException {
parser.parse("exception==text");
}
@Test
public void testSetterNumericText() throws FiqlParseException {
parser.parse("name==10");
}
@Test(expected = IllegalArgumentException.class)
public void testMismatchedAccessorTypes() throws FiqlParseException {
new FiqlParser<MismatchedTypes>(MismatchedTypes.class);
}
@Test
public void testParseName() throws FiqlParseException {
SearchCondition<Condition> filter = parser.parse("name==king");
assertTrue(filter.isMet(new Condition("king", 10, new Date())));
assertTrue(filter.isMet(new Condition("king", 0, null)));
assertFalse(filter.isMet(new Condition("diamond", 10, new Date())));
assertFalse(filter.isMet(new Condition("diamond", 0, null)));
}
@Test
public void testParseLevel() throws FiqlParseException {
SearchCondition<Condition> filter = parser.parse("level=gt=10");
assertTrue(filter.isMet(new Condition("whatever", 15, new Date())));
assertTrue(filter.isMet(new Condition(null, 15, null)));
assertFalse(filter.isMet(new Condition("blah", 5, new Date())));
assertFalse(filter.isMet(new Condition("foobar", 0, null)));
}
@Test
public void testParseDate() throws FiqlParseException, ParseException {
SearchCondition<Condition> filter = parser.parse("time=le=2010-03-11T18:00:00.000+00:00");
DateFormat df = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSZ");
assertTrue(filter.isMet(new Condition("whatever", 15, df.parse("2010-03-11T18:00:00.000+0000"))));
assertTrue(filter.isMet(new Condition(null, null, df.parse("2010-03-10T22:22:00.000+0000"))));
assertFalse(filter.isMet(new Condition("blah", null, df.parse("2010-03-12T00:00:00.000+0000"))));
assertFalse(filter.isMet(new Condition(null, 123, df.parse("2010-03-12T00:00:00.000+0000"))));
}
@Test
public void testParseDateDuration() throws Exception {
SearchCondition<Condition> filter = parser.parse("time=gt=-PT1M");
Date now = new Date();
Date tenMinutesAgo = new Date();
DatatypeFactory.newInstance().newDuration("-PT10M").addTo(tenMinutesAgo);
assertTrue(filter.isMet(new Condition(null, null, now)));
assertFalse(filter.isMet(new Condition(null, null, tenMinutesAgo)));
}
@Test
public void testParseComplex1() throws FiqlParseException {
SearchCondition<Condition> filter = parser.parse("name==ami*;level=gt=10");
assertTrue(filter.isMet(new Condition("amichalec", 12, new Date())));
assertTrue(filter.isMet(new Condition("ami", 12, new Date())));
assertFalse(filter.isMet(new Condition("ami", 8, null)));
assertFalse(filter.isMet(new Condition("am", 20, null)));
}
@Test
public void testSQL1() throws FiqlParseException {
SearchCondition<Condition> filter = parser.parse("name==ami*;level=gt=10");
String sql = filter.toSQL("table");
assertTrue("SELECT * FROM table WHERE name LIKE 'ami%' AND level > '10'".equals(sql)
|| "SELECT * FROM table WHERE level > '10' AND name LIKE 'ami%'".equals(sql));
}
@Test
public void testParseComplex2() throws FiqlParseException {
SearchCondition<Condition> filter = parser.parse("name==ami*,level=gt=10");
assertTrue(filter.isMet(new Condition("ami", 0, new Date())));
assertTrue(filter.isMet(new Condition("foo", 20, null)));
assertFalse(filter.isMet(new Condition("foo", 0, null)));
}
@Test
public void testSQL2() throws FiqlParseException {
SearchCondition<Condition> filter = parser.parse("name==ami*,level=gt=10");
String sql = filter.toSQL("table");
assertTrue("SELECT * FROM table WHERE (name LIKE 'ami%') OR (level > '10')".equals(sql)
|| "SELECT * FROM table WHERE (level > '10') OR (name LIKE 'ami%')".equals(sql));
}
@Test
public void testParseComplex3() throws FiqlParseException {
SearchCondition<Condition> filter = parser.parse("name==foo*;(name!=*bar,level=gt=10)");
assertTrue(filter.isMet(new Condition("fooooo", 0, null)));
assertTrue(filter.isMet(new Condition("fooooobar", 20, null)));
assertFalse(filter.isMet(new Condition("fooobar", 0, null)));
assertFalse(filter.isMet(new Condition("bar", 20, null)));
}
@Test
public void testSQL3() throws FiqlParseException {
SearchCondition<Condition> filter = parser.parse("name==foo*;(name!=*bar,level=gt=10)");
String sql = filter.toSQL("table");
assertTrue(("SELECT * FROM table WHERE (name LIKE 'foo%') AND ((name NOT LIKE '%bar') "
+ "OR (level > '10'))").equals(sql)
|| ("SELECT * FROM table WHERE (name LIKE 'foo%') AND "
+ "((level > '10') OR (name NOT LIKE '%bar'))").equals(sql));
}
@Test
public void testSQL4() throws FiqlParseException {
SearchCondition<Condition> filter = parser.parse("(name==test,level==18);(name==test1,level!=19)");
String sql = filter.toSQL("table");
assertTrue(("SELECT * FROM table WHERE ((name = 'test') OR (level = '18'))"
+ " AND ((name = 'test1') OR (level <> '19'))").equals(sql)
|| ("SELECT * FROM table WHERE ((name = 'test1') OR (level <> '19'))"
+ " AND ((name = 'test') OR (level = '18'))").equals(sql));
}
@Test
public void testParseComplex4() throws FiqlParseException {
SearchCondition<Condition> filter = parser.parse("name==foo*;name!=*bar,level=gt=10");
assertTrue(filter.isMet(new Condition("zonk", 20, null)));
assertTrue(filter.isMet(new Condition("foobaz", 0, null)));
assertTrue(filter.isMet(new Condition("foobar", 20, null)));
assertFalse(filter.isMet(new Condition("fooxxxbar", 0, null)));
}
@Ignore
static class Condition {
private String name;
private Integer level;
private Date time;
public Condition() {
}
public Condition(String name, Integer level, Date time) {
this.name = name;
this.level = level;
this.time = time;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getLevel() {
return level;
}
public void setLevel(int level) {
this.level = level;
}
public Date getTime() {
return time;
}
public void setTime(Date time) {
this.time = time;
}
public void setException(Exception ex) {
// do nothing
}
}
// TODO refactor to Beanspector unit tests
@Ignore
static class MismatchedTypes {
public Date getFoo() {
return null;
}
public void setFoo(String val) {
}
}
}
Other Apache CXF examples (source code examples)
Here is a short list of links related to this Apache CXF FiqlParserTest.java source code file:
|