Skip to content

An example C++ repository on Linux using GitHub Actions and analyzed on SonarQube using AutoConfig

Notifications You must be signed in to change notification settings

sonarsource-cfamily-examples/linux-autoconfig-gh-actions-sq

Repository files navigation

C++ example project scanned on SonarQube using AutoConfig

Build Status Quality Gate Status

This project is analysed on SonarQube!

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

  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_HOST_URL to your server url (e.g.: https://example.com:9000)

    2. Analyze your code using the SonarQube Scan Github Action

  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 (see Generating and Using Tokens).

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

Documentation

Code Description

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:

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.

About

An example C++ repository on Linux using GitHub Actions and analyzed on SonarQube using AutoConfig

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages