Skip to content

Latest commit

 

History

History
86 lines (59 loc) · 5.55 KB

README.adoc

File metadata and controls

86 lines (59 loc) · 5.55 KB

C++ example project scanned on SonarQube Server using GitHub Actions

Build Status Quality Gate Status

This project is analysed on SonarQube Server!

It is very easy to analyze a C, C++ and Objective-C project with SonarQube:

  1. Create a sonar-project.properties file to store your configuration

  2. In your .github/workflows/build.yml file:

    1. Set the environment variable SONAR_SERVER_URL to your server url (e.g.: https://example.com:9000)

    2. Download the Build Wrapper using the SonarSource/sonarqube-scan-action/install-build-wrapper action

    3. Wrap your compilation with the Build Wrapper

    4. Run the SonarQube scan using the SonarSource/sonarqube-scan-action action as final step

  3. Ensure that your token is stored as a secret in your repository (SONARQUBE_TOKEN in this example project). If you don’t have a token yet, you can generate a new one in SonarQube Server (see Managing your tokens).

You can take a look at the sonar-project.properties and build.yml to see it in practice.

Documentation

Windows\CMake

A build of the code repository on Windows platform using CMake build system.

To build the code run:

mkdir build && cd build
cmake ..
msbuild sonar_scanner_example.vcxproj

Code Description

An example of a flawed C++ code. The code repository is meant to 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 Server or SonarQube Cloud.

You can find examples for:

Using the following build systems:

Running on the following CI services:

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.