sonarqube for code qualities / sonarqube usage

代码质量检查工具sonarqube的简单使用小册:

sonarqube for code qualities usage by ukyo

相关:
SONARQUBE官网

  1. Set sonar stuff dependencies with project,
    Install sonarlint(plugin) for IDE and sonar scanner
    Overview | SonarQube Docs
    to push project codes to sonarqube server.

image

1.给要被代码扫描的项目设定相关sonar依赖,并下载安装sonarlint插件给IDE,以及配置sonar scanner插件
用于推送项目代码到sonarqube远端服务器。

gradle项目大致如下:(其他可查看官网或ford sonarqube相关提示)

buildscript {
    repositories {
        maven{url "https://plugins.gradle.org/m2/"}
    }
    dependencies {
        //sonar scanner插件,用于将整体测试目录推送到sonarqube server
        classpath("org.sonarsource.scanner.gradle:sonarqube-gradle-plugin:3.0")
    }
}

..

plugins {
    id "org.sonarqube" version "3.0"
    id "jacoco"  //(JACOCO用于在单元测试后推送测试结果给sonarqube server)
}

..

apply plugin: 'jacoco'
apply plugin: "org.sonarqube"

sonarqube{
    properties{
        property "sonar.sourceEncoding","UTF-8"
        property "sonar.sources", "src/main/java"
    }
}

..

dependencies {
	//(jacoco插件也需要加入这个依赖到dependencies)
    testImplementation group: 'org.jacoco', name: 'org.jacoco.agent', version: '0.8.8'
}

..

jacoco{
    toolVersion = "0.8.8"
    reportsDir=file("$buildDir/reports") //指定单元测试报告输出路径 $buildDir一般为build
}

..

jacocoTestReport {
    dependsOn test
    group = "Reporting"
    description="Generate Jacoco coverage reports after running tests."
    reports{
        xml.enabled true //指定单元报告格式xml
//        html.enabled true
    }
}

check.dependsOn jacocoTestReport

2.配置jacoco依赖插件到项目(见上面的配置文件),jacoco主要功能是本地执行单元测试命令将代码测试覆盖率推送到sonarqube server。
(1)编写好单元测试(2)项目root目录下执行以下命令,其中login=后数据是sonarqube server生成的token。projectKey=是项目域(Administrator创建分配)

gradle test jacocoTestReport -D'sonar.login=************************' -D'sonar.host.url=https://www.sonarqube.yoursite
.com' -D'sonar.projectKey=yourkey' sonarqube

3.申请sonarqube server的相关参数,如token。

My Account > Security > Generate Tokens

4.配置相关配置文件
sonar-project.properties

# must be unique in a given SonarQube instance
sonar.projectKey=
#----- Default SonarQube server
sonar.host.url=https://www.sonarqube.yoursite.com
#token from sonarqube server
sonar.login=*****************************************

sonar.scm.disabled=false
#test dictionary
sonar.test=src/test
#code source
sonar.java.source=src/main/java
#binaries dictionary
sonar.java.binaries=build/classes
sonar.binaries=build/classes
sonar.groovy.binaries=build/classes
#coverage plugin 
sonar.core.codeCoveragePlugin=jacoco
#jacoco plugin reports path
sonar.coverage.jacoco.xmlReportPaths=build/test-results

# --- optional properties ---

# defaults to project key
#sonar.projectName=My project
# defaults to 'not provided'
#sonar.projectVersion=1.0

# Path is relative to the sonar-project.properties file. Defaults to .
#sonar.sources=.

# Encoding of the source code. Default is default system encoding
#sonar.sourceEncoding=UTF-8

5.Action

(1)执行命令推送被检项目到sonarqube server

#Windows
sonar-scanner -D'sonar.login=************************************'
#Unix like
sonar-scanner -Dsonar.login=************************************

推送后如下图
image

(2)这时如果配置及一切配置完善,可以从配置文件sonar-project.properties指定的url网站web端
查看被推送的项目以及相关评测。
(3)在代码改动或有新代码时需要重新进行scanner以及编写单元测试确保sonarqube server中项目下Measures tab
选项下的Coverage -> Overall -> Uncoverd Lines关联到的代码进行了测试,并执行测试推送如:

gradle test jacocoTestReport -D'sonar.login=************************' -D'sonar.host.url=https://www.sonarqube.ford
.com' -D'sonar.projectKey=yourkey' sonarqube

image

6.现阶段通过代码检测需要状态PASSED,覆盖率80%,配合IDE安装的sonarlint插件进行本地代码检查,再进行单元测试,执行以上test命令,在sonarqube server端查看结果即可。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章