cargo-sonar
help you to use the tools of the Rust community and report the information to Sonarcloud (or Sonarqube).
You can even set it up in a Continuous Integration so this report is automatically forwarded to Sonar.
git clone https://gitlab.com/woshilapin/cargo-sonar
cd cargo-sonar
cargo install --path .
cargo sonar --help
cargo install cargo-sonar
cargo sonar --help
export CONTAINER_ENGINE=docker # or CONTAINER_ENGINE=podman
${CONTAINER_ENGINE} pull docker.io/woshilapin/cargo-sonar
${CONTAINER_ENGINE} run docker.io/woshilapin/cargo-sonar --help
cargo-sonar
is only a tool to convert reports from other tools into Sonar compatible report (see Supported tools).
Once the Sonar report is generated, it can be sent to sonarcloud.io or any SonarQube instance with sonar-scanner
.
First generate a report from any supported tool, for example clippy
.
cargo clippy --message-format > my-clippy-report.json
Then convert this report.
cargo sonar --clippy --clippy-path my-clippy-report.json
This creates a file sonar.json
.
You can now configure sonar-scanner
with sonar.externalIssuesReportPaths=sonar.json
in your sonar-project.properties
file.
cargo-clippy
cargo clippy --message-format=json -- --warn clippy::pedantic > clippy.json
cargo-audit
cargo audit --json > audit.json
cargo-deny
cargo deny --format json check 2> deny.json
Note that only advisories
and licenses
are supported at the moment.
cargo-outdated
cargo outdated --depth 1 --format json --workspace > outdated.json
--depth 1
is useful here since the conversion will not work on any dependency
of greater depth.
The best example out there at the moment is the project cargo-sonar
itself.
In the CI, you can see the generation of the clippy
report and the audit
report.
Then, cargo sonar
is executed followed by sonar-scanner
with the sonar-project.properties
configuration file.
The final result can be seen on sonarcloud.io.
All the release process is automated: each time you push a commit on main
branch,
the next version is automatically deduce from the conventional commit standard since last tag.
Sometimes, the CI might get into a problem. If you need to switch to manual release, here are the steps.
Below, 1.2.3
is used as an example, please replace with the correct version.
cog bump --auto
git checkout 1.2.3
cargo publish
git checkout 1.2.3
buildah bud --layers --tag woshilapin/cargo-sonar:1.2.3
buildah push woshilapin/cargo-sonar:1.2.3
cargo-geiger
parsing