This project is analysed on SonarCloud!
It is very easy to analyze a C, C++ and Objective-C project with SonarCloud on Azure DevOps:
-
Create a
sonar-project.properties
file to store your configuration -
Install SonarCloud extension for your organization:
-
Open Organization settings (in the bottom left corner of organization view)
-
Open "Extensions" page (in the General category)
-
Press "Browse marketplace" and find "SonarCloud"
-
Select your organization and click "Install"
-
-
Add the SonarCloud connection to your project:
-
Open Project settings (in the bottom left corner)
-
Open "Service connections" page (in the Pipelines category)
-
Press "New connection" and select the "SonarCloud"
-
Fill in the
SONAR_TOKEN
-
Name your connection
SonarCloud
(to reference it later inazure-pipelines.yml
)
-
-
In your
azure-pipelines.yml
file:-
Add the
SonarCloudPrepare
task and configure it:-
Specify the
SonarCloud Service Endpoint
asSonarCloud
- the connection you created earlier -
Choose your
organization
-
Choose "Use standalone scanner" (
scannerMode: 'CLI'
) -
Choose "Store configuration with my source code (sonar-project.properties)" (
configMode: 'file'
)
-
-
Add a task to download the Build Wrapper
-
Wrap your compilation with the Build Wrapper
-
Add the
SonarCloudAnalyze
task
-
You can take a look at the sonar-project.properties and azure-pipelines.yml to see it in practice.
A build of the code repository on a Linux platform using CMake build system.
To build the code run:
mkdir build && cd build cmake .. make
An example of a flawed C++ code. The code repository can be analyzed automatically, but it can also be compiled with different build systems using different CI pipelines on Linux, macOS, and Windows.
The code repository is forked into other repositories in this collection to add a specific build system, platform, and CI. The downstream repositories are analyzed either with SonarQube or SonarCloud.
You can find examples for:
Using the following build systems:
Running on the following CI services:
-
Additionally, generic examples demonstrate integration with other CIs and manual-configuration examples should help you if you are running locally.
Configured for analysis on:
You can find also a few examples demonstrating:
See examples-structure.adoc for a description of the structure of this GitHub organization and the relations between its different repositories.