Top Related Projects
SpotBugs is FindBugs' successor. A tool for static analysis to look for bugs in Java code.
An extensible multilanguage static code analyzer.
Checkstyle is a development tool to help programmers write Java code that adheres to a coding standard. By default it supports the Google Java Style Guide and Sun Code Conventions, but is highly configurable. It can be invoked with an ANT task and a command line program.
Static code analysis for Kotlin
Quick Overview
SonarQube is an open-source platform developed by SonarSource for continuous inspection of code quality. It performs automatic reviews with static analysis of code to detect bugs, code smells, and security vulnerabilities on 20+ programming languages. SonarQube provides detailed reports and dashboards to help developers maintain and improve their code quality over time.
Pros
- Supports a wide range of programming languages and integrates with various CI/CD tools
- Offers comprehensive code analysis, including security vulnerabilities, bugs, and code smells
- Provides clear visualizations and metrics for easy interpretation of code quality
- Allows for customizable quality gates and rules to fit specific project needs
Cons
- Can be resource-intensive, especially for large codebases
- Initial setup and configuration can be complex for beginners
- Some advanced features are only available in paid versions
- False positives in analysis results may require manual review and filtering
Getting Started
To get started with SonarQube:
- Download and install SonarQube from the official website
- Start the SonarQube server
- Access the web interface (default: http://localhost:9000)
- Create a new project and generate a token
- Install SonarScanner on your development machine
- Run the scanner on your project with the following command:
sonar-scanner \
-Dsonar.projectKey=my_project \
-Dsonar.sources=. \
-Dsonar.host.url=http://localhost:9000 \
-Dsonar.login=YOUR_GENERATED_TOKEN
- View the analysis results in the SonarQube web interface
For more detailed instructions and advanced configurations, refer to the official SonarQube documentation.
Competitor Comparisons
SpotBugs is FindBugs' successor. A tool for static analysis to look for bugs in Java code.
Pros of SpotBugs
- Lightweight and focused specifically on Java bytecode analysis
- Can be easily integrated into build processes and IDEs
- Free and open-source with a large community of contributors
Cons of SpotBugs
- Limited to Java language analysis only
- Less comprehensive in terms of overall code quality metrics
- Requires more manual configuration compared to SonarQube's out-of-the-box setup
Code Comparison
SpotBugs configuration (in Maven pom.xml):
<plugin>
<groupId>com.github.spotbugs</groupId>
<artifactId>spotbugs-maven-plugin</artifactId>
<version>4.5.0.0</version>
</plugin>
SonarQube configuration (in Maven pom.xml):
<plugin>
<groupId>org.sonarsource.scanner.maven</groupId>
<artifactId>sonar-maven-plugin</artifactId>
<version>3.9.1.2184</version>
</plugin>
Both tools can be integrated into Maven builds, but SonarQube offers a more comprehensive analysis across multiple languages and metrics, while SpotBugs focuses specifically on Java bytecode analysis for finding bugs.
An extensible multilanguage static code analyzer.
Pros of PMD
- Lightweight and easy to integrate into existing build processes
- Supports multiple programming languages beyond Java
- Highly customizable with user-defined rules
Cons of PMD
- Less comprehensive analysis compared to SonarQube
- Limited reporting and visualization capabilities
- Requires more manual configuration for advanced use cases
Code Comparison
PMD rule definition:
<rule name="AvoidUsingHardCodedIP"
language="java"
message="Avoid using hardcoded IP addresses"
class="net.sourceforge.pmd.lang.rule.XPathRule">
<description>
Avoid using hardcoded IP addresses in code.
</description>
<priority>3</priority>
<properties>
<property name="xpath">
<value>
//Literal[matches(@Image, "^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$")]
</value>
</property>
</properties>
</rule>
SonarQube rule definition:
@Rule(key = "S1313")
public class HardcodedIpAddressCheck extends IssuableSubscriptionVisitor {
private static final String MESSAGE = "Make this IP '%s' address configurable.";
private static final Pattern IP = Pattern.compile("^(?:[0-9]{1,3}\\.){3}[0-9]{1,3}$");
@Override
public List<Tree.Kind> nodesToVisit() {
return ImmutableList.of(Tree.Kind.STRING_LITERAL);
}
@Override
public void visitNode(Tree tree) {
LiteralTree literal = (LiteralTree) tree;
if (IP.matcher(LiteralUtils.trimQuotes(literal.value())).matches()) {
reportIssue(literal, String.format(MESSAGE, literal.value()));
}
}
}
Checkstyle is a development tool to help programmers write Java code that adheres to a coding standard. By default it supports the Google Java Style Guide and Sun Code Conventions, but is highly configurable. It can be invoked with an ANT task and a command line program.
Pros of Checkstyle
- Lightweight and focused solely on Java code style checking
- Highly customizable with extensive rule sets
- Easy integration with build tools like Maven and Gradle
Cons of Checkstyle
- Limited to Java language only
- Lacks advanced static code analysis features
- No built-in reporting or visualization tools
Code Comparison
Checkstyle configuration example:
<module name="Checker">
<module name="TreeWalker">
<module name="AvoidStarImport"/>
<module name="ConstantName"/>
</module>
</module>
SonarQube configuration example:
sonar.projectKey=my:project
sonar.projectName=My project
sonar.projectVersion=1.0
sonar.sources=src
sonar.java.binaries=target/classes
Summary
Checkstyle is a lightweight, Java-specific code style checker that excels in customization and easy integration with build tools. It's ideal for projects focused solely on Java code style enforcement. However, it lacks the comprehensive static code analysis and multi-language support offered by SonarQube.
SonarQube, on the other hand, provides a more robust solution for code quality management across multiple languages, with advanced static analysis features and built-in reporting tools. It's better suited for larger projects or organizations requiring a more comprehensive code quality platform.
Static code analysis for Kotlin
Pros of detekt
- Lightweight and focused specifically on Kotlin static code analysis
- Easy integration with Gradle and Maven build systems
- Highly customizable with the ability to write custom rules
Cons of detekt
- Limited to Kotlin language analysis only
- Smaller community and fewer out-of-the-box rules compared to SonarQube
- Less comprehensive reporting and visualization features
Code Comparison
detekt configuration example:
detekt {
config = files("$projectDir/config/detekt.yml")
buildUponDefaultConfig = true
allRules = false
}
SonarQube configuration example:
sonar.projectKey=my:project
sonar.sources=src
sonar.java.binaries=build/classes
sonar.kotlin.detekt.reportPaths=build/reports/detekt/detekt.xml
Summary
detekt is a lightweight, Kotlin-specific static code analysis tool that integrates easily with build systems. It offers high customizability but has a narrower focus compared to SonarQube. SonarQube, on the other hand, provides a more comprehensive analysis across multiple languages and offers advanced reporting features, but may be considered heavier and more complex to set up for smaller projects.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
SonarQube
Continuous Inspection
SonarQube provides the capability to not only show the health of an application but also to highlight issues newly introduced. With a Quality Gate in place, you can achieve Clean Code and therefore improve code quality systematically.
Links
- Website
- Download
- Documentation
- Webapp source code
- X
- SonarSource, author of SonarQube
- Issue tracking, read-only. Only SonarSourcers can create tickets.
- Responsible Disclosure
- Next instance of the next SonarQube version
Have Questions or Feedback?
For support questions ("How do I?", "I got this error, why?", ...), please first read the documentation and then head to the SonarSource Community. The answer to your question has likely already been answered! ð¤
Be aware that this forum is a community, so the standard pleasantries ("Hi", "Thanks", ...) are expected. And if you don't get an answer to your thread, you should sit on your hands for at least three days before bumping it. Operators are not standing by. ð
Contributing
If you would like to see a new feature or report a bug, please create a new thread in our forum.
Please be aware that we are not actively looking for feature contributions. The truth is that it's extremely difficult for someone outside SonarSource to comply with our roadmap and expectations. Therefore, we typically only accept minor cosmetic changes and typo fixes.
With that in mind, if you would like to submit a code contribution, please create a pull request for this repository. Please explain your motives to contribute this change: what problem you are trying to fix, what improvement you are trying to make.
Make sure that you follow our code style and all tests are passing (Travis build is executed for each pull request).
Willing to contribute to SonarSource products? We are looking for smart, passionate, and skilled people to help us build world-class code-quality solutions. Have a look at our current job offers here!
Building
To build sources locally follow these instructions.
Build and Run Unit Tests
Execute from the project base directory:
./gradlew build
The zip distribution file is generated in sonar-application/build/distributions/
. Unzip it and start the server by executing:
# on Linux
bin/linux-x86-64/sonar.sh start
# or on MacOS
bin/macosx-universal-64/sonar.sh start
# or on Windows
bin\windows-x86-64\StartSonar.bat
Open in IDE
If the project has never been built, then build it as usual (see previous section) or use the quicker command:
./gradlew ide
Then open the root file build.gradle
as a project in IntelliJ or Eclipse.
Gradle Hints
./gradlew command | Description |
---|---|
dependencies | list dependencies |
licenseFormat --rerun-tasks | fix source headers by applying HEADER.txt |
wrapper --gradle-version 5.2.1 | upgrade wrapper |
Building with UI changes
The SonarQube UI (or webapp as we call it), is located in another repository: sonarqube-webapp.
When building the sonarqube
repository, the webapp is automatically downloaded from Maven Central as a dependency, it makes it easy for you to contribute backend changes without having to care about the webapp.
But if your contribution also contains UI changes, you must clone the sonarqube-webapp
repository, do your changes there, build it locally and then build the sonarqube
repository using the WEBAPP_BUILD_PATH
environment variable to target your custom build of the UI.
Here is an example of how to do it:
cd /path/to/sonarqube-webapp/server/sonar-web
# do your changes
# install dependencies, only needed the first time
yarn
# build the webapp
yarn build
cd /path/to/sonarqube
# build the sonarqube repository using the custom build of the webapp
WEBAPP_BUILD_PATH=/path/to/sonarqube-webapp/server/sonar-web/build/webapp ./gradlew build
You can also target a specific version of the webapp by updating the webappVersion
property in the ./gradle.properties
file and then building the sonarqube
repository normally.
Translations files
Historically our translations were stored in sonar-core/src/main/resources/org/sonar/l10n/core.properties
, but this file is now deprecated and not updated anymore.
Default translations (in English) are now defined in the webapp repository, here:
https://github.com/SonarSource/sonarqube-webapp/blob/master/server/sonar-web/src/main/js/l10n/default.ts
The format has changed but you can still have it as a .properties
file format by running the following command:
cd /path/to/sonarqube-webapp/server/sonar-web
# install dependencies, only needed the first time
yarn
# generate a backward compatible .properties file with all the translation keys
yarn generate-translation-keys
Note that contributing extensions for translations into other languages still work the same way as before. It's just the source of truth for the default translations that changed.
License
Copyright 2008-2024 SonarSource.
Licensed under the GNU Lesser General Public License, Version 3.0
Top Related Projects
SpotBugs is FindBugs' successor. A tool for static analysis to look for bugs in Java code.
An extensible multilanguage static code analyzer.
Checkstyle is a development tool to help programmers write Java code that adheres to a coding standard. By default it supports the Google Java Style Guide and Sun Code Conventions, but is highly configurable. It can be invoked with an ANT task and a command line program.
Static code analysis for Kotlin
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot