Adding analysis to a Jenkins job
This section explains how to add the SonarQube Server analysis to your Jenkins Freestyle or Pipeline jobs.
Note that you can also easily configure and analyze your projects with Jenkins in SonarQube Server through the tutorial in the application.
To be able to add a SonarQube Server analysis to a Jenkins job, Jenkins must have been set up for SonarQube Server integration.
Adding analysis to a Freestyle job
The procedure depends on the project type.
Create and configure your Jenkins job, and go to the Build Environment section.
Enable Prepare SonarScanner environment to allow the injection of SonarQube Server values into this particular job. If multiple SonarQube Server instances are configured, you will be able to choose which one to use. Once the environment variables are available, use them in a standard Maven build step (Invoke top-level Maven targets) by setting the Goals to include, or a standard Gradle build step (Invoke Gradle script) by setting the Tasks to execute.
Maven goal:
$SONAR_MAVEN_GOAL
Gradle task:
sonar
Adding analysis to a Pipeline job
In Jenkins, create your Pipeline job.
Add the SonarQube Server analysis stage to the Jenkins file: see below.
Set up a pipeline pause until the quality gate is computed.
Adding analysis to a Multibranch Pipeline job
This feature is supported from SonarQube Server Developer Edition.
Proceed as follows:
In Jenkins, create your Multibranch Pipeline job.
From your Jenkins job, go to Configure > Branch Sources > Behaviors and:
Under Discover branches, make sure **Exclude branches that are also filed as PRs (**or MRs) is selected.
Under **Discover pull (**or merge) requests from origin, make sure **The current pull (**or merge) request revision is selected.
Under Specify ref specs, make sure the Ref Spec value will include any target branches (the default value should be enough). If the Specify ref specs behavior is not active, click on Add and select Specify ref specs.
Add the SonarQube Server analysis stage to the Jenkins file: see below.
Set up a pipeline pause until the quality gate is computed.
Adding an analysis stage to the Jenkins file
You must use the withSonarQubeEnv
step in the SonarQube Server analysis stage of your pipeline job. This step is used to set the environment variables necessary to connect to the specified SonarQube Server instance. The connection details are retrieved from the Jenkins global configuration.
The withSonarQubeEnv
() method can take the following optional parameters:
installationName
(string): name of the SonarQube Server installation as configured in Jenkins. This is necessary if several SonarQube SonarQube Server hosts are configured in Jenkins.credentialsId
(string): if you want to overwrite the credentials configured in the Jenkins global configuration.envOnly
(boolean): set it to true if you only want the SonarQube Server environment variables to be expanded in the build context
Examples
Note that you don’t need to specify an SCM stage in your Jenkins Pipeline or Multibranch Pipeline job.
Scripted pipeline example:
node {
stage('SonarQube analysis') {
withSonarQubeEnv() { // Will pick the global server connection you have configured
sh './gradlew sonar'
}
}
}
Related pages
Last updated
Was this helpful?