Select Git revision
TestJDBCTranslator.java
-
Grégory Mantelet authored
negative values). The implemented operators precedence is: ``` [~-](unary) >> [*/] >> [+-] >> [^&|] ``` _**Example:** `~3-1|2*5^6/1+2 = ((~3)-1)|((2*5)^((6/1)+2)) = -5`_
Grégory Mantelet authorednegative values). The implemented operators precedence is: ``` [~-](unary) >> [*/] >> [+-] >> [^&|] ``` _**Example:** `~3-1|2*5^6/1+2 = ((~3)-1)|((2*5)^((6/1)+2)) = -5`_
TestJDBCTranslator.java 8.62 KiB
package adql.translator;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.fail;
import org.junit.Before;
import org.junit.Test;
import adql.db.DBType;
import adql.db.FunctionDef;
import adql.db.STCS.Region;
import adql.parser.ADQLParser;
import adql.parser.ADQLParser.ADQLVersion;
import adql.parser.grammar.ParseException;
import adql.query.ADQLQuery;
import adql.query.IdentifierField;
import adql.query.operand.ADQLColumn;
import adql.query.operand.ADQLOperand;
import adql.query.operand.NumericConstant;
import adql.query.operand.Operation;
import adql.query.operand.StringConstant;
import adql.query.operand.function.DefaultUDF;
import adql.query.operand.function.geometry.AreaFunction;
import adql.query.operand.function.geometry.BoxFunction;
import adql.query.operand.function.geometry.CentroidFunction;
import adql.query.operand.function.geometry.CircleFunction;
import adql.query.operand.function.geometry.ContainsFunction;
import adql.query.operand.function.geometry.DistanceFunction;
import adql.query.operand.function.geometry.ExtractCoord;
import adql.query.operand.function.geometry.ExtractCoordSys;
import adql.query.operand.function.geometry.IntersectsFunction;
import adql.query.operand.function.geometry.PointFunction;
import adql.query.operand.function.geometry.PolygonFunction;
import adql.query.operand.function.geometry.RegionFunction;
public class TestJDBCTranslator {
@Before
public void setUp() throws Exception {
}
@Test
public void testTranslateComplexNumericOperation() {
JDBCTranslator tr = new AJDBCTranslator();
ADQLParser parser = new ADQLParser(ADQLVersion.V2_1);
// CASE: Check the applied operators precedence while translating:
try {
ADQLQuery query = parser.parseQuery("SELECT ~3-1|2*5^6/1+2 FROM foo");
assertEquals("SELECT ~3-1|2*5^6/1+2\nFROM foo", query.toADQL());
assertEquals(Operation.class, query.getSelect().get(0).getOperand().getClass());
assertEquals("(((~3)-1)|((2*5)^((6/1)+2)))", tr.translate(query.getSelect().get(0).getOperand()));
} catch(Exception ex) {
ex.printStackTrace();
fail("Unexpected error with valid operations! (see console for more details)");
}
}
@Test
public void testTranslateOffset() {
JDBCTranslator tr = new AJDBCTranslator();
ADQLParser parser = new ADQLParser(ADQLVersion.V2_1);
try {
// CASE: Only OFFSET
assertEquals("SELECT *\nFROM foo\nOFFSET 10", tr.translate(parser.parseQuery("Select * From foo OffSet 10")));
// CASE: Only OFFSET = 0
assertEquals("SELECT *\nFROM foo\nOFFSET 0", tr.translate(parser.parseQuery("Select * From foo OffSet 0")));
// CASE: TOP + OFFSET
assertEquals("SELECT *\nFROM foo\nLIMIT 5\nOFFSET 10", tr.translate(parser.parseQuery("Select Top 5 * From foo OffSet 10")));
// CASE: TOP + ORDER BY + OFFSET
assertEquals("SELECT *\nFROM foo\nORDER BY id ASC\nLIMIT 5\nOFFSET 10", tr.translate(parser.parseQuery("Select Top 5 * From foo Order By id Asc OffSet 10")));
} catch(ParseException pe) {
pe.printStackTrace(System.err);
fail("Unexpected failed query parsing! (see console for more details)");
} catch(Exception e) {
e.printStackTrace(System.err);
fail("There should have been no problem to translate a query with offset into SQL.");
}
}
@Test
public void testTranslateHexadecimal() {
JDBCTranslator tr = new AJDBCTranslator();
ADQLParser parser = new ADQLParser(ADQLVersion.V2_1);
try {
assertEquals("SELECT 15 AS \"0xF\"\nFROM foo", tr.translate(parser.parseQuery("Select 0xF From foo")));
assertEquals("SELECT (15*2) AS \"MULT\"\nFROM foo", tr.translate(parser.parseQuery("Select 0xF*2 From foo")));
assertEquals("SELECT -15 AS \"NEG_0xF\"\nFROM foo", tr.translate(parser.parseQuery("Select -0xF From foo")));
} catch(ParseException pe) {
pe.printStackTrace(System.err);
fail("Unexpected failed query parsing! (see console for more details)");
} catch(Exception e) {
e.printStackTrace(System.err);
fail("There should have been no problem to translate a query with hexadecimal values into SQL.");
}
}
@Test
public void testTranslateStringConstant() {
JDBCTranslator tr = new AJDBCTranslator();
/* Ensure the translation from ADQL to SQL of strings is correct ;
* particularly, ' should be escaped otherwise it would mean the end of
* a string in SQL (the way to escape a such character is by doubling
* the character '): */
try{
assertEquals("'SQL''s translation'", tr.translate(new StringConstant("SQL's translation")));
} catch(TranslationException e) {
e.printStackTrace(System.err);
fail("There should have been no problem to translate a StringConstant object into SQL.");
}
}
@Test
public void testTranslateUserDefinedFunction() {
JDBCTranslator tr = new AJDBCTranslator();
DefaultUDF udf = new DefaultUDF("split", new ADQLOperand[]{ new ADQLColumn("values"), new StringConstant(";") });
// TEST: no FunctionDef, so no translation pattern => just return the ADQL
try {
assertEquals("split(values, ';')", tr.translate(udf));
} catch(TranslationException e) {
e.printStackTrace(System.err);
fail("There should have been no problem to translate this UDF as in ADQL.");
}
// TEST: a FunctionDef with no translation pattern => just return the ADQL
try {
udf.setDefinition(FunctionDef.parse("split(str VARCHAR, sep VARCHAR) -> VARCHAR"));
assertEquals("split(values, ';')", tr.translate(udf));
} catch(TranslationException e) {
e.printStackTrace(System.err);
fail("There should have been no problem to translate this UDF as in ADQL.");
} catch(Exception e) {
e.printStackTrace(System.err);
fail("There should have been no problem preparing this test.");
}
// TEST: a FunctionDef with a translation pattern but no argument reference => the pattern should be returned as such
try {
udf.getDefinition().setTranslationPattern("foobar");
assertEquals("foobar", tr.translate(udf));
} catch(TranslationException e) {
e.printStackTrace(System.err);
fail("There should have been no problem to translate this UDF as in ADQL.");
} catch(Exception e) {
e.printStackTrace(System.err);
fail("There should have been no problem preparing this test.");
}
// TEST: a FunctionDef with a translation pattern and with argument reference => the pattern should be applied
try {
udf.getDefinition().setTranslationPattern("splitWith($2, $1)");
assertEquals("splitWith(" + tr.translate(udf.getParameter(1)) + ", " + tr.translate(udf.getParameter(0)) + ")", tr.translate(udf));
} catch(TranslationException e) {
e.printStackTrace(System.err);
fail("There should have been no problem to translate this UDF as in ADQL.");
} catch(Exception e) {
e.printStackTrace(System.err);
fail("There should have been no problem preparing this test.");
}
}
public final static class AJDBCTranslator extends JDBCTranslator {
@Override
public String translate(ExtractCoord extractCoord) throws TranslationException {
return null;
}
@Override
public String translate(ExtractCoordSys extractCoordSys) throws TranslationException {
return null;
}
@Override
public String translate(AreaFunction areaFunction) throws TranslationException {
return null;
}
@Override
public String translate(CentroidFunction centroidFunction) throws TranslationException {
return null;
}
@Override
public String translate(DistanceFunction fct) throws TranslationException {
return null;
}
@Override
public String translate(ContainsFunction fct) throws TranslationException {
return null;
}
@Override
public String translate(IntersectsFunction fct) throws TranslationException {
return null;
}
@Override
public String translate(PointFunction point) throws TranslationException {
return null;
}
@Override
public String translate(CircleFunction circle) throws TranslationException {
return null;
}
@Override
public String translate(BoxFunction box) throws TranslationException {
return null;
}
@Override
public String translate(PolygonFunction polygon) throws TranslationException {
return null;
}
@Override
public String translate(RegionFunction region) throws TranslationException {
return null;
}
@Override
public boolean isCaseSensitive(IdentifierField field) {
return false;
}
@Override
public DBType convertTypeFromDB(int dbmsType, String rawDbmsTypeName, String dbmsTypeName, String[] typeParams) {
return null;
}
@Override
public String convertTypeToDB(DBType type) {
return null;
}
@Override
public Region translateGeometryFromDB(Object jdbcColValue) throws ParseException {
return null;
}
@Override
public Object translateGeometryToDB(Region region) throws ParseException {
return null;
}
}
}