From 3b7081856729bcc8b584c08d1eec6b231303d812 Mon Sep 17 00:00:00 2001 From: Pearl Dsilva Date: Wed, 14 Jan 2026 11:34:16 -0500 Subject: [PATCH] Add support for errorprone 2.24.1 static analysis tool and Github Action to check for issues reported --- .github/workflows/errorprone.yml | 93 ++++++++++++++++++++++++++++++++ pom.xml | 19 +++++-- 2 files changed, 108 insertions(+), 4 deletions(-) create mode 100644 .github/workflows/errorprone.yml diff --git a/.github/workflows/errorprone.yml b/.github/workflows/errorprone.yml new file mode 100644 index 00000000000..dc391c62c91 --- /dev/null +++ b/.github/workflows/errorprone.yml @@ -0,0 +1,93 @@ +# Licensed to the Apache Software Foundation (ASF) under one +# or more contributor license agreements. See the NOTICE file +# distributed with this work for additional information +# regarding copyright ownership. The ASF 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. + +name: Error Prone Analysis + +on: + push: + branches: [ main ] + pull_request: + branches: [ main ] + +concurrency: + group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }} + cancel-in-progress: true + +permissions: + contents: read + +jobs: + errorprone: + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v4 + + - name: Set up JDK 11 + uses: actions/setup-java@v4 + with: + java-version: '11' + distribution: 'adopt' + architecture: x64 + cache: maven + + - name: Run Error Prone Static Analysis (Strict Mode) + run: | + echo "::group::Error Prone Analysis" + # Temporarily remove -XepAllErrorsAsWarnings to run in strict mode + sed -i 's/-Xplugin:ErrorProne -XepAllErrorsAsWarnings/-Xplugin:ErrorProne/g' pom.xml + mvn clean compile -DskipTests -T$(nproc) 2>&1 | tee errorprone.log + BUILD_RESULT=$? + echo "::endgroup::" + exit $BUILD_RESULT + continue-on-error: true + + - name: Check for Error Prone Issues + id: check-errors + run: | + if grep -q "error: \[" errorprone.log; then + echo "has_errors=true" >> $GITHUB_OUTPUT + echo "::error::Error Prone found issues in the code" + echo "" + echo "=== Error Prone Issues Found ===" + grep -B 2 "error: \[" errorprone.log | head -50 + echo "" + + # Create job summary + echo "## ⚠️ Error Prone Analysis Failed" >> $GITHUB_STEP_SUMMARY + echo "" >> $GITHUB_STEP_SUMMARY + echo "Error Prone static analysis detected issues in this PR." >> $GITHUB_STEP_SUMMARY + echo "" >> $GITHUB_STEP_SUMMARY + echo "### Issues Found (first 50):" >> $GITHUB_STEP_SUMMARY + echo '```' >> $GITHUB_STEP_SUMMARY + grep -B 2 "error: \[" errorprone.log | head -50 >> $GITHUB_STEP_SUMMARY + echo '```' >> $GITHUB_STEP_SUMMARY + echo "" >> $GITHUB_STEP_SUMMARY + echo "See the [Error Prone documentation](https://errorprone.info/) for details on each bug pattern." >> $GITHUB_STEP_SUMMARY + else + echo "has_errors=false" >> $GITHUB_OUTPUT + echo "✅ No Error Prone issues found" + + # Create success summary + echo "## ✅ Error Prone Analysis Passed" >> $GITHUB_STEP_SUMMARY + echo "" >> $GITHUB_STEP_SUMMARY + echo "No issues detected by Error Prone static analysis." >> $GITHUB_STEP_SUMMARY + fi + + - name: Fail if errors found + if: steps.check-errors.outputs.has_errors == 'true' + run: exit 1 + diff --git a/pom.xml b/pom.xml index 6985108302d..fc31667b963 100644 --- a/pom.xml +++ b/pom.xml @@ -80,6 +80,7 @@ 2.22.2 4.4.1 3.2.0 + 2.24.1 2.19.0 @@ -1094,15 +1095,25 @@ ${cs.jdk.version} ${cs.jdk.version} - true - 128m - 512m + UTF-8 -XDignore.symbol.file=true --add-opens=java.base/java.lang=ALL-UNNAMED --add-exports=java.base/sun.security.x509=ALL-UNNAMED --add-exports=java.base/sun.security.provider=ALL-UNNAMED + -XDcompilePolicy=simple + -Xplugin:ErrorProne -XepAllErrorsAsWarnings + + + com.google.errorprone + error_prone_core + ${cs.errorprone.version} + + + true + 128m + 512m @@ -1452,4 +1463,4 @@ - + \ No newline at end of file