This version of the SonarQube documentation is no longer maintained. It relates to a version of SonarQube that is not active.

SonarScanner for Gradle

The SonarScanner for Gradle provides an easy way to start the analysis of a Gradle project with SonarQube.

SonarScanner for Gradle — 7.0.0.6105 | Issue Tracker

7.0.0.6105 2025-10-14 Support of Gradle 9 Download Release notes


6.3.1.5724 2025-08-27 Fix a bug where the scanner would crash when users would define sonar.sources. Download Release notes


6.3.0.5676 2025-08-25 Index .github folder for analysis. Download Release notes


6.2.0.5505 2025-05-15 Better logging of the execution context and migration from deprecated Gradle APIs. Download Release notes


6.1.0.5360 2025-03-25 Add support for SonarQube Cloud regions Download Release notes


6.0.1.5171 2024-11-27 Support of JRE auto-provisioning Download Release notes


6.0.0.5145 2024-11-19 Support of JRE auto-provisioning Download Release notes


5.1.0.4882 2024-07-04 Scan additional files outside of conventional Gradle folders Download Release notes


5.0.0.4638 2024-03-26 Decouple sonar task from Gradle compile tasks Download Release notes


4.4.1.3373 2023-10-03 Allow the skipping/forcing of compile tasks through the property "sonar.gradle.skipCompile" Download Release notes


4.3.1.3277 2023-09-01 Support for analysis of Gradle Kotlin DSL files Download Release notes


4.2.1.3168 2023-06-12 Support for Kotlin Multiplatform and 'sonar.java.enablePreview' property, Java 11+ required Download Release notes


4.0.0.2929 2023-02-17 Support for Gradle 8 Download Release notes


3.5.0.2730 2022-10-27 New 'sonar' task name and better support for Android projects Download Release notes


3.4.0.2513 2022-06-08 Support Gradle 8 and Java 17, increase socket connect timeout to 30s Download Release notes


3.3 2021-06-10 Support Android dynamic features modules Download Release notes


3.2 2021-04-30 Support configuration caching Download Release notes


3.1.1 2021-01-25 Bug fix on the JDK path Download Release notes


3.1 2021-01-13 Support for Bitbucket Pipelines with SonarQube 8.7+, use JDK from the build Download Release notes


3.0 2020-06-02 Change task dependencies on tests, upgrade to Gradle 5 Download Release notes


2.8 2019-10-01 Support SONAR_HOST_URL environment variable to configure the server URL Download Release notes

The SonarScanner for Gradle provides an easy way to start the scan of a Gradle project.

The ability to execute the SonarScanner analysis via a regular Gradle task makes it available anywhere Gradle is available (developer build, CI server, etc.), without the need to manually download, setup, and maintain a SonarScanner CLI installation. The Gradle build already has much of the information needed for the SonarScanner to successfully analyze a project. By preconfiguring the analysis based on that information, the need for manual configuration is reduced significantly.

Prerequisites

  • Gradle 5+

  • Java 11+

Bytecode created by javac compilation is required for Java analysis, including Android projects.

See also the Scanner environment.

Configure the scanner

Installation is automatic, but certain global properties should still be configured. A good place to configure global properties is ~/.gradle/gradle.properties. Be aware that the scanner uses system properties so all properties should be prefixed by systemProp.

# gradle.properties
systemProp.sonar.host.url=http://localhost:9000

Analyzing

First, you need to activate the scanner in your build. Kotlin DSL is the default choice for new Gradle builds.

Apply the SonarQube plugin dependency to your build.gradle.kts file:

plugins {
    id("org.sonarqube") version "4.4.1.3373"
}

sonar {
  properties {
    property("sonar.projectKey", "myProjectKey")
    property("sonar.host.url", "myHostUrl")
  }
}

Ensure that you declare the plugins in the correct sequence required by Gradle, that is, after the buildscript block in your build.gradle file. More details on Gradle - Plugin: org.sonarqube.

