/hazelcast/src/test/java/com/hazelcast/query/ParserTest.java
https://bitbucket.org/gabral6_gmailcom/hazelcast · Java · 170 lines · 130 code · 25 blank · 15 comment · 2 complexity · 323ea2fe45d8a4cd7511c7eed4736e9d MD5 · raw file
- /*
- * Copyright (c) 2008-2013, Hazelcast, Inc. All Rights Reserved.
- *
- * Licensed 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 com.hazelcast.query;
- import org.junit.Test;
- import org.junit.runner.RunWith;
- import java.security.SecureRandom;
- import java.util.Arrays;
- import java.util.List;
- import java.util.Random;
- import static junit.framework.Assert.*;
- @RunWith(com.hazelcast.util.RandomBlockJUnit4ClassRunner.class)
- public class ParserTest {
- Parser parser = new Parser();
- @Test
- public void parseEmpty() {
- List<String> l = parser.toPrefix("");
- assertEquals(Arrays.asList(), l);
- }
- @Test
- public void parseAEqB() {
- String s = "a = b";
- List<String> list = parser.toPrefix(s);
- assertEquals(Arrays.asList("a", "b", "="), list);
- }
- @Test
- public void parseAeqBandXgrtY() {
- assertTrue(parser.hasHigherPrecedence("=", "AND"));
- assertFalse(parser.hasHigherPrecedence("=", ">"));
- List<String> list = parser.toPrefix("a = b AND x > y");
- assertEquals(Arrays.asList("a", "b", "=", "x", "y", ">", "AND"), list);
- }
- @Test
- public void parseAeqBandOpenBsmlCorDgtEclose() {
- String s = "A = B AND ( B < C OR D > E )";
- List<String> list = parser.toPrefix(s);
- assertEquals(Arrays.asList("A", "B", "=", "B", "C", "<", "D", "E", ">", "OR", "AND"), list);
- }
- @Test
- public void testComplexStatement() {
- String s = "age > 5 AND ( ( ( active = true ) AND ( age = 23 ) ) OR age > 40 ) AND ( salary > 10 ) OR age = 10";
- List<String> list = parser.toPrefix(s);
- assertEquals(Arrays.asList("age", "5", ">", "active", "true", "=", "age", "23", "=", "AND", "age", "40", ">", "OR", "AND", "salary", "10", ">", "AND", "age", "10", "=", "OR"), list);
- }
- @Test
- public void testTwoInnerParanthesis() {
- String s = "a and b AND ( ( ( a > c AND b > d ) OR ( x = y ) ) ) OR t > u";
- List<String> list = parser.toPrefix(s);
- assertEquals(Arrays.asList("a", "b", "and", "a", "c", ">", "b", "d", ">", "AND", "x", "y", "=", "OR", "AND", "t", "u", ">", "OR"), list);
- }
- @Test
- public void testBetweenAnd() {
- String s = "a and b between 10 and 15";
- List<String> list = parser.toPrefix(s);
- assertEquals(Arrays.asList("a", "b", "10", "15", "between", "and"), list);
- }
- @Test
- public void testBetween() {
- String s = "b between 10 and 15";
- List<String> list = parser.toPrefix(s);
- assertEquals(Arrays.asList("b", "10", "15", "between"), list);
- }
- @Test
- public void testIn() {
- String s = "a and b OR c in ( 4, 5, 6 )";
- List<String> list = parser.toPrefix(s);
- assertEquals(Arrays.asList("a", "b", "and", "c", "4,5,6", "in", "OR"), list);
- }
- @Test
- public void testNot() {
- String s = "a and not(b) OR c not in ( 4, 5, 6 )";
- List<String> list = parser.toPrefix(s);
- assertEquals(Arrays.asList("a", "b", "not", "and", "c", "4,5,6", "in", "not", "OR"), list);
- }
- @Test
- public void testNotEqual() {
- String s = "b != 30";
- List<String> list = parser.toPrefix(s);
- assertEquals(Arrays.asList("b", "30", "!="), list);
- }
- @Test
- public void split1() {
- List<String> tokens = parser.split("a and b");
- assertEquals(Arrays.asList("a", "and", "b"), tokens);
- }
- @Test
- public void split2() {
- List<String> tokens = parser.split("(a and b)");
- assertEquals(Arrays.asList("(", "a", "and", "b", ")"), tokens);
- }
- @Test
- public void split3() {
- List<String> tokens = parser.split("((a and b))");
- assertEquals(Arrays.asList("(", "(", "a", "and", "b", ")", ")"), tokens);
- }
- @Test
- public void split4() {
- List<String> tokens = parser.split("a and b AND(((a>c AND b> d) OR (x = y )) ) OR t>u");
- assertEquals(Arrays.asList("a", "and", "b", "AND", "(", "(", "(", "a", ">", "c", "AND", "b", ">", "d", ")", "OR", "(", "x", "=", "y", ")", ")", ")", "OR", "t", ">", "u"), tokens);
- }
- @Test
- public void split5() {
- List<String> tokens = parser.split("a and b AND(((a>=c AND b> d) OR (x <> y )) ) OR t>u");
- assertEquals(Arrays.asList("a", "and", "b", "AND", "(", "(", "(", "a", ">=", "c", "AND", "b", ">", "d", ")", "OR", "(", "x", "<>", "y", ")", ")", ")", "OR", "t", ">", "u"), tokens);
- }
- @Test
- public void testComplexStatementWithGreaterAndEqueals() {
- String s = "age>=5 AND ((( active = true ) AND (age = 23 )) OR age > 40) AND( salary>10 ) OR age=10";
- List<String> list = parser.toPrefix(s);
- assertEquals(Arrays.asList("age", "5", ">=", "active", "true", "=", "age", "23", "=", "AND", "age", "40", ">", "OR", "AND", "salary", "10", ">", "AND", "age", "10", "=", "OR"), list);
- }
- @Test(expected = NullPointerException.class)
- public void parserShouldNotAcceptNull() {
- parser.toPrefix(null);
- fail();
- }
- @Test
- public void parserShouldThrowOnInvalidInput() {
- parser.toPrefix(")");
- }
- @Test
- public void shouldNotThrowOnRandomInput() {
- Random random = new SecureRandom();
- StringBuilder stringBuilder = new StringBuilder();
- for (int i = 0; i < 1000; i++) {
- stringBuilder.setLength(0);
- for (int n = 0; n < 1000; n++) {
- stringBuilder.append((char) (random.nextInt() & 0xFFFF));
- }
- parser.toPrefix(stringBuilder.toString());
- }
- }
- }