Set up the continuous analysis
Last updated
Last updated
1. Visit TrustInSoft CI Sign-in page and click Sign in/up with GitHub.
2. If not already signed in, sign in to GitHub.
You'll be redirected to the GitHub authorization page for TrustInSoft CI to be granted access to your GitHub projects:
3. Optionally grant access to any of your GitHub organizations, that own C and C++ projects, by clicking Grant.
4. Click Authorize TrustInSoft.
You'll be redirected to TrustInSoft CI.
1. After sign-in in TrustInSoft CI, you are redirected to your Dashboard that gathers all your recent activity.
2. To add a project, you can directly click on Create your first project
in the Last activity
section here, or you can go to the Projects page and click on the Add project
button (on the top-right corner of the screen):
3. Then, select the project demo-caesar and click on Add and select branch
:
4. Now, select the master branch.
5. The status
notifies the branch does not have (yet) a configuration required to run a build in TrustInSoft CI. So click on the Add and create configuration
button to create this missing configuration.
After clicking on Add and create configuration
, you will be redirected to the Build configuration page of your project.
The configuration is split instead two steps:
The optional Build preparation stage (to execute an arbitrary Bash script before the run a build): this stage is not required for this tutorial.
The required Analyses configuration, which describes how to perform analyses.
1. Skip the Build preparation
section, and scroll down to the Analysis configuration
section.
Now, you will have to write an Analyses configuration, which is defined as a sort of "light" specification in JSON of your analyses.
2. Copy the following Analyses configuration:
3. Click on Add reference
to save the changes and add the master
branch.
If you did not change the project settings, a build will automatically be run for the master
branch and you will be redirected to the page of this build.
1. Wait for the analysis to complete, then look at the results in Build status (see the capture below).
2. Click on the only analysis. The detected undefined behavior corresponds to an invalid memory access:
Now that we know that the project demo-caesar contains an undefined behavior, let's understand its root cause!