Analyse Code with SonarQube
Steps to test code analysis with SonarQube.
data:image/s3,"s3://crabby-images/25df4/25df4d4ad6e4c1dc3ee299e5e3754947a1874c8b" alt="SonarQube logo"
Now that you installed SonarQube, it's time to analyse your code.
Create a project
SonarQube works with the concept of projects; I identify a project with a git repository for convenience.
First you create a new project by clicking 'Create Project' button at the top-right of the page:
data:image/s3,"s3://crabby-images/15162/15162ca6d11ce7132ac923b7b3a913d107d4fbd8" alt="Create project"
For this testing purpose, you should create the project 'Manually':
data:image/s3,"s3://crabby-images/084f1/084f11330b1b650d37791134e94013bb7309e30d" alt="Create a project manually"
Once you've selected manual creation, you are presented with a page to enter your project's details:
data:image/s3,"s3://crabby-images/c5776/c577665a39db6adca84a15a8dee4e5ec9587ddf6" alt="Introduce project details"
I've entered 'My Project' as the project's display name. The key is auto-generated by default, but you can replace it as long as you respect the rules indicated.
Now, the project is created and you will see a page with monitoring options. SonarQube provides presets for all popular CI frameworks:
data:image/s3,"s3://crabby-images/367c5/367c5896f823b2ac891a6843fbd6231fab3211a3" alt="Project set up"
Again, for testing, I've selected the Locally option. This will allow me to execute the verification script manually.
Prepare analysis
Now that my project is created, I have to generate a token. This token will allow the verification script to identify the project in SonarQube (and put its results in the right place).
data:image/s3,"s3://crabby-images/85546/855469488e9c09c8e4040670d700e46e78eb0c45" alt="Token creation"
Note: Mind the expiration date. If you'll use CI, you might want to set up a longer expiration date, so you don't need to generate tokens too often.
Once you click the Generate button, an unique token will be generated:
data:image/s3,"s3://crabby-images/2e08d/2e08db4ddf194859dc64fa91bbb1376dc22daa5d" alt="Token generated"
Run analysis
Once the token is created, you can analyse your code:
data:image/s3,"s3://crabby-images/01ef9/01ef9ece0b55950f5497e9f828a2187c44c4c1d0" alt="Analyse manually"
You have different options, depending on what's in your code.
Maven
Part of my code is a java/springboot app using maven. I can generate a maven command line to analyse it:
data:image/s3,"s3://crabby-images/e142d/e142d2d0f9bd9ceed6167a525dc202e202b02d5a" alt="Maven command line"
The command (reproduced for convenience) is:
mvn clean verify sonar:sonar \
-Dsonar.projectKey=My-project \
-Dsonar.host.url=http://localhost:9000 \
-Dsonar.login=sqp_7dce29e4c4addb4dddedfcff67f1d96dcb7c7f17
Gradle
If you're using gradle, you can need to add the sonarqube plugin to your build.gradle file.
data:image/s3,"s3://crabby-images/b4e98/b4e98368434ef834d47edea157191f5166afbc5b" alt="Use gradle"
You can then execute gradlew
:
./gradlew sonarqube \
-Dsonar.projectKey=My-project \
-Dsonar.host.url=http://localhost:9000 \
-Dsonar.login=sqp_7dce29e4c4addb4dddedfcff67f1d96dcb7c7f17
Others (including NodeJS)
My other part is in angular, so I have to also use the 'Other' option. In this case, I have to first get the sonar scanner, install it and then execute the command.
data:image/s3,"s3://crabby-images/cd840/cd8407547b5cab1688a2b6dff4617c7f7beae4cc" alt=""
The command line (using the winbdows version) is:
sonar-scanner.bat -D"sonar.projectKey=My-project" -D"sonar.sources=." -D"sonar.host.url=http://localhost:9000" -D"sonar.login=sqp_7dce29e4c4addb4dddedfcff67f1d96dcb7c7f17"
Results
Once you've executed the command(s), you have results shown like this:
data:image/s3,"s3://crabby-images/b0b11/b0b114989dc88284cd1142a3cb37b345c2629651" alt="Results page"
Summary
This post showed how to:
- Create a SonarQube project
- Generate a token
- Use command line to verify your code