diff --git a/ballerina/Ballerina.toml b/ballerina/Ballerina.toml index 096f311b..ac190c8e 100644 --- a/ballerina/Ballerina.toml +++ b/ballerina/Ballerina.toml @@ -1,7 +1,7 @@ [package] org = "ballerinax" name = "java.jdbc" -version = "1.2.0" +version = "1.2.1" authors = ["Ballerina"] keywords = ["database", "client", "network", "SQL", "RDBMS", "JDBC"] repository = "https://github.com/ballerina-platform/module-ballerinax-java.jdbc" @@ -9,7 +9,7 @@ license = ["Apache-2.0"] distribution = "slbeta6" [[platform.java11.dependency]] -path = "../native/build/libs/java.jdbc-native-1.2.0.jar" +path = "../native/build/libs/java.jdbc-native-1.2.1.jar" [[platform.java11.dependency]] -path = "./lib/sql-native-1.2.0.jar" +path = "./lib/sql-native-1.2.1.jar" diff --git a/ballerina/CompilerPlugin.toml b/ballerina/CompilerPlugin.toml index 774f63ed..afcc1725 100644 --- a/ballerina/CompilerPlugin.toml +++ b/ballerina/CompilerPlugin.toml @@ -3,4 +3,4 @@ id = "jdbc-compiler-plugin" class = "io.ballerina.stdlib.java.jdbc.compiler.JDBCCompilerPlugin" [[dependency]] -path = "../compiler-plugin/build/libs/java.jdbc-compiler-plugin-1.2.0.jar" +path = "../compiler-plugin/build/libs/java.jdbc-compiler-plugin-1.2.1.jar" diff --git a/ballerina/Dependencies.toml b/ballerina/Dependencies.toml index 9e4916dc..57baf537 100644 --- a/ballerina/Dependencies.toml +++ b/ballerina/Dependencies.toml @@ -274,7 +274,7 @@ dependencies = [ [[package]] org = "ballerina" name = "sql" -version = "1.2.0" +version = "1.2.1" dependencies = [ {org = "ballerina", name = "io"}, {org = "ballerina", name = "jballerina.java"}, @@ -364,7 +364,7 @@ modules = [ [[package]] org = "ballerinax" name = "java.jdbc" -version = "1.2.0" +version = "1.2.1" dependencies = [ {org = "ballerina", name = "file"}, {org = "ballerina", name = "io"}, diff --git a/changelog.md b/changelog.md index 0391229d..cf006f2c 100644 --- a/changelog.md +++ b/changelog.md @@ -9,6 +9,12 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Added ### Changed +- [Fix Compiler plugin crash when variable is passed for `sql:ConnectionPool`](https://github.com/ballerina-platform/ballerina-standard-library/issues/2536) + +## [1.2.0] - 2021-12-13 + +### Changed +- Release module on top of Swan Lake Beta6 distribution ## [1.1.0] - 2021-11-20 diff --git a/compiler-plugin-tests/src/test/java/io/ballerina/stdlib/java/jdbc/compiler/CompilerPluginTest.java b/compiler-plugin-tests/src/test/java/io/ballerina/stdlib/java/jdbc/compiler/CompilerPluginTest.java index dd55cbbc..cd81a183 100644 --- a/compiler-plugin-tests/src/test/java/io/ballerina/stdlib/java/jdbc/compiler/CompilerPluginTest.java +++ b/compiler-plugin-tests/src/test/java/io/ballerina/stdlib/java/jdbc/compiler/CompilerPluginTest.java @@ -104,4 +104,17 @@ public void testSQLConnectionPoolFieldsInNewExpression() { Assert.assertEquals(diagnostic.diagnosticInfo().messageFormat(), SQL_101.getMessage()); }); } + + @Test + public void testSQLConnectionPoolFieldsInNewExpressionWVariables() { + Package currentPackage = loadPackage("sample3"); + PackageCompilation compilation = currentPackage.getCompilation(); + DiagnosticResult diagnosticResult = compilation.diagnosticResult(); + List diagnosticErrorStream = diagnosticResult.diagnostics().stream() + .filter(r -> r.diagnosticInfo().severity().equals(DiagnosticSeverity.ERROR)) + .collect(Collectors.toList()); + long availableErrors = diagnosticErrorStream.size(); + + Assert.assertEquals(availableErrors, 0); + } } diff --git a/compiler-plugin-tests/src/test/resources/diagnostics/sample3/Ballerina.toml b/compiler-plugin-tests/src/test/resources/diagnostics/sample3/Ballerina.toml new file mode 100644 index 00000000..a8eaca3a --- /dev/null +++ b/compiler-plugin-tests/src/test/resources/diagnostics/sample3/Ballerina.toml @@ -0,0 +1,4 @@ +[package] +org = "jdbc_test" +name = "sample3" +version = "0.1.0" diff --git a/compiler-plugin-tests/src/test/resources/diagnostics/sample3/main.bal b/compiler-plugin-tests/src/test/resources/diagnostics/sample3/main.bal new file mode 100644 index 00000000..a1c1a8d8 --- /dev/null +++ b/compiler-plugin-tests/src/test/resources/diagnostics/sample3/main.bal @@ -0,0 +1,29 @@ +// Copyright (c) 2021, WSO2 Inc. (http://www.wso2.org) All Rights Reserved. +// +// WSO2 Inc. licenses this file to you 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. + +import ballerinax/java.jdbc; + +public function main() returns error? { + + int connectionNum = 5; + int connectionNumInvalid = -5; + + jdbc:Client dbClient1 = check new("url", connectionPool = {maxOpenConnections: connectionNum}); + check dbClient1.close(); + + jdbc:Client dbClient2 = check new("url", (), (), {}, {maxOpenConnections: connectionNumInvalid}); + check dbClient2.close(); +} diff --git a/compiler-plugin/src/main/java/io/ballerina/stdlib/java/jdbc/compiler/analyzer/InitializerParamAnalyzer.java b/compiler-plugin/src/main/java/io/ballerina/stdlib/java/jdbc/compiler/analyzer/InitializerParamAnalyzer.java index bbec7e80..15a96b33 100644 --- a/compiler-plugin/src/main/java/io/ballerina/stdlib/java/jdbc/compiler/analyzer/InitializerParamAnalyzer.java +++ b/compiler-plugin/src/main/java/io/ballerina/stdlib/java/jdbc/compiler/analyzer/InitializerParamAnalyzer.java @@ -99,7 +99,7 @@ public void perform(SyntaxNodeAnalysisContext ctx) { ExpressionNode valueNode = ((SpecificFieldNode) field).valueExpr().get(); switch (name) { case Constants.ConnectionPool.MAX_OPEN_CONNECTIONS: - int maxOpenConnections = Integer.parseInt(getTerminalNodeValue(valueNode)); + int maxOpenConnections = Integer.parseInt(getTerminalNodeValue(valueNode, "1")); if (maxOpenConnections < 1) { DiagnosticInfo diagnosticInfo = new DiagnosticInfo(SQL_101.getCode(), SQL_101.getMessage(), SQL_101.getSeverity()); @@ -110,7 +110,7 @@ public void perform(SyntaxNodeAnalysisContext ctx) { } break; case Constants.ConnectionPool.MIN_IDLE_CONNECTIONS: - int minIdleConnection = Integer.parseInt(getTerminalNodeValue(valueNode)); + int minIdleConnection = Integer.parseInt(getTerminalNodeValue(valueNode, "0")); if (minIdleConnection < 0) { DiagnosticInfo diagnosticInfo = new DiagnosticInfo(SQL_102.getCode(), SQL_102.getMessage(), SQL_102.getSeverity()); @@ -120,7 +120,7 @@ public void perform(SyntaxNodeAnalysisContext ctx) { } break; case Constants.ConnectionPool.MAX_CONNECTION_LIFE_TIME: - float maxConnectionTime = Float.parseFloat(getTerminalNodeValue(valueNode)); + float maxConnectionTime = Float.parseFloat(getTerminalNodeValue(valueNode, "30")); if (maxConnectionTime < 30) { DiagnosticInfo diagnosticInfo = new DiagnosticInfo(SQL_103.getCode(), SQL_103.getMessage(), SQL_103.getSeverity()); @@ -136,15 +136,16 @@ public void perform(SyntaxNodeAnalysisContext ctx) { } } - private String getTerminalNodeValue(Node valueNode) { - String value; + private String getTerminalNodeValue(Node valueNode, String defaultValue) { + String value = defaultValue; if (valueNode instanceof BasicLiteralNode) { value = ((BasicLiteralNode) valueNode).literalToken().text(); - } else { + } else if (valueNode instanceof UnaryExpressionNode) { UnaryExpressionNode unaryExpressionNode = (UnaryExpressionNode) valueNode; value = unaryExpressionNode.unaryOperator() + ((BasicLiteralNode) unaryExpressionNode.expression()).literalToken().text(); } + // Currently we cannot process values from variables, this needs code flow analysis return value.replaceAll(UNNECESSARY_CHARS_REGEX, ""); } diff --git a/gradle.properties b/gradle.properties index a128c15a..b43325d6 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,5 +1,5 @@ group=io.ballerina.stdlib -version=1.2.0 +version=1.2.1 puppycrawlCheckstyleVersion=8.18 checkstyleToolVersion=7.8.2 @@ -12,7 +12,7 @@ testngVersion=7.4.0 ballerinaLangVersion=2.0.0-beta.6 -stdlibSqlVersion=1.2.0 +stdlibSqlVersion=1.2.1 stdlibIoVersion=1.1.0 stdlibRegexVersion=1.1.0