Assuming a local SonarQube server with out-of-the-box settings is up and running, no further configuration is required.

You need to pass an Generating and using tokens using one of the following options:

  • Use the sonar.token property in your command line: Execute gradle sonar -Dsonar.token=yourAuthenticationToken and wait until the build has completed.

  • Create the SONAR_TOKEN environment variable and set the token as its value before you run the analysis.

Once passing your token and running an analysis, open the web page indicated at the bottom of the console output. Your analysis results should be available shortly after the CI-side analysis is complete.

Analyzing multi-project builds

To analyze a project hierarchy, apply the SonarQube plugin to the root project of the hierarchy. Typically (but not necessarily) this will be the root project of the Gradle build. Information pertaining to the analysis as a whole has to be configured in the sonar block of this project. Any properties set on the command line also apply to this project.

A configuration shared between subprojects can be configured in a subprojects block.

// build.gradle
subprojects {
    sonar {
        properties {
            property "sonar.sources", "src"
        }
    }
}

Project-specific information is configured in the sonar block of the corresponding project.

// build.gradle
project(":project1") {
    sonar {
        properties {
            property "sonar.branch.name", "Foo"
        }
    }}

To skip SonarScanner analysis for a particular subproject, set sonarqube.skipProject to true.

// build.gradle
project(":project2") {
    sonar {
        isSkipProject = true
    }
}

Task dependencies

All tasks that produce output that should be included in the SonarScanner analysis need to be executed before the sonar task runs. Typically, these are compile tasks, test tasks, and Overview tasks.

Starting with v3.0 of the SonarScanner for Gradle, task dependencies are no longer added automatically. Instead, the SonarScanner plugin enforces the correct order of tasks with mustRunAfter. You need to be either manually run the tasks that produce output before sonarqube, or you can add a dependency to the build script:

// build.gradle
project.tasks["sonar"].dependsOn "anotherTask"

Sample project

A simple working example is available at this URL so you can check everything is correctly configured in your env: https://github.com/SonarSource/sonar-scanning-examples/tree/master/sonar-scanner-gradle/gradle-basic

Analysis property defaults

The SonarScanner for Gradle uses information contained in Gradle’s object model to provide smart defaults for most of the standard Analysis parameters, as listed below. Note that additional defaults are provided depending on the projects.

Gradle defaults for standard Sonar properties

Property

Gradle default

sonar.projectKey

[${project.group}:]${project.name} for root module; <root module key>:<module path> for submodules

sonar.projectName

${project.name}

sonar.projectDescription

${project.description}

sonar.projectVersion

${project.version}

sonar.projectBaseDir

${project.projectDir}

sonar.working.directory

${project.buildDir}/sonar

Additional defaults for all projects

Property

Description

Gradle default

sonar.gradle.skipCompile

If set to true, it prevents Gradle from compiling before running the sonar task on the project, thus allowing the compilation of a project with one version of the language and the analysis with another (e.g. build with Java 8 as the JDK and run the scanner with Java 17 as the runtime).

false

Additional defaults for projects with Java-base or Java plugin applied

Property

Gradle default

sonar.sourceEncoding

${project.compileJava.options.encoding}

sonar.java.source

${project.targetCompatibility}

sonar.java.target

${project.targetCompatibility}

sonar.sources

${sourceSets.main.allJava.srcDirs} (filtered to only include existing directories)

sonar.tests

${sourceSets.test.allJava.srcDirs} (filtered to only include existing directories)

sonar.java.binaries

${sourceSets.main.output.classesDir}

sonar.java.libraries

${sourceSets.main.compileClasspath} (filtering to only include files; rt.jar and jfxrt.jar added if necessary)

sonar.java.test.binaries

${sourceSets.test.output.classesDir}

sonar.java.test.libraries

${sourceSets.test.compileClasspath} (filtering to only include files; rt.jar and jfxrt.jar added if necessary)

