Java, Kotlin, and Groovy
All Qodana linters are based on JetBrains IDEs designed for particular programming languages and frameworks. To analyze Java projects, you can use the following linters:
The Qodana for JVM and Qodana for Android linters based on IntelliJ IDEA Ultimate and licensed under the Ultimate and Ultimate Plus licenses,
The Qodana Community for JVM and Qodana Community for Android linters based on IntelliJ IDEA Community and licensed under the Community license.
To see the list of supported technologies and features, you can navigate to the Supported technologies and features section.
Before your start
Before running Qodana, you may need to configure the JDK for your project.
Qodana Cloud
Depending on a linter, you may need to obtain a project token that will be used by Qodana for identifying and verifying a license, follow the steps below:
Navigate to Qodana Cloud and create an account there.
In Qodana Cloud, create an organization, a team, and a project.
On the project card, you can find the project token that you will be using further in this section.
Prepare your software
On the
tab of the GitHub UI, create theQODANA_TOKEN
encrypted secret and save the project token as its value.On the
tab of the GitHub UI, set up a new workflow and save the following workflow configuration to the.github/workflows/code_quality.yml
file:name: Qodana on: workflow_dispatch: pull_request: push: branches: - main jobs: qodana: runs-on: ubuntu-latest permissions: contents: write pull-requests: write checks: write steps: - uses: actions/checkout@v3 with: ref: ${{ github.event.pull_request.head.sha }} # to check out the actual pull request commit, not the merge commit fetch-depth: 0 # a full history is required for pull request analysis - name: 'Qodana Scan' uses: JetBrains/qodana-action@v2024.2 with: # Uncomment the linter you wish to use # args: --linter,jetbrains/qodana-jvm:2024.2 # args: --linter,jetbrains/qodana-jvm-community:2024.2 # args: --linter,jetbrains/qodana-jvm-android:2024.2 # args: --linter,jetbrains/qodana-android:2024.2 env: QODANA_TOKEN: ${{ secrets.QODANA_TOKEN }}This configuration sample will be modified throughout the section.
In Jenkins, make sure that these plugins are up and running:
Docker and Docker Pipeline are required for running Docker images,
git is required for git operations in Jenkins projects.
Make sure that Docker is installed and accessible by Jenkins.
If applicable, make sure that Docker is accessible by the
jenkins
user as described in the Manage Docker as a non-root user section of the Docker documentation.In Jenkins, create the
qodana-token
credential and save the project token as its value.In Jenkins, create a Multibranch Pipeline project as described on the Jenkins documentation portal.
Make sure that your project repository is accessible by GitLab CI/CD.
In GitLab CI/CD, create the
$qodana_token
variable and save the project token as its value.
In TeamCity, Create a project and a build configuration.
Install Docker on the machine were you are going to run Qodana.
If you are using Linux, you should be able to run Docker under your current non-root user.
Follow the instructions from the Qodana CLI page on GitHub.
Run this command to pull the Docker image of a required linter:
Here, <linter>
refers to one of the following linters:
jetbrains/qodana-jvm:2024.2
jetbrains/qodana-jvm-community:2024.2
jetbrains/qodana-jvm-android:2024.2
jetbrains/qodana-android:2024.2
Run Qodana
You can run the linters in two modes:
The native mode is the recommended method that lets you run linters without using Docker containers,
The container mode is an alternative that involves Docker containers.
The qodana.yaml
file is a universal method of the native mode configuration. Alternatively, you can configure it without using the qodana.yaml
file.
Save the following configuration in the
qodana.yaml
file:ide: QDJVM
for the Qodana for JVM linter,ide: QDJVMC
for the Qodana Community for JVM linter.
You can run Qodana using the Qodana Scan GitHub action.
To inspect the
main
branch, release branches and the pull requests coming to your repository in the native mode, save this workflow configuration to the.github/workflows/code_quality.yml
file:name: Qodana on: workflow_dispatch: pull_request: push: branches: # Specify your branches here - main # The 'main' branch - 'releases/*' # The release branches jobs: qodana: runs-on: ubuntu-latest permissions: contents: write pull-requests: write checks: write steps: - uses: actions/checkout@v3 with: ref: ${{ github.event.pull_request.head.sha }} # to check out the actual pull request commit, not the merge commit fetch-depth: 0 # a full history is required for pull request analysis - name: 'Qodana Scan' uses: JetBrains/qodana-action@v2024.2 env: QODANA_TOKEN: ${{ secrets.QODANA_TOKEN }}
You can run Qodana using the Qodana Scan GitHub action.
To inspect the main
branch, release branches and the pull requests coming to your repository in the native mode, save this workflow configuration to the .github/workflows/code_quality.yml
file:
Here, <linter-code>
refers to one of the following linters:
| Linter |
---|---|
| Qodana for JVM |
| Qodana Community for JVM |
More configuration examples are available in the GitHub Actions section.
Save the following configuration in the
qodana.yaml
file:ide: QDJVM
for the Qodana for JVM linter,ide: QDJVMC
for the Qodana Community for JVM linter.
Run this command in the project root directory:
qodana scan \ -e QODANA_TOKEN="<qodana-cloud-token>"In your browser, open Qodana Cloud to examine analysis results and reconfigure the analysis, see the Inspection report section for details.
Run this command in the project root directory:
Here, <linter-code>
refers to one of the following linters:
| Linter |
---|---|
| Qodana for JVM |
| Qodana Community for JVM |
In your browser, open Qodana Cloud to examine analysis results and reconfigure the analysis, see the Inspection report section for details.
The container mode is available for all linters; however, we recommend that you use the native mode whenever possible.
To analyze the main
branch, release branches and the pull requests coming to your repository in the container mode, save this workflow configuration to the .github/workflows/code_quality.yml
file:
More configuration examples are available in the GitHub Actions section.
Save this configuration to the Jenkinsfile
:
More configuration examples are available in the Jenkins section.
In the root directory of your project, save this snippet to the .gitlab-ci.yml
file:
In this snippet:
The
cache
keyword configures GitLab CI/CD caches to store the Qodana cache, so subsequent runs will be faster,The
script
keyword runs theqodana
command and enumerates the Qodana configuration options described in the Shell commands section,The
variables
keyword defines theQODANA_TOKEN
variable referring to the project token.
More configuration examples are available in the GitLab CI/CD section.
In the TeamCity UI, navigate to the configuration page of a build where you would like to run Qodana.
- page, navigate to the
On the
page, click the button.On the page that opens, select the
runner.On the
page, click and configure the runner:uniquely identifies this step among other build steps.
uniquely identifies this step among other build steps.
configures the build condition that will trigger this build step.
TeamCity documentation for details. You can leave this field empty if the
sets the directory for the build process, see theCheckout directory
parameter is specified on the tab.uniquely identifies the report to let you distinguish between multiple reports when several inspection steps are configured within a single build.
The Test tab of the TeamCity UI. Using this option, you can view codebase problems along with other problems detected.
checkbox configures Qodana report availability in the- configures the
Here, select either the Qodana for JVM, Qodana Community for JVM, Qodana Community for Android or the Qodana for Android linter.
is by default set toLatest
.- defines an
Recommended (default)
is one of the default profiles.Embedded profile
lets you select a default profile, see the Existing Qodana profiles section for details.Path to the IntelliJ profile
lets you specify the path to your custom profile. To use this option, make sure that you also configure the custom profile in theqodana.yaml
file.
project token generated in Qodana Cloud.
configures aShell commands section for details.
configures the arguments accepted by a Docker image, see theOptions section for details.
lets you extend the default Qodana functionality, see the
Click the
button.
More configuration examples are available in the TeamCity section.
Here, <linter>
refers to one of the following linters:
jetbrains/qodana-jvm:2024.2
jetbrains/qodana-jvm-community:2024.2
jetbrains/qodana-jvm-android:2024.2
jetbrains/qodana-android:2024.2
Here, <linter>
refers to one of the following linters:
jetbrains/qodana-jvm:2024.2
jetbrains/qodana-jvm-community:2024.2
jetbrains/qodana-jvm-android:2024.2
jetbrains/qodana-android:2024.2
In your browser, open Qodana Cloud to examine analysis results and reconfigure the analysis, see the Inspection report section for details.
In IntelliJ IDEA Ultimate, navigate to
.On the
dialog, you can configure Qodana.This dialog contains the following components:
Name
Description
The
qodana.yaml
fileIn the text field, you can set up code analysis used by Qodana in this file. You can learn more about available configuration options
The
optionIf you want to send reports to Qodana Cloud, you can check this option and paste the project token generated in Qodana Cloud
The
optionBy checking this option, you can save the Qodana configuration made on this dialog to the
qodana.yaml
file in the project root of your projectThe
optionUsing the baseline feature, you can skip analysis for specific problems
Click
for analyzing your code.On the inspection results.
tab of the tool window, see the
Explore analysis results
You can load the latest Qodana report from Qodana Cloud to your IDE as explained below.
In your IDE, navigate to
.On the
dialog, click .This will redirect you to the authentication page.
Select the Qodana Cloud project to link your local project with.
If you check the
option, you will be able to receive the most actual and relevant reports from Qodana Cloud.In this case, the IDE will search and fetch from Qodana Cloud the report that has the revision ID corresponding to the current revision ID (HEAD). If this report was not found, the IDE will select the previous report with the revision closest to the current revision ID (HEAD). Otherwise, the IDE retrieves the latest available report from Qodana Cloud.
On the analysis results.
tab of the tool window, view
After Qodana analyzed your project and uploaded the analysis results to Qodana Cloud, in Qodana Cloud navigate to your project and review the analysis results report.
To learn more about Qodana report UI, see the Inspection report section.
Extend Qodana configuration
Adjusting the scope of analysis
Out of the box, Qodana provides two predefined profiles hosted on GitHub:
qodana.starter
is the default profile and a subset of the more comprehensiveqodana.recommended
profile,qodana.recommended
is suitable for running in CI/CD pipelines and mostly implements the default IntelliJ IDEA Ultimate profile, see the IntelliJ IDEA Ultimate documentation for details.
You can customize Qodana profiles using configurations in YAML and XML formats. To learn more about configuration basics, visit the Configure Qodana your way section.
Enabling the baseline
You can skip analysis for specific problems using the baseline feature. Information about a baseline is contained in a SARIF-formatted file.
Save the following configuration in the
qodana.yaml
file:ide: QDJVM
for the Qodana for JVM linter,ide: QDJVMC
for the Qodana Community for JVM linter.
Save the snippet to the
.github/workflows/code_quality.yml
file containing theargs: --baseline,qodana.sarif.json
option that specifies the path to the SARIF-formatted baseline file:name: Qodana on: workflow_dispatch: pull_request: push: branches: # Specify your branches here - main # The 'main' branch - 'releases/*' # The release branches jobs: qodana: runs-on: ubuntu-latest permissions: contents: write pull-requests: write checks: write steps: - uses: actions/checkout@v3 with: ref: ${{ github.event.pull_request.head.sha }} # to check out the actual pull request commit, not the merge commit fetch-depth: 0 # a full history is required for pull request analysis - name: 'Qodana Scan' uses: JetBrains/qodana-action@v2024.2 env: QODANA_TOKEN: ${{ secrets.QODANA_TOKEN }}
Save the snippet to the .github/workflows/code_quality.yml
file containing the args: --baseline,qodana.sarif.json
option that specifies the path to the SARIF-formatted baseline file:
Here, <linter-code>
refers to one of the following linters:
| Linter |
---|---|
| Qodana for JVM |
| Qodana Community for JVM |
Save the following configuration in the
qodana.yaml
file:ide: QDJVM
for the Qodana for JVM linter,ide: QDJVMC
for the Qodana Community for JVM linter.
Run this command in the project root directory using the
--baseline,<path/to/qodana.sarif.json>
option to specify the path to a SARIF-formatted file containing a baseline:qodana scan \ -e QODANA_TOKEN="<qodana-cloud-token>" \ --baseline <path/to/qodana.sarif.json>In your browser, open Qodana Cloud to examine analysis results and reconfigure the analysis, see the Inspection report section for details.
Run this command in the project root directory using the --baseline,<path/to/qodana.sarif.json>
option to specify the path to a SARIF-formatted file containing a baseline:
Here, <linter-code>
refers to one of the following linters:
| Linter |
---|---|
| Qodana for JVM |
| Qodana Community for JVM |
In your browser, open Qodana Cloud to examine analysis results and reconfigure the analysis, see the Inspection report section for details.
Save this snippet to the .github/workflows/code_quality.yml
file containing the args: --baseline,qodana.sarif.json
option that specifies the path to the SARIF-formatted baseline file:
In the Jenkinsfile
, save the configuration containing the --baseline <path/to/qodana.sarif.json>
line that specifies the path to the SARIF-formatted baseline file:
In the root directory of your project, save this snippet to the .gitlab-ci.yml
file and uncomment the linter that you would like to employ:
The --baseline <path/to/qodana.sarif.json>
line in the script
block invokes the baseline feature.
In the TeamCity UI, navigate to the configuration page of a build where you would like to run Qodana.
- page, navigate to the
On the
page, click the button.On the page that opens, select the
runner.On the
page, click and configure the runner:uniquely identifies this step among other build steps.
uniquely identifies this step among other build steps.
configures the build condition that will trigger this build step.
TeamCity documentation for details. You can leave this field empty if the
sets the directory for the build process, see theCheckout directory
parameter is specified on the tab.uniquely identifies the report to let you distinguish between multiple reports when several inspection steps are configured within a single build.
The Test tab of the TeamCity UI. Using this option, you can view codebase problems along with other problems detected.
checkbox configures Qodana report availability in the- configures the
Here, select either the Qodana for JVM, Qodana Community for JVM, Qodana Community for Android or the Qodana for Android linter.
is by default set toLatest
.- defines an
Recommended (default)
is one of the default profiles.Embedded profile
lets you select a default profile, see the Existing Qodana profiles section for details.Path to the IntelliJ profile
lets you specify the path to your custom profile. To use this option, make sure that you also configure the custom profile in theqodana.yaml
file.
project token generated in Qodana Cloud.
configures aShell commands section for details.
configures the arguments accepted by a Docker image, see theOptions section for details.
lets you extend the default Qodana functionality, see theIn this field, specify the baseline feature using the
--baseline <path/to/qodana.sarif.json>
option.
Click the
button.
Choose how you would like to run the baseline feature from the command line:
Here, <linter>
refers to one of the following linters:
jetbrains/qodana-jvm:2024.2
jetbrains/qodana-jvm-community:2024.2
jetbrains/qodana-jvm-android:2024.2
jetbrains/qodana-android:2024.2
Here, <linter>
refers to one of the following linters:
jetbrains/qodana-jvm:2024.2
jetbrains/qodana-jvm-community:2024.2
jetbrains/qodana-jvm-android:2024.2
jetbrains/qodana-android:2024.2
In your IDE, navigate to the
tool window.In the
tool window, click the tab.On the
tab, click the button.On the dialog that opens, expand the
section and specify the path to the baseline file, and then click .
Enabling the quality gate
Depending on the linter, you can configure quality gates for:
The total number of project problems, available for all linters,
Multiple quality gates for problem severities, available for all linters,
Code coverage thresholds, available for the Qodana for JVM and Qodana for Android linters.
You can configure quality gates for the total number of project problems, specific problem severities and code coverage by saving this snippet to the qodana.yaml
file:
You can configure quality gates for the total number of project problems and specific problem severities by saving this snippet to the qodana.yaml
file:
Analyzing pull requests
Save the following configuration in the
qodana.yaml
file:ide: QDJVM
for the Qodana for JVM linter,ide: QDJVMC
for the Qodana Community for JVM linter.
The Qodana Scan GitHub action automatically analyzes all pull requests, so you do not have to provide any additional configuration. Save this configuration to the
.github/workflows/code_quality.yml
file:name: Qodana on: workflow_dispatch: pull_request: push: branches: # Specify your branches here - main # The 'main' branch - 'releases/*' # The release branches jobs: qodana: runs-on: ubuntu-latest permissions: contents: write pull-requests: write checks: write steps: - uses: actions/checkout@v3 with: ref: ${{ github.event.pull_request.head.sha }} # to check out the actual pull request commit, not the merge commit fetch-depth: 0 # a full history is required for pull request analysis - name: 'Qodana Scan' uses: JetBrains/qodana-action@v2024.2 env: QODANA_TOKEN: ${{ secrets.QODANA_TOKEN }}
The Qodana Scan GitHub action automatically analyzes all pull requests, so you do not have to provide any additional configuration. Save this configuration to the .github/workflows/code_quality.yml
file:
Here, <linter-code>
refers to one of the following linters:
| Linter |
---|---|
| Qodana for JVM |
| Qodana Community for JVM |
Save the following configuration in the
qodana.yaml
file:ide: QDJVM
for the Qodana for JVM linter,ide: QDJVMC
for the Qodana Community for JVM linter.
To analyze changes in your code, employ the
--diff-start
option and specify a hash of the commit that will act as a base for comparison:qodana scan \ -e QODANA_TOKEN="<cloud-project-token>" \ --diff-start=<GIT_START_HASH>In your browser, open Qodana Cloud to examine analysis results and reconfigure the analysis, see the Inspection report section for details.
To analyze changes in your code, employ the --diff-start
option and specify a hash of the commit that will act as a base for comparison:
Here, <linter-code>
refers to one of the following linters:
| Linter |
---|---|
| Qodana for JVM |
| Qodana Community for JVM |
In your browser, open Qodana Cloud to examine analysis results and reconfigure the analysis, see the Inspection report section for details.
The Qodana Scan GitHub action automatically analyzes all pull requests, so you do not have to provide any additional configuration. Save this configuration to the .github/workflows/code_quality.yml
file:
In the root directory of your project, save the .gitlab-ci.yml
file containing the following snippet:
Here, the --diff-start
option specifies a hash of the commit that will act as a base for comparison.
Information about configuring TeamCity for analyzing pull and merge requests is available on the TeamCity documentation portal.
To analyze changes in your code, employ the --diff-start
option and specify a hash of the commit that will act as a base for comparison:
Here, <linter>
refers to one of the following linters:
jetbrains/qodana-jvm:2024.2
jetbrains/qodana-jvm-community:2024.2
jetbrains/qodana-jvm-android:2024.2
jetbrains/qodana-android:2024.2
Here, <linter>
refers to one of the following linters:
jetbrains/qodana-jvm:2024.2
jetbrains/qodana-jvm-community:2024.2
jetbrains/qodana-jvm-android:2024.2
jetbrains/qodana-android:2024.2
Supported technologies and features
Support for | Name | Qodana for JVM and Qodana for Android | Qodana Community for JVM | Qodana Community for Android |
---|---|---|---|---|
Programming languages | Java Kotlin Groovy | ✔ ✔ ✔ | ✔ ✔ ✔ | ✔ ✔ ✔ |
Frameworks and libraries | JavaBeans JUnit Lombok TestNG JPA Reactive Streams JavaFX Java EE JAX-RS JSP Spring | ✔ ✔ ✔ ✔ ✔ ✔
✔ ✔ ✔ ✔ | ✔ ✔ ✔ ✔ ✔ ✔
| ✔ ✔
✔
✔
|
Databases and ORM | Hibernate ORM MongoDB Oracle MySQL PostgreSQL SQL SQL server | ✔ ✔ ✔ ✔ ✔ ✔ ✔ |
|
|
Markup languages | CSS FreeMarker HTML JSON and JSON5 RELAX NG XML XPath XSLT YAML TOML | ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔ |
✔ ✔ ✔ ✔
|
✔ ✔ ✔ ✔
✔ ✔ |
Scripting languages | Shell script Expression Language (EL) | ✔ ✔ |
| ✔
|
Build management | Ant Gradle Maven | ✔ ✔ ✔ | ✔ ✔ ✔ | ✔ ✔ ✔ |
Qodana features | ✔ ✔ ✔ ✔ ✔ ✔ | ✔ ✔
| ✔ ✔
|