Golang代码检测(可配合Sonar使用)

检测golang

首先安装搭建go的开发环境,方法见相应文档

go的单元测试

单元测试编写

  • 文件名必须是_test.go结尾的,这样在执行go test的时候才会执行到相应的代码
  • 你必须import testing这个包
  • 所有的测试用例函数必须是Test开头
  • 测试用例会按照源代码中写的顺序依次执行
  • 测试函数TestXxx()的参数是testing.T,我们可以使用该类型来记录错误或者是测试状态
  • 测试格式:func TestXxx (t *testing.T),Xxx部分可以为任意的字母数字的组合,但是首字母不能是小写字母[a-z],例如Testintdiv是错误的函数名。
  • 函数中通过调用testing.T的Error, Errorf, FailNow, Fatal, FatalIf方法,说明测试不通过,调用Log方法用来记录测试的信息。

单元测试执行

  • go的自带go test还是很好用的,执行的前提是需要写对应的单元测试(功能测试、性能测试 可写在1个测试文件里)
go test  #执行单元测试
go test -v  #打印执行的详细信息,即使测试成功(默认情况下测试成功是不打印结果的)
go test -v xxx #执行指定文件的单元测试(此处注意,go只会读取go/src下面的目录。所以写文件路径不需要加go/src)
go test -v xxx> test # 执行指定文件的单元测试并且将结果写入文档(文件名根据自己需要设置,文件内容=终端显示)
go test -v xxx -json  # 执行指定文件的单元测试并且将结果转化为json格式
go test -v xxx -json > test.json # 执行指定文件的单元测试并且将结果转化为json格式写入文档(文件名根据自己需要设置,文件内容=终端显示)
go test -bench=.  #执行性能测试
go test -bench=. -v #显示执行的详细信息
  • 直接生成xml报告
go get -u github.com/jstemmer/go-junit-report  #安装报告模板插件
go test -v xx/xx | go-junit-report > test.xml  #测试指定文件,并直接生成xml报告

检测go测试的覆盖率

使用go test(go的1.9以下版本必须使用这种方法)

  • 使用
go test -cover  #即可在终端看到覆盖率
go test -coverprofile=covprofile  #将覆盖率结果写入文档(文件名根据自己需要设置,文件内容=终端显示)
go tool cover -html=covprofile -o coverage.html  #将上面生成的文件转成html,打开html即可看到覆盖/未覆盖的具体代码
go tool cover -func=covprofile -o coverage.txt  #将上面生成的文件转成txt,打开html即可看到覆盖率详细统计数据
  • 使用此方法检测覆盖率时,默认的统计模式是set,可以通过“-covermode=xxx”的设定进行调整
模式解释
set缺省模式,只记录语句是否被执行
count记录语句被执行的次数
stomic记录语句被执行的次数,并保证在并发执行时的正确性
  • 可以将报告转成xml(方法一,未尝试成功)
go get github.com/axw/gocov/...    #安装gocov(本人安装后一直提示gocov未找到命令)
go get github.com/AlekSi/gocov-xml   #安装转换插件
gocov convert xxx | gocov-xml > coverage.xml  #转换执行结果文件,为xml文件
  • 可以将报告转成xml(方法二)
go get github.com/t-yuki/gocover-cobertura   # 安装转换工具
./xxx/xx/gocover-cobertura <  xx/xx/covprofile  > xx/coverage.xml  #转换,运行工具准换指定文件为xml文件,并存储在指定位置
  • 由此还有一种方式(只是可用,不推荐比较麻烦)
go test -c -covermode=count -coverpkg   #执行生成一个.test的可执行文件
./ xxx.test   #执行这个可执行文件

使用gocov(本人安装后一直提示gocov未找到命令)

  • 安装gocov
go get github.com/axw/gocov/...
  • 进行测试
gocov test xx/xxx  #统计指定文件下的测试覆盖率
gocov test xx/xxx > xxxx  #统计指定文件下的测试覆盖率,并将结果写入指定文件内(文件内容=终端显示)
  • 进行测试并生成指定格式文件
go get github.com/AlekSi/gocov-xml   # 安装转换xml文件的插件
gocov test xx/xx | gocov-xml > coverage.xml # 统计指定文件下的测试覆盖率,并生成xml报告

检测Go语言源码中静态错误

使用go vet(go自带)

  • 使用
go vet  #执行检测
go vet -n   #打印执行的命令而并不真正执行它们,也不会取消命令的执行
go vet -x   #进行实质的执行
go vet -n xxx/xxx  #检测指定文件夹
go vet -n xxx/xxx 2> xxxxx/xxx  #检测指定文件夹并将结果生成报告到指定文件夹

golint(代码检测规则)

  • 安装golint
go get -u github.com/golang/lint/golint  #百度有很多方式但是只有这种可行
  • 运行golint
cd xx/xx  #相应的项目目录
golint xx/xx #指定目录扫描
golint xx/xx > xx/xx  #扫描指定目录,并将结果写入指定目录内

gometalinter(代码检测规则)

  • 安装gometalinter
go get github.com/alecthomas/gometalinter  #遇坑没有安装git,sudo apt install git安装即可
gometalinter --install --update
  • 运行gometalinter
cd xx/xx  #相应的项目目录
gometalinter
gometalinter xx/xx #指定目录扫描
gometalinter xx/xx > xx/xx  #扫描指定目录,并将结果写入指定目录内
gometalinter --checkstyle xx/xx > xx/xx.xml  #扫描指定目录,并将结果(checkstyle XML格式)已写入指定目录内

go的压力测试

压力测试用来检测函数(方法)的性能,和编写单元功能测试的方法类似,此处不再赘述,但需要注意以下几点:

  • 压力测试用例必须遵循如下格式,其中XXX可以是任意字母数字的组合,但是首字母不能是小写字母
func BenchmarkXXX(b *testing.B) { ... }
  • go test不会默认执行压力测试的函数,如果要执行压力测试需要带上参数-test.bench,语法: -test.bench=“test_name_regex”,例如go test -test.bench=".*"表示测试全部的压力测试函数
  • 在压力测试用例中,请记得在循环体内使用testing.B.N,以使测试可以正常的运行
  • 文件名也必须以_test.go结尾
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值