sonar.junit.reportPaths

${test.testResultsDir} (if the directory exists)

Additional default for Groovy projects

Property

Gradle default

sonar.groovy.binaries

${sourceSets.main.output.classesDir}

Additional defaults when JaCoCo plugin is applied

Property

Gradle default

sonar.jacoco.reportPaths

${jacoco.destinationFile}

sonar.groovy.jacoco.reportPath

${jacoco.destinationFile}

Additional defaults for Android projects

Additional defaults are provided for Android projects (com.android.application, com.android.library, or com.android.test). By default the first variant of type debug will be used to configure the analysis. You can override the name of the variant to be used using the parameter androidVariant:

build.gradle
sonar {
    androidVariant 'fullDebug'
}

Property

Gradle default

sonar.sources (for non test variants)

${variant.sourcesets.map} (ManifestFile/CDirectories/AidlDirectories/AssetsDirectories/CppDirectories/JavaDirectories/RenderscriptDirectories/ResDirectories/ResourcesDirectories)

sonar.tests (for test variants)

${variant.sourcesets.map} (ManifestFile/CDirectories/AidlDirectories/AssetsDirectories/CppDirectories/JavaDirectories/RenderscriptDirectories/ResDirectories/ResourcesDirectories)

sonar.java[.test].binaries

${variant.destinationDir}

sonar.java[.test].libraries

${variant.javaCompile.classpath} + ${bootclasspath}

sonar.java.source

${variant.javaCompile.sourceCompatibility}

sonar.java.target

${variant.javaCompile.targetCompatibility}

Passing manual properties / overriding defaults

The SonarScanner for Gradle adds a sonar extension to the project and its subprojects, which allows you to configure/override the analysis properties.

// in build.gradle
sonar {
    properties {
        property "sonar.exclusions", "**/*Generated.java"
    }
}

Sonar properties can also be set from the command line, or by setting a system property named exactly like the Sonar property in question. This can be useful when dealing with sensitive information (e.g. credentials), environment information, or for ad-hoc configuration.

gradle sonar -Dsonar.host.url=http://sonar.mycompany.com -Dsonar.verbose=true

While certainly useful at times, we recommend keeping the bulk of the configuration in a (versioned) build script, readily available to everyone. A Sonar property value set via a system property overrides any value set in a build script (for the same property). When analyzing a project hierarchy, values set via system properties apply to the root project of the analyzed hierarchy. Each system property starting with sonar. will be taken into account.

Analyzing custom source sets

By default, the SonarScanner for Gradle passes on the project’s main source set as production sources, and the project’s test source set as test sources. This works regardless of the project’s source directory layout. Additional source sets can be added as needed.

// build.gradle
sonar {
    properties {
        properties["sonar.sources"] += sourceSets.custom.allSource.srcDirs
        properties["sonar.tests"] += sourceSets.integTest.allSource.srcDirs
    }
}

Advanced topics

More on configuring SonarQube properties

Let’s take a closer look at the sonar.properties block. As we have already seen in the examples, the property method allows you to set new properties or override existing ones. Furthermore, all properties that have been configured up to this point, including all properties preconfigured by Gradle, are available via the properties accessor.

Entries in the properties map can be read and written with the usual Groovy syntax. To facilitate their manipulation, values still have their "idiomatic" type (File, List, etc.). After the sonar.properties block has been evaluated, values are converted to Strings as follows: Collection values are (recursively) converted to comma-separated Strings, and all other values are converted by calling their toString methods.

Because the sonar.properties block is evaluated lazily, properties of Gradle’s object model can be safely referenced from within the block, without having to fear that they have not yet been set.

Troubleshooting

If you get a java.lang.OutOfMemoryError: Metaspace

Increase the metaspace size in your gradle.properties file:

org.gradle.jvmargs=-XX:MetaspaceSize=512M -XX:MaxMetaspaceSize=512M

Last updated

Was this helpful?