Setting up feature integration with Azure DevOps for your project
This page explains how to add SonarQube Server connection (necessary if you use Azure Pipelines) and how to set up the pull request integration with Azure DevOps for your SonarQube Server project.
Adding SonarQube Server service connection to Azure Pipelines (SonarQube Server endpoint)
Service connections are authenticated connections between Azure Pipelines and external or remote services. You must declare your SonarQube Server as a service connection in your Azure DevOps project.
Proceed as follows:
- In SonarQube Server, create an authentication token that will be used by Azure DevOps to execute the analysis of your project in SonarQube Server. To do so, create a Project analysis token for your project and copy it (you may also use a Global analysis token, but it’s not recommended). For more information, see Managing your Tokens.
- In your Azure DevOps project, go to Project Settings > Service connections.
- Select New service connection and then select SonarQube Server from the service connection list.
- Enter your SonarQube Server URL, the token created in the first step, and a memorable Service connection name (You will need this name when configuring your Azure build pipelines). Then, select Save to save your connection.
Setting up pull request integration
SonarQube Server can:
- Report the quality gate status and analysis metrics to your pull requests in Azure DevOps.
- Show issues detected on a pull request in Azure DevOps. Each issue will be a comment on the Azure DevOps pull request. If you change the status of an issue in SonarQube Server, that status change is immediately reflected in the Azure DevOps interface.
The report of the analysis results to your pull requests is supported for monorepo projects starting in Enterprise Edition.
To set up the pull request analysis:
- See the prerequisites in Setting up the pull request analysis.
- Enable the pull request analysis on the target branch: see below.
- When running on Azure Pipelines, the SonarScanners can automatically detect the pull request parameters. If you don't use Azure Pipelines, you must manually set up these parameters: see Setting up the pull request analysis.
- For an unbound project, an additional setup is required: see below.
- You can prevent the pull request merge if the quality gate fails: see below.
Enabling pull request analysis on target branch
To ensure that all of your pull requests get automatically analyzed:
- Add a build validation branch policy on the target branch.
Additional setup for an unbound project
For an unbound project (a project not created by importing the corresponding Azure DevOps repository), an additional setup is required as explained below:
- Retrieve the project in SonarQube Server and select Project Settings > General Settings > DevOps Platform Integration.
- Enter the Project name and Repository name.
Preventing pull request merges when the quality gate fails
You can prevent the merge of pull requests when the quality gate fails. To do so:
- In Azure DevOps, add a
SonarQube/quality gate
status check branch policy on the target branch.
You can also watch this video for a quick overview of the procedure.
This feature is not supported for projects on a monorepo.
Related pages
Was this page helpful?