2019-01-02 14:16:34 -08:00
---
title: Code Quality Tools
2019-12-11 10:49:28 +01:00
category: Contributing
2019-12-11 17:01:46 +01:00
layout: default
2021-09-14 16:05:21 +02:00
SPDX-License-Identifier: LGPL-2.1-or-later
2019-01-02 14:16:34 -08:00
---
2018-06-07 15:07:23 +02:00
# Code Quality Tools
The systemd project has a number of code quality tools set up in the source
tree and on the github infrastructure. Here's an incomprehensive list of the
available functionality:
2020-12-11 11:33:39 +01:00
1. Use `meson test -C build` to run the unit tests. Some tests are skipped if
2018-06-07 15:07:23 +02:00
no privileges are available, hence consider also running them with `sudo
2020-12-11 11:33:39 +01:00
meson test -C build`. A couple of unit tests are considered "unsafe" (as
they change system state); to run those too, build with `meson setup
2018-06-07 15:07:23 +02:00
-Dtests=unsafe`. Finally, some unit tests are considered to be very slow,
2020-12-11 11:33:39 +01:00
build them too with `meson setup -Dslow-tests=true` . (Note that there are a
couple of manual tests in addition to these unit tests.) (Also note: you can
change these flags for an already set up build tree, too, with "meson
configure -C build -D…".)
2018-06-07 15:07:23 +02:00
2. Use `./test/run-integration-tests.sh` to run the full integration test
suite. This will build OS images with a number of integration tests and run
them in nspawn and qemu. Requires root.
3. Use `./coccinelle/run-coccinelle.sh` to run all
[Coccinelle ](http://coccinelle.lip6.fr/ ) semantic patch scripts we ship. The
output will show false positives, hence take it with a pinch of salt.
4. Use `./tools/find-double-newline.sh recdiff` to find double newlines. Use
`./tools/find-double-newline.sh recpatch` to fix them. Take this with a grain
of salt, in particular as we generally leave foreign header files we include in
our tree unmodified, if possible.
5. Similar use `./tools/find-tabs.sh recdiff` to find TABs, and
`./tools/find-tabs.sh recpatch` to fix them. (Again, grain of salt, foreign
headers should usually be left unmodified.)
2022-04-12 12:05:53 +02:00
6. Use `ninja -C build check-api-docs` to compare the list of exported symbols
of `libsystemd.so` and `libudev.so` with the list of man pages. Symbols
2018-06-07 15:07:23 +02:00
lacking documentation are highlighted.
2022-04-12 12:05:53 +02:00
7. Use `ninja -C build update-hwdb` and `ninja -C build update-hwdb-autosuspend`
to automatically download and import the PCI, USB, and OUI databases and the
autosuspend quirks into the hwdb.
2018-06-07 15:07:23 +02:00
2022-04-12 12:05:53 +02:00
8. Use `ninja -C build update-man-rules` to update the meson rules for building
man pages automatically from the docbook XML files included in `man/` .
2018-06-07 15:07:23 +02:00
2022-04-12 12:05:53 +02:00
9. There are multiple CI systems in use that run on every github pull request
submission or update.
2018-06-07 15:07:23 +02:00
2021-12-23 21:25:31 +01:00
10. [Coverity ](https://scan.coverity.com/ ) is analyzing systemd `main` branch
in regular intervals. The reports are available
2018-06-07 15:07:23 +02:00
[online ](https://scan.coverity.com/projects/systemd ).
2022-05-26 14:07:32 +00:00
11. [OSS-Fuzz ](https://github.com/google/oss-fuzz ) is continuously fuzzing the
2018-06-07 15:07:23 +02:00
codebase. Reports are available
2022-05-26 14:07:32 +00:00
[online ](https://oss-fuzz.com/testcases?project=systemd&open=yes ).
It also builds
[coverage reports ](https://oss-fuzz.com/coverage-report/job/libfuzzer_asan_systemd/latest )
daily.
2018-06-07 15:07:23 +02:00
2018-06-12 12:03:13 +02:00
12. Our tree includes `.editorconfig` , `.dir-locals.el` and `.vimrc` files, to
2018-06-12 14:06:13 +02:00
ensure that editors follow the right indentiation styles automatically.
2018-06-12 12:03:13 +02:00
13. When building systemd from a git checkout the build scripts will
2018-06-12 14:06:13 +02:00
automatically enable a git commit hook that ensures whitespace cleanliness.
2018-06-12 12:03:13 +02:00
2021-12-23 21:25:31 +01:00
14. [LGTM ](https://lgtm.com/ ) analyzes every commit pushed to `main` . The list
2018-11-30 00:47:13 -08:00
of active alerts can be found
[here ](https://lgtm.com/projects/g/systemd/systemd/alerts/?mode=list ).
2018-06-23 16:53:04 +00:00
2019-05-27 14:14:26 +02:00
15. Each PR is automatically tested with [Address Sanitizer ](https://clang.llvm.org/docs/AddressSanitizer.html )
and [Undefined Behavior Sanitizer ](https://clang.llvm.org/docs/UndefinedBehaviorSanitizer.html ).
2022-05-18 00:05:38 +02:00
See [Testing systemd using sanitizers ](TESTING_WITH_SANITIZERS.md )
2019-05-27 14:14:26 +02:00
for more information.
2020-05-21 09:00:53 +02:00
16. Fossies provides [source code misspelling reports ](https://fossies.org/features.html#codespell ).
2021-12-23 21:25:31 +01:00
The systemd report can be found [here ](https://fossies.org/linux/misc/systemd/codespell.html ).
2020-05-21 09:00:53 +02:00
2018-06-23 16:53:04 +00:00
Access to Coverity and oss-fuzz reports is limited. Please reach out to the
maintainers if you need access.