Gradle進(jìn)階使用結(jié)合Sonarqube進(jìn)行代碼審查的方法
作為代碼質(zhì)量檢查的流行工具,比如Sonarqube能夠檢查代碼的“七宗罪”,跟代碼結(jié)合起來能夠更好地提高代碼的質(zhì)量,這篇文章將會介紹如何結(jié)合gradle和sonarqube對代碼質(zhì)量與測試覆蓋率進(jìn)行分析。
Sonarqube
Sonarqube可以使用docker版本快速搭建,可以參看一下Easypack整理的鏡像,具體使用可以參看如下鏈接,這里不再贅述:
環(huán)境假定
本文使用到的sonarqube為本機(jī)32003可以訪問到的服務(wù)。
gradle的sonarqube插件
gradle中的sonarqube的插件是org.sonarqube,用來在gradle中調(diào)用sonarqube進(jìn)行代碼質(zhì)量分析。詳細(xì)介紹請參看:
- https://plugins.gradle.org/plugin/org.sonarqube
- 當(dāng)前插件最新版本:2.6.2(更新于2018/2/13)
使用方式
指定plugin
在build.gradle中添加如下插件版本信息
plugins { id "org.sonarqube" version "2.6.2" }
添加apply plugin信息
apply plugin: "org.sonarqube"
sonarqube設(shè)定信息
最簡單的需求的情況下,非多工程項(xiàng)目做以上配置即可,接下來就是傳遞給gradle所需要的sonarqube的詳細(xì)信息,而這些可以通過property的方式傳入,詳細(xì)的使用方式在前面的基礎(chǔ)中都已介紹,此處不再贅述,主要設(shè)定的內(nèi)容為:
- URL:systemProp.sonar.host.url=http://localhost:32003
- 用戶名:systemProp.sonar.login=admin
- 密碼:systemProp.sonar.password=admin
設(shè)定方式可以使用如下方式:
sonarqube { properties { property "sonar.host.url", "http://localhost:32003" property "sonar.login", "admin" property "sonar.password", "admin" } }
build.gradle詳細(xì)信息
liumiaocn:springboot liumiao$ cat build.gradle buildscript { ext { springBootVersion = '2.1.1.RELEASE' } repositories { mavenCentral() } dependencies { classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}") } } plugins { id "org.sonarqube" version "2.6.2" } sonarqube { properties { property "sonar.host.url", "http://localhost:32003" property "sonar.login", "admin" property "sonar.password", "admin" } } apply plugin: 'java' apply plugin: 'jacoco' apply plugin: 'org.sonarqube' apply plugin: 'org.springframework.boot' apply plugin: 'io.spring.dependency-management' group = 'com.liumiaocn' version = '0.0.1-SNAPSHOT' sourceCompatibility = 1.8 repositories { mavenCentral() } dependencies { implementation('org.springframework.boot:spring-boot-starter-web') testImplementation('org.springframework.boot:spring-boot-starter-test') } jacocoTestReport { reports { xml.enabled false html.enabled true } } check.dependsOn jacocoTestReport liumiaocn:springboot liumiao$
掃描方式
可以使用gradle sonarqube即可進(jìn)行掃描
執(zhí)行日志
liumiaocn:springboot liumiao$ gradle sonarqube
> Task :sonarqube
SCM provider autodetection failed. No SCM provider claims to support this project. Please use sonar.scm.provider to define SCM of your project.
Class not found: javax.annotation.Nonnull
Class not found: javax.annotation.meta.When
Class not found: javax.annotation.meta.TypeQualifierNickname
Class not found: org.junit.jupiter.api.extension.ExtendWith
BUILD SUCCESSFUL in 6s
5 actionable tasks: 1 executed, 4 up-to-date
liumiaocn:springboot liumiao$
結(jié)果確認(rèn)
掃描結(jié)果確認(rèn)
可以看到質(zhì)量掃描結(jié)果和覆蓋率的信息都進(jìn)行了顯示
脆弱性信息詳細(xì)
查出了一個(gè)缺陷,實(shí)際是一個(gè)誤報(bào),詳細(xì)可參看maven使用方式的詳細(xì)介紹。
代碼覆蓋率
代碼覆蓋率的詳細(xì)信息也可以在sonarqube上進(jìn)行直接確認(rèn)
小結(jié)
使用SonarQube可以很好的檢查出代碼的問題,但是在實(shí)際的項(xiàng)目中需要進(jìn)行裁剪和定制,掃出來的不一定有問題,沒有掃出來也不一定萬事大吉,但是一定程度的代碼規(guī)范和質(zhì)量提高還是很有用處,實(shí)際在使用的時(shí)候應(yīng)該根據(jù)具體情況進(jìn)行實(shí)施。
參考文章
- https://docs.sonarqube.org/display/SCAN/Analyzing+with+SonarQube+Scanner+for+Gradle
- https://plugins.gradle.org/plugin/org.sonarqube
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
- Android 使用gradle打包Assets目錄的案例
- 使用idea和gradle編譯spring5源碼的方法步驟
- Gradle的使用教程詳解
- IDEA使用Gradle構(gòu)建SpringBoot項(xiàng)目工程的詳細(xì)教程
- 在IDEA里gradle配置和使用的方法步驟
- Android Studio和Gradle使用不同位置JDK的問題解決
- Kotlin之在Gradle中無參(no-arg)編譯器插件的使用詳解
- Jenkins使用Gradle編譯Android項(xiàng)目詳解
- AndroidStduio3.0 使用gradle將module打包jar文件的方法
- 使用Gradle做Java代碼質(zhì)量檢查的方法示例
- Android使用Gradle依賴配置compile、implementation與api的區(qū)別介紹
- Gradle的基本使用
相關(guān)文章
Springboot如何切換默認(rèn)的Tomcat容器
這篇文章主要介紹了Springboot如何切換默認(rèn)的Tomcat容器,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06使用Java實(shí)現(xiàn)動態(tài)生成MySQL數(shù)據(jù)庫
這篇文章主要為大家詳細(xì)介紹了如何使用Java實(shí)現(xiàn)動態(tài)生成MySQL數(shù)據(jù)庫,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02Java中的線程池如何實(shí)現(xiàn)線程復(fù)用
這篇文章主要介紹了Java中的線程池如何實(shí)現(xiàn)線程復(fù)用問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03SpringBoot基于數(shù)據(jù)庫實(shí)現(xiàn)定時(shí)任務(wù)過程解析
這篇文章主要介紹了SpringBoot基于數(shù)據(jù)庫實(shí)現(xiàn)定時(shí)任務(wù)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12