Purpose of the article: A lot of people are unaware that Reactjs can integrate SonarQube. therefore those who are eager to learn new technologies will find this post helpful
Intended Audience: Sonarqube, docker, reactjs
Tools and Technology: VS code, ReactJS ,Sonarqube ,Docker
Keywords: how to integrate sonarqube in react ,sonar integration in reactJS, how to integrate sonar in react project with docker
The topics that I am going to discuss revolve around:
- What is SonarQube?
- Why Sonar?
- Required things (versions)
- Installation of SonarQube
- How to integrate Sonar in Reactjs?
What is SonarQube:
- SonarQube is an online platform where developers can check the code quality, improve scalability, & code coverage
- SonarQube detects bugs, loopholes, code smells in a codebase
- After downloading Sonar (click me), it will take you to the community edition
- In case you want to choose any other edition, click here
data:image/s3,"s3://crabby-images/5ae8e/5ae8e49a7e73c3d7cd520a8222b4ef2cca1f6412" alt=""
Why Sonar:
- It includes a static code analysis tool that can be used to analyze source code without running it.
- It extends a continuous integration tool that helps you to detect and prevent defects.
- It can be added to CI/DC flows
Required things:
- To run Sonar we need to install docker (click here) (to install docker
for windows click on download windows and for Linux or any other download the relevant versions)
- JVM is required to run
data:image/s3,"s3://crabby-images/00ab2/00ab2de8eafdb02cbed2d023e39ad7a3fddb4ffd" alt=""
Installation:
Step-1: Make sure you installed docker using above link
and then install the “sonarqube-scanner”package in your react project
yarn add –dev sonarqube-scanner
yarn add --dev sonarqube-scanner
Step-2: Create a docker-compose.yml file in the root of your project folder and add the below code
data:image/s3,"s3://crabby-images/c3df9/c3df937f01a76ab01c4a6f6fcb88f008876467bd" alt=""
version: "3.2"
services:
sonarqube:
container_name: "sonarqube-container"
image: "sonarqube:9.9.2-community"
volumes:
- ./sonarqube/extensions:/opt/sonarqube/extensions
- ./sonarqube/logs:/opt/sonarqube/logs
- ./sonarqube/data:/opt/sonarqube/data
expose:
- "9000"
ports:
- "9000:9000"
Step-3: Create a sonarqube folder on your root project folder and add a sonarscan.js file with the following content.
data:image/s3,"s3://crabby-images/91de9/91de9fea798e12306902faba219e77a93c818c7c" alt=""
const scanner = require("sonarqube-scanner");
scanner(
{
serverUrl: "http://localhost:9000",
token: "sqa_9bf54da2b3f8364bdda1d2f6aefca1b27d9bd182",
options: {
"sonar.projectName": "sonarqube-react-project",
"sonar.projectDescription": "Here I can add a description of my project",
"sonar.projectKey": "sonarqube-react-project",
"sonar.projectVersion": "0.0.1",
"sonar.exclusions":
"sonar.sourceEncoding": "UTF-8",
"sonar.javascript.lcov.reportPaths": "coverage/lcov.info"
}
},
()=> process.exit()
);
you can customize Project name and Project key to update a token.
Step-4: To start sonar server, run the following command.
docker compose up
after docker up open http://localhost:9000. You should use below cred
data:image/s3,"s3://crabby-images/2f32e/2f32efd49fea0516a09ccb693858f4cccaa74b98" alt=""
Step-5: After successful login, you will be able to see the below picture –
data:image/s3,"s3://crabby-images/8db65/8db65e0206e8f962bd5435e2b0c5f37267c7457f" alt=""
Step-6: Click on create a project by clicking manually and give project name & project key and click next
data:image/s3,"s3://crabby-images/0567e/0567eacfd84166e02f4bfe374bc4fac5c773a96e" alt=""
give a title to your project. Make sure the project display name and project key is the same
Step-7: Generate a token for the project, you can use any name you want. When the token is generated, make sure to keep it in a safe place to use when we needed.
data:image/s3,"s3://crabby-images/b89be/b89be14f117a5217db30094bf4e944964a54804d" alt=""
Click on locally.
Click on ‘generate token’.
Remember to save this token because it will be used in a future step to run an analysis
data:image/s3,"s3://crabby-images/674b4/674b40056b6da8cb8961eeab5f4b22dab162668d" alt=""
Make sure to replace the latest token in sonarscan.js file
Step-8: Starting a new scan
Add this line in .gitignore files (if you are using git)
.scannerwork
sonarqube/extensions
sonarqube/data
sonarqube/logs
Run the command in command prompt
node ./sonarqube/sonarscan.js
Wait until this screen comes –
data:image/s3,"s3://crabby-images/dd0b4/dd0b46fdfca9304b4b199618426305ca5748d302" alt=""
Step-9: Return to SonarQube dashboard and check how many bugs ,vulnerabilities, security hotspots you have
data:image/s3,"s3://crabby-images/67a50/67a50fa60276d2d4db80641bd2b00cf943cbb6f5" alt=""
Finally, it is done.
Thank you for reading my article.
If you have any queries, please feel free to reach me.
Author Bio:
data:image/s3,"s3://crabby-images/038e9/038e99b94f26e76dac49aafc118f97983c7f047e" alt="Picture of Saipraveen krishna PINNAMAREDDY"
Saipraveen krishna PINNAMAREDDY
Associate Software Engineer - Application Development-Digital Transformation
Hi, I am Saipraveen, working as an Associate Software Engineering for almost 3 years now, at MOURI Tech . I am skilled in front-end programming languages like React and NodeJS. I am a dedicated team player, an efficient multitasker, and believe i have strong interpersonal and communication skills which have helped me grow professionally.