This is lazy dog HOWTO to using CodeChecker analysis. It invokes Clang Static Analyzer and Clang-Tidy tools to analyze your code.
CodeChecker only analyzes what is also built by your build system.
- Select a module to build (open source tmux in this example).
cd tmux
./configure
- Clean that module. e.g.
make clean
make clean
- Log your build:
CodeChecker log -b "make" -o compilation.json
- Check the contents of compilation.json. If everything goes well it should contain the
gcc
calls.
cat ./compilation.json
What to do if the compilation.json
is empty?
-
Make sure that your build system actually invoked the compiler (e.g.
gcc
,g++
). In case your software was built once (and the binaries are already generated), the compiler will not be invoked. In this case do a build cleanup (e.g.make clean
) and retry to log your build. -
Make sure that the
CC_LOGGER_GCC_LIKE
environment variable is set correctly and contains your compilers. For detailed description see the user guide. -
MacOS users need
intercept-build
to be available on the system, and in most cases, System Integrity Protection needs to be turned off. See the README for details.
Once the build is logged successfully (and the compilation.json
) was created, you can analyze your project.
- Run the analysis:
CodeChecker analyze compilation.json -o ./reports
- View the analysis results in the command line
CodeChecker parse ./reports
Hint:
You can do the 1st and the 2nd step in one round by executing check
cd tmux
make clean
CodeChecker check -b "make"
or to run on 22 threads
CodeChecker check -j22 -b "make clean;make -j22"
What to do if the analysis fails (analysis settings for cross-compilation)
You can store the analysis results in a central database and view the results in a web viewer
- Start the CodeChecker server locally on port 8555 (using SQLite DB, which is not recommended for multi-user central deployment) create a workspace directory, where the database will be stored.
mkdir ./ws
CodeChecker server -w ./ws -v 8555
A default product called Default
will be automatically created where you can store your results.
- Store the results in the server under run name "tmux" (in the
Default
product):
CodeChecker store ./reports --name tmux --url http://localhost:8555/Default
The URL is in PRODUCT_URL
format:
[http[s]://]host:port/ProductEndpoint
Please note that if you start the server in secure mode (with SSL) you will need to use the https
protocol prefix.
The default protocol is http
.
See user guide for detailed description of the PRODUCT_URL
format.
- View the results in your web browser http://localhost:8555/Default
You can ignore analysis results for certain files for example 3rd party modules.
For that use the -i
parameter of the analyze command:
-i SKIPFILE, --ignore SKIPFILE, --skip SKIPFILE
Path to the Skipfile dictating which project files
should be omitted from analysis. Please consult the
User guide on how a Skipfile should be laid out.
For the skip file format see the user guide.
CodeChecker analyze -b "make" -i ./skip.file" -o ./reports
You can list the checkers using the following command
CodeChecker checkers --details
those marked with (+) are enabled by default.
You may want to enable more checkers or disable some of them using the -e, -d switches of the analyze command.
For example to enable alpha checkers additionally to the defaults
CodeChecker analyze -e alpha -b "make" -i ./skip.file" -o ./reports
After execution of
CodeChecker analyze build.json -o reports
the failed analysis output is collected into
./reports/failed
directory.
This means that analysis of these files failed and there is no Clang Static Analyzer output for these compilation commands.
This section describes a recommended "way of working" about how CodeChecker is designed to be used in a CI environment to
- generate daily report summaries
- implement CI guard to prevent the introduction of new bugs into the code-base.
In CodeChecker each bug has a unique hash identifier that is independent of the exact line number therefore resistant to shifts in the source code. With this feature CodeChecker can recognize the same and new bugs in two different version of the same source file.
In summary:
- Store daily runs of a module every day in a new run post-fixed with date. You can query new and resolved bugs
using the
cmd diff
or the WEB GUI. - Create a single run for each module in each branch and keep it up to date with code changes (commits). The CI loop then can compare pull requests (commit attempts) against this run and list new bugs in the changed code. Programmers can also compare their local edits to this run to see if they would introduce any new issues.
- Programmers should use in-code-suppression to tell the CI guard that a report is false positive and should be ignored. This way your suppressions remain also resistant to eventual changes of the bug hash (generated by clang).
Let us assume that you want to analyze your code-base daily and would like to send out an email summary about any newly introduced and resolved issues.
Store each analysis into a new run.
Each daily analysis should be stored as a new run name with for example the following naming convention:
<module_name>_<branch_name>_<date>
For example to analyze tmux
project daily.
- Generate a new log file
CodeChecker log -b "make" -o compilation.json
- Re-analyze the code
CodeChecker analyze compilation.json ./reports-daily
- Store the analysis results into the central database.
CodeChecker store ./reports --url http://localhost:8555/Default --name tmux_master_2017_08_28
and the next day repeat the steps above but store the results under run name tmux_master_2017_08_29
.
Then you can query newly introduced bugs in the following way.
CodeChecker cmd diff -b tmux_master_2017_08_28 -n tmux_master_2017_08_29 --new --url http://localhost:8555/Default
If you would like to generate a report page out of this using a script, you can get the results in json
format too:
CodeChecker cmd diff -b tmux_master_2017_08_28 -n tmux_master_2017_08_29 --new --url http://localhost:8555/Default -o json
Note: Don't forget to delete old runs you don't need to save database space.
Let us assume that at each commit you would like to keep your analysis results up-to-date and send an alert email to the programmer if a new bug is introduced in a "pull request". Also when there is a new bug in the uploaded code, reject the "pull request".
A single run should be used to store the analysis results of module on a specific branch:
<module_name>_<branch>
The run should be always updated when a new commit is merged to reflect the analysis status of the latest code version on your branch.
Let's assume that user john_doe
changed tmux/attributes.c
in tmux.
The CI loop re-analizes tmux project and sends an email with reject if new bug was found compared to the master version, or
accepts and merges the commit if no new bugs were found.
Let's assume that the working directory is tmux
containing John Doe's modifications.
- Generate a new log file for the new code
CodeChecker log -b "make" -o compilation.json
- Re-analyze the changed code of john_doe
CodeChecker analyze compilation.json ./reports-john-doe
- Check for new bugs in the run
CodeChecker cmd diff -b tmux_master -n ./reports-john-doe --new --url http://localhost:8555/Default
If new bugs were found, reject the commit and send an email with the new bugs to John.
If no new bugs were found:
-
Merge the changes into the master branch
-
Update the analysis results according to the new code version:
CodeChecker store ./reports-john-doe --url http://localhost:8555/Default --name tmux_master
If John finds a false positive report in his code and so the CI loop would prevent the merge of his pull request, he can suppress the false positive by amending the following suppression comment in his code a line above the bug
// codechecker_suppress [core.NullDereference] suppress all checker results
x = 1; // warn
See User guide for more information.
Say that you made some local changes in your code (tmux in our example) and you wonder whether you introduced any new bugs. Each bug has a unique hash identifier that is independent of the line number, therefore resistant to shifts in the source code. This way, newly introduced bugs can be detected compared to a central CodeChecker report database.
Let's assume that you are working on the master branch and the analysis of the master branch
is already stored under run name tmux_master
.
- You make local changes to tmux
- Generate a new log file
CodeChecker log -b "make" -o compilation.json
- Re-analyze your code
CodeChecker analyze compilation.json ./reports
- Compare your local analysis to the central one
CodeChecker cmd diff -b tmux_master -n ./reports --new --url http://localhost:8555/Default