Mercurial > hg > monetdb-java
changeset 925:4dfdb62e3e9d
Extend JDBC_API_Tester program with optional second startup argument '-skipMALoutput'.
This allows the JDBC_API_Tester program to be called to skip the comparing the MAL output of tests which return MAL output such as PLAN, EXPLAIN and TRACE statements.
It is intended for internal development use only.
author | Martin van Dinther <martin.van.dinther@monetdbsolutions.com> |
---|---|
date | Thu, 08 Aug 2024 15:26:28 +0200 (7 months ago) |
parents | ace9f8f617f1 |
children | 0ce63f3686fe |
files | tests/JDBC_API_Tester.java |
diffstat | 1 files changed, 51 insertions(+), 39 deletions(-) [+] |
line wrap: on
line diff
--- a/tests/JDBC_API_Tester.java +++ b/tests/JDBC_API_Tester.java @@ -47,7 +47,7 @@ public final class JDBC_API_Tester { final private boolean isPostDec2023; // flag to support version specific output private boolean foundDifferences = false; - final private static int sbInitLen = 5468; + final private static int sbInitLen = 5468; // max needed size of sb /** * constructor @@ -66,19 +66,25 @@ public final class JDBC_API_Tester { /** * main function - * @param args this should contain the connectionURL string - * @throws Exception if a database access error occurs + * @param args args[0] should contain the connectionURL string, args[1] an optional flag: -skipMALoutput + * @throws Exception if a connection or database access error occurs */ public static void main(String[] args) throws Exception { - String con_URL = args[0]; + if (args.length < 1) { + System.err.println("Error: Missing required connection URL as first startup argument!"); + System.exit(-1); + } + + final String con_URL = args[0]; + final boolean skipMALoutput = (args.length >= 2) ? args[1].equals("-skipMALoutput") : false; + // System.err.println("skipMALoutput = " + skipMALoutput); // Test this before trying to connect UrlTester.runAllTests(); - Connection conn = DriverManager.getConnection(con_URL); + final Connection conn = DriverManager.getConnection(con_URL); JDBC_API_Tester jt = new JDBC_API_Tester(conn); - // run the tests jt.Test_Cautocommit(con_URL); jt.Test_CisValid(); @@ -93,7 +99,7 @@ public final class JDBC_API_Tester { jt.Test_FetchSize(); jt.Test_Int128(); jt.Test_Interval_Types(); - jt.Test_PlanExplainTraceDebugCmds(); + jt.Test_PlanExplainTraceDebugCmds(skipMALoutput); jt.Test_PSgeneratedkeys(); jt.Test_PSgetObject(); jt.Test_PSlargebatchval(); @@ -1944,7 +1950,7 @@ public final class JDBC_API_Tester { "ParameterTypeName: interval minute to second Precision: 15 Scale: 0 ParameterType: 3 ParameterClassName: java.math.BigDecimal\n"); } - private void Test_PlanExplainTraceDebugCmds() { + private void Test_PlanExplainTraceDebugCmds(boolean skipMALoutput) { sb.setLength(0); // clear the output log buffer Statement stmt = null; @@ -1966,21 +1972,23 @@ public final class JDBC_API_Tester { // plan statements are supported via JDBC qry = "plan SELECT 2;"; rs = stmt.executeQuery(qry); - compareResultSet(rs, qry, - ! isPreJan2022 ? - "Resultset with 1 columns\n" + - "rel\n" + - (isPostDec2023 ? "varchar" : "clob") + "(37)\n" + - "project (\n" + - "| [ boolean(1) \"true\" as \"%1\".\"%1\" ]\n" + - ") [ tinyint(2) \"2\" ]\n" - : - "Resultset with 1 columns\n" + - "rel\n" + - "clob(21)\n" + - "project (\n" + - "| [ boolean \"true\" ]\n" + - ") [ tinyint \"2\" ]\n"); + if (!skipMALoutput) { + compareResultSet(rs, qry, + ! isPreJan2022 ? + "Resultset with 1 columns\n" + + "rel\n" + + (isPostDec2023 ? "varchar" : "clob") + "(37)\n" + + "project (\n" + + "| [ boolean(1) \"true\" as \"%1\".\"%1\" ]\n" + + ") [ tinyint(2) \"2\" ]\n" + : + "Resultset with 1 columns\n" + + "rel\n" + + "clob(21)\n" + + "project (\n" + + "| [ boolean \"true\" ]\n" + + ") [ tinyint \"2\" ]\n"); + } rs.close(); rs = null; sb.setLength(0); // clear the output log buffer @@ -1995,11 +2003,13 @@ public final class JDBC_API_Tester { } rs.close(); rs = null; - compareExpectedOutput("Test_PlanExplainTraceDebugCmds: " + qry, - "function user.main():void;\n" + - " X_1:void := querylog.define(\"explain select 3;\":str, \"default_pipe\":str, 6:int);\n" + - " X_10:int := sql.resultSet(\".%2\":str, \"%2\":str, \"tinyint\":str, 2:int, 0:int, 7:int, 3:bte);\n" + - "end user.main;\n"); + if (!skipMALoutput) { + compareExpectedOutput("Test_PlanExplainTraceDebugCmds: " + qry, + "function user.main():void;\n" + + " X_1:void := querylog.define(\"explain select 3;\":str, \"default_pipe\":str, 6:int);\n" + + " X_10:int := sql.resultSet(\".%2\":str, \"%2\":str, \"tinyint\":str, 2:int, 0:int, 7:int, 3:bte);\n" + + "end user.main;\n"); + } sb.setLength(0); // clear the output log buffer // trace statements are supported via JDBC. Note that it returns two resultsets, one with the query result and next one with the trace result. @@ -2017,17 +2027,19 @@ public final class JDBC_API_Tester { } rs.close(); rs = null; - compareExpectedOutput("Test_PlanExplainTraceDebugCmds: " + qry, - ! isPreJan2022 ? - "4\n" + - "Another resultset\n" + - " X_1=0@0:void := querylog.define(\"trace select 4;\":str, \"default_pipe\":str, 6:int);\n" + - " X_10=0:int := sql.resultSet(\".%2\":str, \"%2\":str, \"tinyint\":str, 3:int, 0:int, 7:int, 4:bte);\n" - : - "4\n" + - "Another resultset\n" + - "X_0=0@0:void := querylog.define(\"trace select 4;\":str, \"default_pipe\":str, 6:int);\n" + - "X_1=0:int := sql.resultSet(\".%2\":str, \"%2\":str, \"tinyint\":str, 3:int, 0:int, 7:int, 4:bte);\n"); + if (!skipMALoutput) { + compareExpectedOutput("Test_PlanExplainTraceDebugCmds: " + qry, + ! isPreJan2022 ? + "4\n" + + "Another resultset\n" + + " X_1=0@0:void := querylog.define(\"trace select 4;\":str, \"default_pipe\":str, 6:int);\n" + + " X_10=0:int := sql.resultSet(\".%2\":str, \"%2\":str, \"tinyint\":str, 3:int, 0:int, 7:int, 4:bte);\n" + : + "4\n" + + "Another resultset\n" + + "X_0=0@0:void := querylog.define(\"trace select 4;\":str, \"default_pipe\":str, 6:int);\n" + + "X_1=0:int := sql.resultSet(\".%2\":str, \"%2\":str, \"tinyint\":str, 3:int, 0:int, 7:int, 4:bte);\n"); + } sb.setLength(0); // clear the output log buffer // debug statements are NOT supported via JDBC driver, so the execution should throw an SQLException