/**
* Copyright (c) 2000-present Liferay, Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation; either version 2.1 of the License, or (at your option)
* any later version.
*
* This library is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
* details.
*/
package com.liferay.poshi.runner.pql;
import java.util.Properties;
import java.util.Set;
import java.util.TreeSet;
import junit.framework.TestCase;
import org.junit.Test;
/**
* @author Michael Hashimoto
*/
public class PQLQueryTest extends TestCase {
@Test
public void testGetPQLResultComparativeOperator() throws Exception {
Properties properties = new Properties();
properties.setProperty("component.names", "Blogs,Message Boards,WEM");
properties.setProperty("portal.smoke", "true");
properties.setProperty("priority", "5");
Set<String> queries = new TreeSet<>();
queries.add("component.names !~ 'Journal'");
queries.add("component.names ~ 'Message Boards'");
queries.add("portal.smoke != false");
queries.add("portal.smoke == true");
queries.add("priority < 6");
queries.add("priority <= 5");
queries.add("priority > 4");
queries.add("priority >= 5");
queries.add("priority < 5.1");
queries.add("priority <= 5.1");
queries.add("priority > 4.1");
queries.add("priority >= 4.9");
for (String query : queries) {
_validateGetPQLResult(query, Boolean.TRUE, properties);
}
queries = new TreeSet<>();
queries.add("component.names !~ 'Message Boards'");
queries.add("component.names ~ 'Journal'");
queries.add("portal.smoke != true");
queries.add("portal.smoke == false");
queries.add("priority < 4");
queries.add("priority <= 4");
queries.add("priority > 6");
queries.add("priority >= 6");
queries.add("priority < 4.1");
queries.add("priority <= 4.9");
queries.add("priority > 5.1");
queries.add("priority >= 5.1");
for (String query : queries) {
_validateGetPQLResult(query, Boolean.FALSE, properties);
}
}
@Test
public void testGetPQLResultComparativeOperatorError() throws Exception {
Properties properties = new Properties();
properties.setProperty("component.names", "Blogs,Message Boards,WEM");
properties.setProperty("portal.smoke", "true");
properties.setProperty("priority", "5");
_validateGetPQLResultError(
"true ==", "Invalid query: true ==", properties);
_validateGetPQLResultError(
"false ==", "Invalid query: false ==", properties);
_validateGetPQLResultError(
"== true", "Invalid query: == true", properties);
_validateGetPQLResultError(
"== false", "Invalid query: == false", properties);
}
@Test
public void testGetPQLResultConditionalOperator() throws Exception {
Properties properties = new Properties();
properties.setProperty("component.names", "Blogs,Message Boards,WEM");
properties.setProperty("portal.smoke", "true");
properties.setProperty("priority", "5");
Set<String> queries = new TreeSet<>();
queries.add("portal.smoke == true AND portal.smoke != false");
queries.add("portal.smoke == true OR portal.smoke == false");
queries.add("false OR true");
queries.add("true AND true");
queries.add("true OR false");
queries.add("true OR true");
for (String query : queries) {
_validateGetPQLResult(query, Boolean.TRUE, properties);
}
queries = new TreeSet<>();
queries.add("portal.smoke != true OR portal.smoke == false");
queries.add("portal.smoke == true AND portal.smoke == false");
queries.add("false AND false");
queries.add("false AND true");
queries.add("false OR false");
queries.add("true AND false");
for (String query : queries) {
_validateGetPQLResult(query, Boolean.FALSE, properties);
}
}
@Test
public void testGetPQLResultConditionalOperatorError() throws Exception {
Properties properties = new Properties();
properties.setProperty("component.names", "Blogs,Message Boards,WEM");
properties.setProperty("portal.smoke", "true");
properties.setProperty("priority", "5");
_validateGetPQLResultError(
"AND true == true", "Invalid query: AND true == true", properties);
_validateGetPQLResultError(
"true == true AND", "Invalid query: true == true AND", properties);
_validateGetPQLResultError(
"OR true == true", "Invalid query: OR true == true", properties);
_validateGetPQLResultError(
"true == true OR", "Invalid query: true == true OR", properties);
_validateGetPQLResultError(
"true == true AND AND false == false",
"Invalid value: AND false == false", properties);
_validateGetPQLResultError(
"(true == true) AND", "Invalid query: (true == true) AND",
properties);
_validateGetPQLResultError(
"(true == true) OR", "Invalid query: (true == true) OR",
properties);
}
@Test
public void testGetPQLResultModifier() throws Exception {
Properties properties = new Properties();
properties.setProperty("portal.smoke", "true");
_validateGetPQLResult(
"NOT portal.smoke == true", Boolean.FALSE, properties);
_validateGetPQLResult(
"NOT portal.smoke == false", Boolean.TRUE, properties);
}
@Test
public void testGetPQLResultModifierError() throws Exception {
_validateGetPQLResultError(
"portal.smoke == true NOT", "Invalid value: true NOT");
_validateGetPQLResultError(
"portal.smoke == false NOT", "Invalid value: false NOT");
_validateGetPQLResultError(
"portal.smoke == true NOT AND true", "Invalid value: true NOT");
_validateGetPQLResultError(
"portal.smoke == false NOT AND true", "Invalid value: false NOT");
}
@Test
public void testGetPQLResultParenthesis() throws Exception {
Properties properties = new Properties();
properties.setProperty("component.names", "Blogs,Message Boards,WEM");
properties.setProperty("portal.smoke", "true");
properties.setProperty("priority", "5");
Set<String> queries = new TreeSet<>();
queries.add("(portal.smoke == true AND portal.smoke == false) OR true");
queries.add("(portal.smoke == true OR portal.smoke == false) AND true");
queries.add("(true AND false) OR true");
queries.add("(true AND false) OR true");
queries.add("(true AND true) OR false");
queries.add("(true OR false) AND true");
for (String query : queries) {
_validateGetPQLResult(query, Boolean.TRUE, properties);
}
queries = new TreeSet<>();
queries.add("(portal.smoke != true AND portal.smoke == true) OR false");
queries.add("(portal.smoke != true OR portal.smoke == false) AND true");
queries.add("(false AND true) OR false");
queries.add("(false OR false) AND false");
queries.add("(false OR false) AND true");
queries.add("(false OR true) AND false");
for (String query : queries) {
_validateGetPQLResult(query, Boolean.FALSE, properties);
}
}
private static void _validateGetPQLResult(
String pql, Object expectedPQLResult, Properties properties)
throws Exception {
PQLQuery pqlQuery = new PQLQuery(pql);
Object actualPQLResult = pqlQuery.getPQLResult(properties);
if (!actualPQLResult.equals(expectedPQLResult)) {
StringBuilder sb = new StringBuilder();
sb.append("Mismatched PQL result within the following PQL:\n");
sb.append(pql);
sb.append("\n* Actual: ");
sb.append(actualPQLResult);
sb.append("\n* Expected: ");
sb.append(expectedPQLResult);
throw new Exception(sb.toString());
}
}
private static void _validateGetPQLResultError(
String pql, String expectedError)
throws Exception {
_validateGetPQLResultError(pql, expectedError, new Properties());
}
private static void _validateGetPQLResultError(
String pql, String expectedError, Properties properties)
throws Exception {
String actualError = null;
try {
PQLQuery pqlQuery = new PQLQuery(pql);
pqlQuery.getPQLResult(properties);
}
catch (Exception e) {
actualError = e.getMessage();
if (!actualError.equals(expectedError)) {
StringBuilder sb = new StringBuilder();
sb.append("Mismatched error within the following PQL:\n");
sb.append(pql);
sb.append("\n* Actual: ");
sb.append(actualError);
sb.append("\n* Expected: ");
sb.append(expectedError);
throw new Exception(sb.toString(), e);
}
}
finally {
if (actualError == null) {
throw new Exception(
"No error thrown for the following PQL: " + pql);
}
}
}
}