Releases: felipebz/zpa
Release 3.6.0
Read the announcement on ZPA's blog
SonarQube compatibility
This release is compatible with SonarQube 9.9 LTA Community Edition and newer. However, comprehensive testing and validation have been conducted only on SonarQube 9.9 CE, 10.6 CE, and 10.7 CE. While compatibility is expected for other versions within this range, the full extent of functionality has been assured only for the tested versions.
Additionally, please note that while this version may work with SonarQube’s commercial editions, the compatibility was not tested and simultaneous analysis using ZPA and SonarSource’s embedded PL/SQL plugin is not supported. If you require this scenario, consider using zpa-cli instead.
Install/update instructions
- Download the sonar-zpa-plugin-3.6.0.jar and copy it to the SONARQUBE_HOME/extensions/plugins.
- Remove the older plugin from that directory.
- Restart the SonarQube instance.
For custom plugin developers
Binary compatibility is not guaranteed either in between any version number change. Custom plugins should be recompiled against the same version of sonar-zpa-plugin
.
Download the zpa-toolkit-3.6.0.jar (requires Java 11+) to test the parser and view the AST.
Full changelog
🔀 Merge
- 7db9459 Merge pull request #193 from felipebz/renovate/all, closes #193
- eb9b9ee Merge pull request #191 from felipebz/renovate/all, closes #191
- 76710bd Merge pull request #190 from felipebz/renovate/all, closes #190
- 2cd89ed Merge pull request #188 from felipebz/renovate/all, closes #188
🚀 Features
- 5e51f43 Make UnknownDatatype a singleton to reduce memory allocations
- 4f142b1 Improve scope management for select expressions to ensure proper method scoping in WITH clause
- 99c3c05 grammar: Support function and procedure declarations in WITH_CLAUSE
- 77cffe8 grammar: Support alternative syntax for json_object (JSON { }) and json_array (JSON [ ])
- 1ca3c0e grammar: Add BOOLEAN_TEST_CONDITION node to support IS TRUE/FALSE conditions in addition to IS NULL
- ed033a6 grammar: Make FROM_CLAUSE optional in queries, aligning with Oracle 23ai
- c753425 grammar: Improve support for TO_YMINTERVAL syntax
- beac75b grammar: Improve support for TO_TIMESTAMP_TZ syntax
- 516cc2c grammar: Improve support for TO_TIMESTAMP syntax
- 65043bb grammar: Improve support for TO_NUMBER syntax (#192), closes #192
- 414f652 grammar: Improve support for TO_DSINTERVAL syntax
- 003a7ca grammar: Improve support for TO_DATE syntax
- 4bd31fe grammar: Improve support for TO_BOOLEAN syntax
- eab1962 grammar: Improve support for TO_BINARY_FLOAT syntax
- de53cbd grammar: Improve support for TO_BINARY_DOUBLE syntax
- e38d895 grammar: Improve support for CAST syntax
- 4161080 grammar: Support COVERAGE pragma
- 7149f96 grammar: Support SUPPRESSES_WARNING_6009 pragma
- 93f5995 grammar: Accept expressions in datatype nodes. This is necessary to support things like "var number(some_constant)"
- 547cf56 grammar: Support TRUNCATE TABLE statement
- bb996a6 Review all uses of tokenOriginalValue and change to tokenValue when applicable. tokenValue returns the normalized token according to the case-sensitivity of the identifiers.
- ab4addf Add ActiveRuleConfigurer interface for rule configuration in analysis
🐛 Fixes
- 27c4fb8 grammar: Support more datatypes in JSON_RETURNING_CLAUSE, JSON_VALUE_RETURN_TYPE and JSON_TRANSFORM_RETURNING_CLAUSE
- 4b68157 grammar: JSON_VALUE function should accept multiple ON MISMATCH clauses
- 0985521 grammar: Use BOOLEAN_LITERAL in BOOLEAN_TEST_CONDITION
- 6580efe deps: update all dependencies
- 2c1ca33 grammar: Use ARGUMENT instead of EXPRESSION in conversion functions because in a PL/SQL context they can be called with named arguments like
var := to_number(right => val);
- b538d56 renovate: switch mode from silent to full
- 6c1dc9f Ignore the case of identifiers when searching the corresponding source file for test and coverage reports
- 7340759 Add a special channel to handle quoted identifiers and fix false positives related to them on rules UnusedVariable, UnusedCursor, UnusedParameter and VariableHiding, closes #186
- 78cfa6a grammar: Fix parsing of "in (subquery)"
🔄️ Changes
- 8c4ba16 toolkit: Rename package org.sonar.plsqlopen.toolkit to com.felipebz.zpa.toolkit
🧪 Tests
- 22a7b1a it: Add integration tests for test and coverage reports
- 265eba8 it: Use assertAll to check multiple values
- 17dd386 it: Update integration test files to match the Oracle 23.5 docs
- 78635c7 Order lines from integration tests expectations
🧰 Tasks
- d57c42a Rename "Z PL/SQL Analyzer" to "ZPA"
- 44a4089 it: Update SonarQube test matrix
- 6cd200a deps: update dependency org.junit.jupiter:junit-jupiter to v5.11.1
- 55747e4 deps: update dependency gradle to v8.10.2
- 3305120 docs: Remove links to the early-access release in preparation for shorter release cycles
- 670656c Update JReleaser config to mark the GitHub releases as draft
- abee5a6 deps: update all dependencies
- 584ca37 deps: Update com.gradleup.shadow plugin to 8.3.2
- 1742d9a Configure Renovate
- 0661483 deps: Use FLR 1.5.0
- 5b51cde Update Gradle to 8.10.1
- 26014af Update SonarQube URL
- e114a0c Update dependencies
- 31c8a62 Remove kotlin-bom from the dependencies
- 43264ac Update Kotlin to 2.0.20
- fa7b3ba Update shadow plugin
- 741f1c9 deps: Bump FLR to 1.5.0-SNAPSHOT
- 630cd0e Update links to the new website
- 0dc3f66 Update SQLcl to 24.2.0.180.1721
- 718ade6 Update .gitattributes
- 5338730 Fix path of vendored files in .gitattributes
- 5dda4cb Update SonarScanner plugin to 5.1.0.4882
- 30399be Update test libraries
- fe44f08 Move dependencies to version catalog
- 59c5bda Update to JReleaser 1.13.1
🛠 Build
- 416af10 Release 3.6.0
- 1d46dc8 Publish a zip file with the plsql-custom-rules example
- 8d1b9c4 Pass "-Xconsistent-data-class-copy-visibility" to Kotlin compiler
- 211d7e6 Use Gradle 8.10
- eb776e0 Restore the default test logging level
- 415beb5 Remove unnecessary --build-cache argument from the build workflow
- 8f1a824 Enable parallel execution and build cache in Gradle
- 06d1488 Use Gradle 8.9
- 5d6b503 Remove SQ 10.5 from the test matrix and add SQ 10.7-SNAPSHOT
- 5249ea0 Remove unnecessary dependency from sonar-zpa-plugin
- 715a8ad Bump project version
Release 3.5.1
SonarQube compatibility
This release is compatible with SonarQube 9.9 LTA Community Edition and newer. However, comprehensive testing and validation have been conducted only on SonarQube 9.9 CE, 10.5 CE, and 10.6 CE. While compatibility is expected for other versions within this range, the full extent of functionality has been assured only for the tested versions.
Additionally, please note that while this version may work with SonarQube’s commercial editions, the compatibility was not tested and simultaneous analysis using ZPA and SonarSource’s embedded PL/SQL plugin is not supported. If you require this scenario, consider using zpa-cli instead.
Highlights
First-class support for test and coverage reports generated by utPLSQL
Two new properties specifically designed for consuming test and coverage reports generated by utPLSQL were added:
sonar.zpa.tests.reportPaths
: Use this property to specify the path to the test report(s) (generated using theut_sonar_test_reporter
).sonar.zpa.coverage.reportPaths
: Similarly, this property allows you to specify the path to the coverage report(s) (generated using theut_coverage_sonar_reporter
).
Previously, importing test and coverage reports into SonarQube required generic properties. However, with the introduction of these new properties, the ZPA plugin can now automatically associate the test and coverage results with the corresponding PL/SQL files. The best part? You won’t need to define any complex object-file mapping rules in the utPLSQL-cli.
By leveraging these properties, is much easier to integrate the utPLSQL reports into your SonarQube analysis pipeline. More information is available in the documentation.
Install/update instructions
- Download the sonar-zpa-plugin-3.5.1.jar and copy it to the SONARQUBE_HOME/extensions/plugins.
- Remove the older plugin from that directory.
- Restart the SonarQube instance.
For custom plugin developers
Binary compatibility is not guaranteed either in between any version number change. Custom plugins should be recompiled against the same version of sonar-zpa-plugin
.
Download the zpa-toolkit-3.5.1.jar (requires Java 11+) to test the parser and view the AST.
Full changelog
🐛 Fixes
- 2334bb8 Correct coverage import for package bodies declared in same file as package spec
🧰 Tasks
- eb0d9cc Update changelog template
🛠 Build
Release 3.5.0
SonarQube compatibility
This release is compatible with SonarQube 9.9 LTA Community Edition and newer. However, comprehensive testing and validation have been conducted only on SonarQube 9.9 CE, 10.5 CE, and 10.6 CE. While compatibility is expected for other versions within this range, the full extent of functionality has been assured only for the tested versions.
Additionally, please note that while this version may work with SonarQube’s commercial editions, the compatibility was not tested and simultaneous analysis using ZPA and SonarSource’s embedded PL/SQL plugin is not supported. If you require this scenario, consider using zpa-cli instead.
Highlights
First-class support for test and coverage reports generated by utPLSQL
Two new properties specifically designed for consuming test and coverage reports generated by utPLSQL were added:
sonar.zpa.tests.reportPaths
: Use this property to specify the path to the test report(s) (generated using theut_sonar_test_reporter
).sonar.zpa.coverage.reportPaths
: Similarly, this property allows you to specify the path to the coverage report(s) (generated using theut_coverage_sonar_reporter
).
Previously, importing test and coverage reports into SonarQube required generic properties. However, with the introduction of these new properties, the ZPA plugin can now automatically associate the test and coverage results with the corresponding PL/SQL files. The best part? You won’t need to define any complex object-file mapping rules in the utPLSQL-cli.
By leveraging these properties, is much easier to integrate the utPLSQL reports into your SonarQube analysis pipeline. More information is available in the documentation.
Install/update instructions
- Download the sonar-zpa-plugin-3.5.0.jar and copy it to the SONARQUBE_HOME/extensions/plugins.
- Remove the older plugin from that directory.
- Restart the SonarQube instance.
For custom plugin developers
Binary compatibility is not guaranteed either in between any version number change. Custom plugins should be recompiled against the same version of sonar-zpa-plugin
.
Download the zpa-toolkit-3.5.0.jar (requires Java 11+) to test the parser and view the AST.
Full changelog
🚀 Features
- a2b45d2 grammar: Add remaining XML(...) functions
- 267001e grammar: Update the COLUMNS clause for JSON_TABLE to not require parenthesis
- 0c9dc89 grammar: Support JSON_DATAGUIDE (#182), closes #182
- be2753a grammar: Support JSON_TEXTCONTAINS condition (#182), closes #182
- d45f0a1 grammar: Support JSON_EXISTS condition (#182), closes #182
- e7df8bb grammar: Support JSON_EQUAL condition (#182), closes #182
- 04243e8 grammar: Support IS JSON condition (#182), closes #182
- 995e570 grammar: Support JSON_TRANSFORM (#182), closes #182
- 2f72915 grammar: Accept "?" as a binding expression
- c3d7f8d toolkit: Hide the stacktrace of RecognitionException
- ec9b08d grammar: Support JSON_VALUE (#182), closes #182
- 0ac0549 grammar: Support NESTED clause (short-hand syntax for JSON_TABLE) (#182), closes #182
- 1cb8e99 grammar: Support JSON_TABLE (#182), closes #182
- 0b72375 Add JsonDatatype (#182), closes #182
- 708e999 grammar: Support JSON_SERIALIZE (#182), closes #182
- db6f528 grammar: Support JSON_SCALAR (#182), closes #182
- 6a97dcb grammar: Support JSON_OBJECTAGG (#182), closes #182
- fdb40f5 grammar: Support JSON_OBJECT (#182), closes #182
- 444993b grammar: Support JSON_MERGEPATCH (#182), closes #182
- 5ef627a Update SemanticAstNode.toString to return value/line/column instead of tokenValue/tokenLine/tokenColumn for easier debugging
- a518777 grammar: Support JSON_ARRAYAGG (#182), closes #182
- be972b7 grammar: Support JSON_ARRAY (#182), closes #182
- 460e813 grammar: Support JSON constructor (#182), closes #182
- bd12517 Update rule descriptions to display the line differences between compliant and noncompliant code
- 5cfcb8b grammar: Support JSON_QUERY (#182), closes #182
- 3689350 grammar: Support COLLECT function
- 319beef grammar: Support values clause in queries
- d335949 grammar: Support recursive subquery factoring syntax
- bc26d2b grammar: Support timestamp literals
- 30f014f grammar: Support floating-point literals
- 4ef718b Add debug logging on the test and coverage importers
- 59f081f Add "debug" log level
- 7199edc Add firstToken and lastToken to Scope because the "tree" is empty on the scopes added to the global scope
- c7e952d Import coverage reports correctly when the tested file doesn't start with the executed code (#156), closes #156
- b75eecf Import coverage reports from utPLSQL (#156), closes #156
- 5eb4945 Import correctly utPLSQL test reports that contain the paths to the source files (#156), closes #156
- 38b3e1f Introduce a sensor to import utPLSQL test reports (#156), closes #156
- 99f7216 Add a FileLocator component to be used by the utPLSQL report sensor (#156), closes #156
- fdbd43f Expose the global symbol scope to the consumers of AstScanner
- 9579c04 Add a plSqlFile property to ScopeImpl
- 09b8593 Include empty comment lines in the total count of lines of comments
- a256b94 Remove method getSemanticNode and make the Parser build a SemanticAstNode directly
🐛 Fixes
- 0159c3c grammar: Avoid ambiguity between "/" as the division operator and "/" as a SQL*Plus command, take 2
- 2172558 grammar: Avoid ambiguity between "/" as the division operator and "/" as a SQL*Plus command
- 6fc3fe1 grammar: SET isn't always a reserved keyword, it can be used as a object name
- 02c327e grammar: Support the obsolete THE expression (closes #183), closes #183
- 138ff5e grammar: Support the usage of the keyword AS in table aliases
- 338b2ee Fix zpa-checks tests to use Jackson
- 600b4ea Register all the trigger scopes with the type "CREATE_TRIGGER"
- d6ab929 Wait for the thread to terminate before exiting ProgressReport.stop/cancel to ensure that the message 'xxx source files have been analyzed' doesn't appear after the 'Sensor Z PL/SQL Analyzer [plsqlopen] (done)' in SonarScanner.
- 776c766 Ignore coverage for files with no covered lines
- a2983d0 Store the trigger name on the scope correctly
- b4d5a5e grammar: Skip XMLTABLE_OPTIONS node because all components are optional
- b5918c0 Import test result correctly when the report contains the suite path
- 57d5aad Fix comparison on MethodMatcher
- 7114796 Fix broken test
- 83e5d6a Add a subcategory for test and coverage properties instead of creating a new category
- 4355716 Fix the xml mapping of utPLSQL test report
🔄️ Changes
- efc977e Remove unused method
- 0e8bde4 grammar: Move XMLAGG_EXPRESSION to AggregateSqlFunctionsGrammar
- 9c990f2 grammar: Move TREAT_AS_EXPRESSION and SET_EXPRESSION to SingleRowSqlFunctionsGrammar
- 7742599 Prefer raw strings for regexes in PlSqlLexer
- 2ba31ad Abstract some logic from TestResultImporter that will be shared with the coverage importer
- 734b300 Remove unnecessary parameter from UtPlSqlSensor
- 765b2d1 Move the test report importing code to a separate class (#156), closes #156
- c9212cc Rename class UtPlSqlTestSensor to UtPlSqlSensor
- c6d6fd0 Rename property "sonar.zpa.utplsql.reportPaths" to "sonar.zpa.tests.reportPaths" (#156), closes #156
- 6ec05fa Rename FileLocator to ObjectLocator and don't add the number disabled tests to the total of tests (#156), closes #156
- aa7f0fa Reduce memory usage of MethodMatcher
- 1f6af00 Convert NameCriteria to a functional interface
- d9e0702 Remove unnecessary call to Char.lowercaseChar
- 5a7dc47 Replace usages of org.hamcrest.MatcherAssert with com.felipebz.flr.tests.Assertions
🧪 Tests
- a7a72ba its: Verify if the files are parsed correctly when the error recovery mode is enabled
- 8d5e548 it: Add extracted code from the JSON Developer's Guide
- 039af64 it: Add extracted code from the PL/SQL Language Reference
- 473a8da it: Update CSS selector used by OracleDocsExtractor
- 9bbeb5f it: Use the parser from SQLcl to filter valid statements from Oracle docs
- f1ae98d it: Update the extraction of example from the Oracle docs to include a subfolder with the "book" name
- f4d32bb it: Remove unused oracle-database_19 folder
- 4e7970d Add test files from the antlr/grammars-v4 repository
- b1c7a4b Update test files from Oracle 19c to Oracle 23ai
- 7c8f200 Update integration test expectations
🧰 Tasks
- d2103da it: Update sources and test expectations
- 8f822c3 Add .kotlin to .gitignore
- 88152d8 Regenerate .json files for the integration test expectations
- bba9491 Fix license header
🛠 Build
- f3b6efc Release 3.5.0
- a67b1bf Use the official release SonarQube 10.6 for integration tests
- 9584478 Update build workflow
- 4e9ed91 Store the download SQLcl in the build-artifacts
- 0a7c3b6 Update to Gradle 8.8
- b7b6767 Change shadow plugin to io.github.goooler.shadow
- 938c1ed Simplify the build workflow to avoid rebuilding the project multiple times
- bbc36d6 Update build plugins
- 211e894 deps: Update Kotlin to 2.0.0
- 866854f Fix compilation warnings
- 3389608 Add dependency-submission to GitHub workflow
- 769f728 deps: Use FLR 1.4.0-SNAPSHOT
- 323d9ce Bump project version
📝 Documentation
Release 3.4.0
SonarQube compatibility
This version is compatible with SonarQube 9.9 LTS and SonarQube 10.5 Community Edition.
It may work with the commercial editions of SonarQube, but you won't be able to use ZPA and the embedded PL/SQL plugin from SonarSource to analyze the code simultaneously. If you need this scenario, please use zpa-cli instead.
Highlights
Install/update instructions
- Download the sonar-zpa-plugin-3.4.0.jar and copy it to the SONARQUBE_HOME/extensions/plugins.
- Remove the older plugin from that directory.
- Restart the SonarQube instance.
For custom plugin developers
Binary compatibility is not guaranteed either in between any version number change. Custom plugins should be recompiled against the same version of sonar-zpa-plugin
.
Download the zpa-toolkit-3.4.0.jar (requires Java 11+) to test the parser and view the AST.
Full changelog
🚀 Features
- 7cae5e0 grammar: Improve parsing of ALTER TRIGGER/PROCEDURE/FUNCTION/PACKAGE
- ffa0f67 grammar: Support CREATE/DROP DIRECTORY
- 3f206ed toolkit: Highlight comment nodes when clicking on the corresponding trivia in the AST tree
- d206e03 toolkit: Highlight comment nodes when clicking on the corresponding trivia in the AST tree
- 2d22d47 toolkit: Change the color of the highlighter from gray to a light blueish color
- 5df2de6 grammar: Support TABLE expressions with queries
- 111d864 grammar: Support CURSOR expressions
🐛 Fixes
- 7c1ee44 grammar: Don't consider SELECT_EXPRESSION as a valid expression for all cases, this is necessary to avoid parsing errors like '1 + select 1 from dual' that was being considered valid
- 8344096 Refactor operator handling in PlSqlGrammar (#181), closes #181
🛠 Build
- fc4bc41 Release 3.4.0
- 0485465 Update to Gradle 8.7
- 8c58095 Enable SonarScanner logs
- a8c4658 Change the directory where integration test failures are saved
- 7c573fc Bump project version
📝 Documentation
- 7547f7b Update release template and README
Release 3.3.1
SonarQube compatibility
This version is compatible with SonarQube 9.9 LTS and SonarQube 10.4 Community Edition.
It may work with the commercial editions of SonarQube, but you won't be able to use ZPA and the embedded PL/SQL plugin from SonarSource to analyze the code simultaneously. If you need this scenario, please use zpa-cli instead.
Highlights
Install/update instructions
- Download the sonar-zpa-plugin-3.3.1.jar and copy it to the SONARQUBE_HOME/extensions/plugins.
- Remove the older plugin from that directory.
- Restart the SonarQube instance.
For custom plugin developers
Binary compatibility is not guaranteed either in between any version number change. Custom plugins should be recompiled against the same version of sonar-zpa-plugin
.
Download the zpa-toolkit-3.3.1.jar (requires Java 11+) to test the parser and view the AST.
Full changelog
🐛 Fixes
- 7744f16 Fix lexer to correctly handle binding and host/indicator variables (#181), closes #181
- 56b0a67 Fix lexer to correctly handle national character literals (#181), closes #181
- ce1368f Update list of reserved keywords (closes #179), closes #179
- 1254a36 Add missing set operators from Oracle 20c+ (minus all, intersect all, except, and except all)
- e719d2b Check exception declarations in VariableHidingCheck (closes #180), closes #180
🧰 Tasks
- 9c3a4f5 Update .editorconfig
🛠 Build
- ce4fb60 Release 3.3.1
- af6f456 Reintroduce integration tests with the upcoming SonarQube version
- 15ee987 Bump project version
- 20afa2d Bump project version
📝 Documentation
Release 3.3.0
SonarQube compatibility
This version is compatible with SonarQube 9.9 LTS and SonarQube 10.4 Community Edition.
It may work with the commercial editions of SonarQube, but you won't be able to use ZPA and the embedded PL/SQL plugin from SonarSource to analyze the code simultaneously. If you need this scenario, please use zpa-cli instead.
Highlights
- The property
sonar.zpa.file.suffixes
was renamed tosonar.plsqlopen.file.suffixes
due to changes in SonarQube 10.4. - To support the "Analyzers loading optimization" feature from SonarQube 10.4, custom plugins must set the
Plugin-RequiredForLanguages
toplsqlopen
. See the Gradle example here and the Maven example here.
Install/update instructions
- Download the sonar-zpa-plugin-3.3.0.jar and copy it to the SONARQUBE_HOME/extensions/plugins.
- Remove the older plugin from that directory.
- Restart the SonarQube instance.
For custom plugin developers
Binary compatibility is not guaranteed either in between any version number change. Custom plugins should be recompiled against the same version of sonar-zpa-plugin
.
Download the zpa-toolkit-3.3.0.jar (requires Java 11+) to test the parser and view the AST.
Full changelog
🚀 Features
- 25f8dc4 Improve the error messages in PlSqlCheckVerifierTest assertions
- 1399943 Set the attribute "Plugin-RequiredForLanguages" in the plugin manifest to support the "Analyzers loading optimization" feature from SonarQube 10.4
- 5732e53 Rename property "sonar.zpa.file.suffixes" to "sonar.plsqlopen.file.suffixes"
- 84fd1d5 perf: Small improvement in PlSqlCommentAnalyzer.getContents
- 3e7eccf Optimize memory usage when lexing whitespace
- 65c85d7 Optimize memory usage when lexing identifiers
- ffffccb Optimize memory usage when lexing date literals
- e1ccbea Optimize memory usage when lexing string literals
- 5b7bba5 Optimize memory usage when lexing numeric literals
- b853469 Optimize memory usage when lexing comments
- 437b569 Optimize memory usage in RegexPunctuatorChannel by minimizing Regex usage
- 975a8df Replace usages of Enum.values() by Enum.entries (new in Kotlin 1.9)
- 42ec1f0 Add a name property to all datatype classes
- c160256 Add a name property to AssociativeArrayDatatype and RecordDatatype
- 5d21223 Update plsql-custom-plugin example for zpa-cli compatibility
- c8f6249 Add properties to ZpaActiveRule for zpa-cli integration
- e5b0b3f Use Rula and Priority annotations from the zpa-core module on custom rules
- 0bf214f grammar: Support GROUP BY GROUPING SETS (#168), closes #168
- d9989b8 grammar: Support GROUP BY ROLLUP/CUBE
🐛 Fixes
- b7bf156 core: Change plSqlDatatype and plSqlType attributes on SemanticAstNode to non-nullable
- d7e9910 checks: Fix bounds check on ToCharInOrderByCheck (closes #165), closes #165
🔄️ Changes
- 9aa1597 Implement an optimized channel for integers without using regex
- 4aeaed9 Avoid capturing groups on the regexes used by the lexer
- 548d60a Simplify comparison
- eabbf3d Replace internal comparator class by a lambda
🧰 Tasks
🛠 Build
- e6a61d8 Release 3.3.0
- c40c9a6 Update to FLR 1.3.0
- 2d01d07 Rename job name from "Integration tests" to "IT" in GitHub Actions workflow
- 4ca6ac6 Update the sonar-orchestrator version and removes the DEV version from the integration tests matrix (because SonarSource made their repository private)
- 68be10a Configure the jvm target in the kotlin plugin
- 4d3acb4 Update to Gradle 8.6
- cce21b9 Run Gradle with JDK 21
- d5e29a3 Enable 'continue-on-error' in GitHub workflow for integration tests
- 97bb37b Set sonar.gradle.skipCompile=true
- f4237dd Update GitHub Actions to use newer versions and revise build commands
- 27b3b2c Update to Gradle 8.5 and Kotlin 1.9.22
- 0a709e2 Update SonarScanner for Gradle to 4.4.1.3373
- 14a4fe5 Use Kotlin 1.9.10
- 601a77a Use JReleaser 1.8.0
- 8544710 Use Gradle 8.4
- 9b2dbe3 Use FLR 1.3.0-SNAPSHOT
- 9d50cc6 Use Gradle 8.3
- f424ffd Update dependencies
- 2ffd9bc Use Gradle 8.2.1
- 4e11c3b Use Gradle 8.2.1
- 73f44e8 Fetch all commits in gh actions
- 1e3a434 Use JReleaser 1.6.0
- a4d329a Use Gradle 8.1.1 on plsql-custom-rules
- a97fb3b Migrate to GitHub Actions
- d227ab7 Update Azure Pipelines tasks
- 0230d10 Use Kotlin 1.8.20 and Gradle 8.1.1
- 8374e9a Remove the minimize step from sonar-zpa-plugin
- 3437b7f Update azure-pipelines.yaml
- b9c400a Update changelog format
- e75920d Use JReleaser 1.5.1
- 3e7a3dd Use Gradle 8.0.2
- aaa6838 core: Refactor TestPlSqlFile to require a File object (#166), closes #166
- d06a10c Update changelog template
- be8fe65 Always use JDK 17 to run the integration tests
- f27e196 Use Gradle 8.0.1
- 832f9f9 Update SonarScanner for Gradle
- 012a82a deps: Bump minimum SonarQube version to 9.9 LTS
📝 Documentation
Release 3.2.1
SonarQube compatibility
This version supports SonarQube 8.9 LTS and newer.
Please be aware that ZPA is only tested with SonarQube Community Edition. It may work with the commercial editions of SonarQube, but you won't be able to use ZPA and the embedded PL/SQL plugin from SonarSource to analyze the code simultaneously. If you need this scenario, please use zpa-cli instead.
Install/update instructions
- Download the sonar-zpa-plugin-3.2.1.jar and copy it to the SONARQUBE_HOME/extensions/plugins.
- Remove the older plugin from that directory.
- Restart the SonarQube instance.
For custom plugin developers
Binary compatibility is not guaranteed either in between any version number change. Custom plugins should be recompiled against the same version of sonar-zpa-plugin
.
Download the zpa-toolkit-3.2.1.jar (requires Java 11+) to test the parser and view the AST.
Changelog
🐛 Fixes
- 28401ad fix(grammar): Accept PARALLEL_ENABLE on functions declarations
- 697d87a fix(grammar): Fix EXISTS_EXPRESSION to parse the subquery correctly
🛠 Build
Release 3.2.0
SonarQube compatibility
This version supports SonarQube 8.9 LTS and newer.
Please be aware that ZPA is only tested with SonarQube Community Edition. It may work with the commercial editions of SonarQube, but you won't be able to use ZPA and the embedded PL/SQL plugin from SonarSource to analyze the code simultaneously. If you need this scenario, please use zpa-cli instead.
Install/update instructions
- Download the sonar-zpa-plugin-3.2.0.jar and copy it to the SONARQUBE_HOME/extensions/plugins.
- Remove the older plugin from that directory.
- Restart the SonarQube instance.
For custom plugin developers
Binary compatibility is not guaranteed either in between any version number change. Custom plugins should be recompiled against the same version of sonar-zpa-plugin
.
Download the zpa-toolkit-3.2.0.jar (requires Java 11+) to test the parser and view the AST.
Changelog
🚀 Features
- 972cbd7 grammar: Support table expression ("table(...)")
- b20d9f0 grammar: Support constraints on custom datatypes (closes #158)
- 7be7f84 grammar: Add EXCEPTION_DECLARATION and classify the exceptions as PlSqlType.EXCEPTION
- 6e339b6 grammar: Add an EXCEPTION_HANDLERS node to group all exception handlers
- b31cb1b grammar: Group parameter declarations under a new PARAMETER_DECLARATIONS node
- 36bee18 grammar: Support extended iterators from Oracle 21c
- 6aab1e4 grammar: Add support for qualified expressions from Oracle 21c
- 94c43b4 toolkit: Add a new tab on zpa-toolkit to show scopes and symbols identified
- 504df79 toolkit: Change zpa-toolkit look and feel
- 25d0d10 toolkit: Implement the "click-to-highlight" feature on the new "symbol tree" on zpa-toolkit
- fee4525 toolkit: Add "Statistics" tab on zpa-toolkit
- 73d0fbc Convert some methods to properties on Scope/Symbol
- eda8399 Improve symbol usage tracker to handle qualified variables (#125)
- 12ff703 Add Symbol.innerScope to simplify the access to the symbols declared inside program units and cursors
🐛 Fixes
- b631d88 grammar: Use MEMBER_EXPRESSION instead of CUSTOM_DATATYPE in REF/ANCHORED_DATATYPE
- 70b1add grammar: Fix CHARACTER_DATATYPE_CONSTRAINT
- 83cada8 Reduce usage of RegexPunctuatorChannel on PlSqlLexer to avoid unnecessary parsing with regexes
🧰 Tasks
- 1e28a5f Bump minimum SonarQube version to 8.9
3.1.1
Fixes:
- "ClassNotFoundException: org.jaxen.saxpath.base.XPathReader" exception on XPath rules (#154).
Install/update instructions:
- Copy the
sonar-zpa-plugin-3.1.1.jar
file to SONARQUBE_HOME/extensions/plugins. - Remove the older plugin from that directory.
- Restart the SonarQube instance.
For custom plugin developers:
- There are no changes affecting custom plugins.
3.1.0
This version Improves performance on multi-core processors (#153). This option can be disabled through the SonarQube UI on "General Settings" > "Z PL/SQL Analyzer" > "Enable concurrent execution" or setting the property sonar.zpa.concurrentExecution=false
.
This version supports SonarQube 7.6 and newer and it's the last release supporting SonarQube 7.6. Please be aware that ZPA is only tested with SonarQube Community Edition. It may work with the commercial editions of SonarQube, but you'll have to choose if you want to use ZPA or SonarPLSQL (from SonarSource). You can't use both plugins to analyze the code simultaneously.
The next release will require SonarQube 8.9 LTS as minimum version.
Install/update instructions:
- Copy only the
sonar-zpa-plugin-3.1.0.jar
file to the SONARQUBE_HOME/extensions/plugins. - Remove the older plugin (
sonar-plsql-open-plugin*.jar
orsonar-zpa*.jar
) from that directory. - Restart the SonarQube instance.
For custom plugin developers:
- There are no changes affecting custom plugins.