/* * JBoss, Home of Professional Open Source. * See the COPYRIGHT.txt file distributed with this work for information * regarding copyright ownership. Some portions may be licensed * to Red Hat, Inc. under one or more contributor license agreements. * * 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. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301 USA. */ package org.teiid.translator.jdbc.postgresql; import static org.junit.Assert.*; import java.sql.Connection; import org.junit.BeforeClass; import org.junit.Test; import org.teiid.core.util.SimpleMock; import org.teiid.translator.SourceSystemFunctions; import org.teiid.translator.TranslatorException; import org.teiid.translator.jdbc.TranslationHelper; import org.teiid.util.Version; @SuppressWarnings("nls") public class TestPostgreSQLTranslator { private static PostgreSQLExecutionFactory TRANSLATOR; @BeforeClass public static void setupOnce() throws Exception { TRANSLATOR = new PostgreSQLExecutionFactory(); TRANSLATOR.setUseBindVariables(false); TRANSLATOR.setDatabaseVersion(Version.DEFAULT_VERSION); TRANSLATOR.start(); TRANSLATOR.setPostGisVersion("1.0"); TRANSLATOR.initCapabilities(SimpleMock.createSimpleMock(Connection.class)); } public String getTestVDB() { return TranslationHelper.PARTS_VDB; } private String getTestBQTVDB() { return TranslationHelper.BQT_VDB; } public void helpTestVisitor(String vdb, String input, String expectedOutput) throws TranslatorException { TranslationHelper.helpTestVisitor(vdb, input, expectedOutput, TRANSLATOR); } @Test public void testStartWithoutVersion() throws TranslatorException { new PostgreSQLExecutionFactory().start(); } @Test public void testConversion1() throws Exception { String input = "SELECT char(convert(PART_WEIGHT, integer) + 100) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT chr((cast(PARTS.PART_WEIGHT AS integer) + 100)) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion2() throws Exception { String input = "SELECT convert(PART_WEIGHT, long) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(PARTS.PART_WEIGHT AS bigint) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion3() throws Exception { String input = "SELECT convert(PART_WEIGHT, short) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(PARTS.PART_WEIGHT AS smallint) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion4() throws Exception { String input = "SELECT convert(PART_WEIGHT, float) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(PARTS.PART_WEIGHT AS real) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion5() throws Exception { String input = "SELECT convert(PART_WEIGHT, double) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(PARTS.PART_WEIGHT AS float8) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion6() throws Exception { String input = "SELECT convert(PART_WEIGHT, biginteger) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(PARTS.PART_WEIGHT AS numeric(38)) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion7() throws Exception { String input = "SELECT convert(PART_WEIGHT, bigdecimal) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(PARTS.PART_WEIGHT AS decimal) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion8() throws Exception { String input = "SELECT convert(PART_WEIGHT, boolean) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(PARTS.PART_WEIGHT AS boolean) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion8a() throws Exception { String input = "SELECT convert(convert(PART_WEIGHT, boolean), long) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(cast(PARTS.PART_WEIGHT AS boolean) AS integer) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion9() throws Exception { String input = "SELECT convert(PART_WEIGHT, date) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(PARTS.PART_WEIGHT AS date) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion10() throws Exception { String input = "SELECT convert(PART_WEIGHT, time) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(PARTS.PART_WEIGHT AS time) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion11() throws Exception { String input = "SELECT convert(PART_WEIGHT, timestamp) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(PARTS.PART_WEIGHT AS timestamp) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion12() throws Exception { String input = "SELECT convert(convert(PART_WEIGHT, time), string) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT to_char(cast(PARTS.PART_WEIGHT AS time), 'HH24:MI:SS') FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion13() throws Exception { String input = "SELECT convert(convert(PART_WEIGHT, timestamp), string) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT to_char(cast(PARTS.PART_WEIGHT AS timestamp), 'YYYY-MM-DD HH24:MI:SS.US') FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion14() throws Exception { String input = "SELECT convert(convert(PART_WEIGHT, date), string) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT to_char(cast(PARTS.PART_WEIGHT AS date), 'YYYY-MM-DD') FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion15() throws Exception { String input = "SELECT convert(convert(PART_WEIGHT, timestamp), date) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(cast(PARTS.PART_WEIGHT AS timestamp) AS date) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion16() throws Exception { String input = "SELECT convert(convert(PART_WEIGHT, timestamp), time) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(date_trunc('second', cast(PARTS.PART_WEIGHT AS timestamp)) AS time) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion17() throws Exception { String input = "SELECT convert(convert(PART_WEIGHT, time), timestamp) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(PARTS.PART_WEIGHT AS time) + TIMESTAMP '1970-01-01' FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion18() throws Exception { String input = "SELECT convert(convert(PART_WEIGHT, date), timestamp) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast(cast(PARTS.PART_WEIGHT AS date) AS timestamp) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testConversion19() throws Exception { String input = "SELECT convert(convert(PART_WEIGHT, boolean), string) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT CASE WHEN cast(PARTS.PART_WEIGHT AS boolean) THEN 'true' WHEN not(cast(PARTS.PART_WEIGHT AS boolean)) THEN 'false' END FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testLog() throws Exception { String input = "SELECT log(convert(PART_WEIGHT, double)) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT ln(cast(PARTS.PART_WEIGHT AS float8)) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); input = "SELECT log10(convert(PART_WEIGHT, double)) FROM PARTS"; //$NON-NLS-1$ output = "SELECT log(cast(PARTS.PART_WEIGHT AS float8)) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testLeft() throws Exception { String input = "SELECT left(PART_WEIGHT, 2) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT substring(PARTS.PART_WEIGHT from 1 for 2) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testDayOfWeek() throws Exception { String input = "SELECT dayofweek(convert(PART_WEIGHT, timestamp)) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT CAST((EXTRACT(DOW FROM cast(PARTS.PART_WEIGHT AS timestamp)) + 1) AS integer) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testDayOfMonth() throws Exception { String input = "SELECT dayofmonth(convert(PART_WEIGHT, timestamp)) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT CAST(EXTRACT(DAY FROM cast(PARTS.PART_WEIGHT AS timestamp)) AS integer) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testDayOfYear() throws Exception { String input = "SELECT dayofyear(convert(PART_WEIGHT, timestamp)) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT CAST(EXTRACT(DOY FROM cast(PARTS.PART_WEIGHT AS timestamp)) AS integer) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testHour() throws Exception { String input = "SELECT hour(convert(PART_WEIGHT, timestamp)) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT CAST(EXTRACT(HOUR FROM cast(PARTS.PART_WEIGHT AS timestamp)) AS integer) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testMinute() throws Exception { String input = "SELECT minute(convert(PART_WEIGHT, timestamp)) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT CAST(EXTRACT(MINUTE FROM cast(PARTS.PART_WEIGHT AS timestamp)) AS integer) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testMonth() throws Exception { String input = "SELECT month(convert(PART_WEIGHT, timestamp)) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT CAST(EXTRACT(MONTH FROM cast(PARTS.PART_WEIGHT AS timestamp)) AS integer) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testQuarter() throws Exception { String input = "SELECT quarter(convert(PART_WEIGHT, timestamp)) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT CAST(EXTRACT(QUARTER FROM cast(PARTS.PART_WEIGHT AS timestamp)) AS integer) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testSecond() throws Exception { String input = "SELECT second(convert(PART_WEIGHT, timestamp)) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT CAST(EXTRACT(SECOND FROM cast(PARTS.PART_WEIGHT AS timestamp)) AS integer) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testWeek() throws Exception { String input = "SELECT week(convert(PART_WEIGHT, timestamp)) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT CAST(EXTRACT(WEEK FROM cast(PARTS.PART_WEIGHT AS timestamp)) AS integer) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testYear() throws Exception { String input = "SELECT year(convert(PART_WEIGHT, timestamp)) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT CAST(EXTRACT(YEAR FROM cast(PARTS.PART_WEIGHT AS timestamp)) AS integer) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testDayName() throws Exception { String input = "SELECT dayname(convert(PART_WEIGHT, timestamp)) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT rtrim(TO_CHAR(cast(PARTS.PART_WEIGHT AS timestamp), 'Day')) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testMonthName() throws Exception { String input = "SELECT monthname(convert(PART_WEIGHT, timestamp)) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT rtrim(TO_CHAR(cast(PARTS.PART_WEIGHT AS timestamp), 'Month')) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testIfnull() throws Exception { String input = "SELECT ifnull(PART_WEIGHT, 'otherString') FROM PARTS"; //$NON-NLS-1$ String output = "SELECT coalesce(PARTS.PART_WEIGHT, 'otherString') FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testSubstring1() throws Exception { String input = "SELECT substring(PART_WEIGHT, 1) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT substring(PARTS.PART_WEIGHT from 1) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testSubstring2() throws Exception { String input = "SELECT substring(PART_WEIGHT, 1, 5) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT substring(PARTS.PART_WEIGHT from 1 for 5) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testSubstringExpressionIndex() throws Exception { String input = "SELECT substring(PART_WEIGHT, cast(part_id as integer), 5) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT substring(PARTS.PART_WEIGHT from case sign(cast(PARTS.PART_ID AS integer)) when -1 then cast(null as int4) when 0 then 1 else cast(PARTS.PART_ID AS integer) end for 5) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testSubstringZeroIndex() throws Exception { String input = "SELECT substring(PART_WEIGHT, 0, 5) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT substring(PARTS.PART_WEIGHT from 1 for 5) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testBooleanAggregate() throws Exception { String input = "SELECT MIN(convert(PART_WEIGHT, boolean)) FROM PARTS"; //$NON-NLS-1$ String output = "SELECT bool_and(cast(PARTS.PART_WEIGHT AS boolean)) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testRowLimit2() throws Exception { String input = "select intkey from bqt1.smalla limit 100"; //$NON-NLS-1$ String output = "SELECT SmallA.IntKey FROM SmallA LIMIT 100"; //$NON-NLS-1$ helpTestVisitor(getTestBQTVDB(), input, output); } @Test public void testRowLimit3() throws Exception { String input = "select intkey from bqt1.smalla limit 50, 100"; //$NON-NLS-1$ String output = "SELECT SmallA.IntKey FROM SmallA LIMIT 100 OFFSET 50"; //$NON-NLS-1$ helpTestVisitor(getTestBQTVDB(), input, output); } @Test public void testBitFunctions() throws Exception { String input = "select bitand(intkey, intnum), bitnot(intkey), bitor(intnum, intkey), bitxor(intnum, intkey) from bqt1.smalla"; //$NON-NLS-1$ String output = "SELECT (SmallA.IntKey & SmallA.IntNum), ~(SmallA.IntKey), (SmallA.IntNum | SmallA.IntKey), (SmallA.IntNum # SmallA.IntKey) FROM SmallA"; //$NON-NLS-1$ helpTestVisitor(getTestBQTVDB(), input, output); } /** * Test the translator's ability to rewrite the LOCATE() function in a form * suitable for the data source. * <p> * <code>SELECT locate(INTNUM, 'chimp', 1) FROM BQT1.SMALLA</code> * * @throws Exception */ @Test public void testLocate() throws Exception { String input = "SELECT locate(INTNUM, 'chimp', 1) FROM BQT1.SMALLA"; //$NON-NLS-1$ String output = "SELECT position(cast(SmallA.IntNum AS varchar(4000)) in 'chimp') FROM SmallA"; //$NON-NLS-1$ TranslationHelper.helpTestVisitor(TranslationHelper.BQT_VDB, input, output, TRANSLATOR); } /** * Test the translator's ability to rewrite the LOCATE() function in a form * suitable for the data source. * <p> * <code>SELECT locate(STRINGNUM, 'chimp') FROM BQT1.SMALLA</code> * * @throws Exception */ @Test public void testLocate2() throws Exception { String input = "SELECT locate(STRINGNUM, 'chimp') FROM BQT1.SMALLA"; //$NON-NLS-1$ String output = "SELECT position(SmallA.StringNum in 'chimp') FROM SmallA"; //$NON-NLS-1$ TranslationHelper.helpTestVisitor(TranslationHelper.BQT_VDB, input, output, TRANSLATOR); } /** * Test the translator's ability to rewrite the LOCATE() function in a form * suitable for the data source. * <p> * <code>SELECT locate(INTNUM, '234567890', 1) FROM BQT1.SMALLA WHERE INTKEY = 26</code> * * @throws Exception */ @Test public void testLocate3() throws Exception { String input = "SELECT locate(INTNUM, '234567890', 1) FROM BQT1.SMALLA WHERE INTKEY = 26"; //$NON-NLS-1$ String output = "SELECT position(cast(SmallA.IntNum AS varchar(4000)) in '234567890') FROM SmallA WHERE SmallA.IntKey = 26"; //$NON-NLS-1$ TranslationHelper.helpTestVisitor(TranslationHelper.BQT_VDB, input, output, TRANSLATOR); } /** * Test the translator's ability to rewrite the LOCATE() function in a form * suitable for the data source. * <p> * <code>SELECT locate('c', 'chimp', 1) FROM BQT1.SMALLA</code> * * @throws Exception */ @Test public void testLocate4() throws Exception { String input = "SELECT locate('c', 'chimp', 1) FROM BQT1.SMALLA"; //$NON-NLS-1$ String output = "SELECT 1 FROM SmallA"; //$NON-NLS-1$ TranslationHelper.helpTestVisitor(TranslationHelper.BQT_VDB, input, output, TRANSLATOR); } /** * Test the translator's ability to rewrite the LOCATE() function in a form * suitable for the data source. * <p> * <code>SELECT locate(STRINGNUM, 'chimp', -5) FROM BQT1.SMALLA</code> * * @throws Exception */ @Test public void testLocate5() throws Exception { String input = "SELECT locate(STRINGNUM, 'chimp', -5) FROM BQT1.SMALLA"; //$NON-NLS-1$ String output = "SELECT position(SmallA.StringNum in 'chimp') FROM SmallA"; //$NON-NLS-1$ TranslationHelper.helpTestVisitor(TranslationHelper.BQT_VDB, input, output, TRANSLATOR); } @Test public void testLocate5a() throws Exception { String input = "SELECT locate(STRINGNUM, 'chimp', 2) FROM BQT1.SMALLA"; //$NON-NLS-1$ String output = "SELECT (position(SmallA.StringNum in substring('chimp' from 2)) + 1) FROM SmallA"; //$NON-NLS-1$ TranslationHelper.helpTestVisitor(TranslationHelper.BQT_VDB, input, output, TRANSLATOR); } /** * Test the translator's ability to rewrite the LOCATE() function in a form * suitable for the data source. * <p> * <code>SELECT locate(STRINGNUM, 'chimp', INTNUM) FROM BQT1.SMALLA</code> * * @throws Exception */ @Test public void testLocate6() throws Exception { String input = "SELECT locate(STRINGNUM, 'chimp', INTNUM) FROM BQT1.SMALLA"; //$NON-NLS-1$ String output = "SELECT (position(SmallA.StringNum in substring('chimp' from CASE WHEN SmallA.IntNum < 1 THEN 1 ELSE SmallA.IntNum END)) + CASE WHEN SmallA.IntNum < 1 THEN 1 ELSE SmallA.IntNum END - 1) FROM SmallA"; //$NON-NLS-1$ TranslationHelper.helpTestVisitor(TranslationHelper.BQT_VDB, input, output, TRANSLATOR); } /** * Test the translator's ability to rewrite the LOCATE() function in a form * suitable for the data source. * <p> * <code>SELECT locate(STRINGNUM, 'chimp', LOCATE(STRINGNUM, 'chimp') + 1) FROM BQT1.SMALLA</code> * * @throws Exception */ @Test public void testLocate7() throws Exception { String input = "SELECT locate(STRINGNUM, 'chimp', LOCATE(STRINGNUM, 'chimp') + 1) FROM BQT1.SMALLA"; //$NON-NLS-1$ String output = "SELECT (position(SmallA.StringNum in substring('chimp' from CASE WHEN (position(SmallA.StringNum in 'chimp') + 1) < 1 THEN 1 ELSE (position(SmallA.StringNum in 'chimp') + 1) END)) + CASE WHEN (position(SmallA.StringNum in 'chimp') + 1) < 1 THEN 1 ELSE (position(SmallA.StringNum in 'chimp') + 1) END - 1) FROM SmallA"; //$NON-NLS-1$ TranslationHelper.helpTestVisitor(TranslationHelper.BQT_VDB, input, output, TRANSLATOR); } @Test public void testAggregate() throws Exception { String input = "SELECT count(*), max(booleanvalue), max(intnum) FROM BQT1.SMALLA"; //$NON-NLS-1$ String output = "SELECT COUNT(*), bool_or(SmallA.BooleanValue), MAX(SmallA.IntNum) FROM SmallA"; //$NON-NLS-1$ TranslationHelper.helpTestVisitor(TranslationHelper.BQT_VDB, input, output, TRANSLATOR); } @Test public void testArrayFunctions() throws Exception { String input = "SELECT array_get(objectvalue, 3), array_length(objectvalue) FROM BQT1.SMALLA"; //$NON-NLS-1$ String output = "SELECT SmallA.ObjectValue[3], array_length(SmallA.ObjectValue, 1) FROM SmallA"; //$NON-NLS-1$ TranslationHelper.helpTestVisitor(TranslationHelper.BQT_VDB, input, output, TRANSLATOR); } @Test public void testLikeRegex() throws Exception { String input = "SELECT intkey FROM BQT1.SMALLA where stringkey like_regex 'ab.*c+' and stringkey not like_regex 'ab{3,5}c'"; //$NON-NLS-1$ String output = "SELECT SmallA.IntKey FROM SmallA WHERE SmallA.StringKey ~ 'ab.*c+' AND SmallA.StringKey !~ 'ab{3,5}c'"; //$NON-NLS-1$ TranslationHelper.helpTestVisitor(TranslationHelper.BQT_VDB, input, output, TRANSLATOR); } @Test public void testTempTable() throws Exception { assertEquals("create temporary table foo (COL1 int4, COL2 varchar(100)) on commit drop", TranslationHelper.helpTestTempTable(TRANSLATOR, true)); assertEquals("create temporary table foo (COL1 int4, COL2 varchar(100)) ON COMMIT PRESERVE ROWS", TranslationHelper.helpTestTempTable(TRANSLATOR, false)); } @Test public void testFormatTimestampFrac() throws Exception { String input = "SELECT formattimestamp(now(), 'SSS'), formattimestamp(now(), 'SSSSSSS') FROM PARTS"; //$NON-NLS-1$ String output = "SELECT TO_CHAR(now(), 'MS'), TO_CHAR(now(), 'US') FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testRecursiveCTE() throws Exception { String input = "WITH p(n) as (select part_name as n from parts union select n from p) SELECT * FROM P"; //$NON-NLS-1$ String output = "WITH RECURSIVE p (n) AS (SELECT PARTS.PART_NAME AS n FROM PARTS UNION SELECT p.n FROM p) SELECT P.n FROM P"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testGeometryFunctions() throws Exception { PostgreSQLExecutionFactory pgef = new PostgreSQLExecutionFactory(); pgef.setPostGisVersion("1.5"); pgef.setDatabaseVersion(Version.DEFAULT_VERSION); pgef.start(); assertTrue(pgef.getSupportedFunctions().contains(SourceSystemFunctions.ST_ASBINARY)); assertFalse(pgef.getSupportedFunctions().contains(SourceSystemFunctions.ST_GEOMFROMGEOJSON)); } @Test public void testBooleanConversion() throws Exception { String input = "SELECT cast(bigdecimalvalue as boolean), cast(doublenum as boolean) from bqt1.smalla"; //$NON-NLS-1$ String output = "SELECT SmallA.BigDecimalValue <> 0, cast(SmallA.DoubleNum AS boolean) FROM SmallA"; //$NON-NLS-1$ helpTestVisitor(TranslationHelper.BQT_VDB, input, output); } @Test public void testSelectStringLiteral() throws Exception { String input = "SELECT 'a' FROM PARTS"; //$NON-NLS-1$ String output = "SELECT cast('a' AS bpchar) FROM PARTS"; //$NON-NLS-1$ helpTestVisitor(getTestVDB(), input, output); } @Test public void testRound() throws Exception { String input = "SELECT round(bigdecimalvalue, 2), round(doublenum, 3), round(doublenum, 0) from bqt1.smalla"; //$NON-NLS-1$ String output = "SELECT round(SmallA.BigDecimalValue, 2), round(cast(SmallA.DoubleNum AS decimal), 3), round(SmallA.DoubleNum) FROM SmallA"; //$NON-NLS-1$ helpTestVisitor(TranslationHelper.BQT_VDB, input, output); } @Test public void testBinaryLiteral() throws TranslatorException { helpTestVisitor(TranslationHelper.BQT_VDB, "SELECT X'abcd1234'", //$NON-NLS-1$ "SELECT cast(E'\\\\xABCD1234' AS bytea)"); //$NON-NLS-1$ } @Test public void testBooleanExpressionComparision() throws TranslatorException { helpTestVisitor(TranslationHelper.BQT_VDB, "SELECT intkey from bqt1.smalla where (intkey < 10) = true", //$NON-NLS-1$ "SELECT SmallA.IntKey FROM SmallA WHERE (SmallA.IntKey < 10) = TRUE"); //$NON-NLS-1$ } }