标签:secure rev less 参考 jpg flags mpi iat complex
原文发布于个人站点: GitDiG.com, 原文链接:像 Awesome-Go 一样提升企业 Go 项目代码质量
参与过awesome-go项目的gopher
都知道,每个MR都必须满足它以下的要求:
Make sure that you‘ve checked the boxes below before you submit PR:
- [ ] I have added my package in alphabetical order.
- [ ] I have an appropriate description with correct grammar.
- [ ] I know that this package was not listed before.
- [ ] I have added godoc link to the repo and to my pull request.
- [ ] I have added coverage service link to the repo and to my pull request.
- [ ] I have added goreportcard link to the repo and to my pull request.
- [ ] I have read Contribution guidelines, maintainers note and Quality standard.
总结出来,就是两项关键质量指标:
这两项指标都通过量化的数值对合并项目进行审查。只有满足了指标的阀值要求,你提及的MR才会被合进awesome-go的主分支。
以下是我的两个合并进主分支的项目:
代码审查 Code Review
,程序员本能就是抵制的。我也不列外,但是很多事即使开始抵制,一旦尝试过,就再也停不下来。代码审查Code Review
属此类。
通过参与awesome-go项目和实际的Code Review
实践,可以得出:一个 Go 项目的优劣至少在编译期就可以作出初步判断,而判断标准就是以下两项:
同样在企业内部也遇到相同的问题,面对开发人员能力水平的参差不齐以及各种Freestyle
的代码风格, 大大增加了企业 Go
项目的维护难度。指定一套标准规范,同时将其固化到 CI
过程,是非常必要的。
在awesome-go项目中采用的是开源的代码审查项目与集成服务,但这些服务仅用于开源项目。要移植到企业内部,需要一些必要的准备工作。分别找出静态代码审查的通过率与单元测试的代码覆盖率替代方案。
通过收集筛选,静态代码审查工具选择golangci-lint项目。该项目的使用者包括了众多国际大厂: google、facebook、 IBM 等等。其可用性已经被充分的验证过了。
在golangci-lint中,它内置了绝大部分Go
项目需要使用的审查工具。以下就其内置工具做一下简单的分类。分类能够帮助我们快速定制出必要的审查工具,哪些是必要的,哪些是可选的一目了然。
该分类,还可以通过以下命令查询:
$: golangci-lint help linters
...
##内置Linters分类
Linters presets:
bugs: bodyclose, errcheck, gosec, govet, scopelint, staticcheck, typecheck
complexity: gocyclo, nakedret
format: gofmt, goimports
performance: bodyclose, maligned, prealloc
style: depguard, dupl, gochecknoglobals, gochecknoinits, goconst, gocritic, golint, gosimple, interfacer, lll, misspell, stylecheck, unconvert
unused: deadcode, ineffassign, structcheck, unparam, unused, varcheck
更详细的工具使用说明,可以直接跳转到对应的项目页进行查询。
代码BUG审查
代码复杂度
代码格式化
代码性能审查
代码风格审查
无用代码审查
按linter
具体功能分类,在进行ci
的过程中, 配置如下:
勾选是必选项,非勾选按实际情况进行配置。具体如何配置,可以参考 .golangci.example.yml。
配置好配置文件后,确认配置,通过以下命令查询当前项目配置.
# 项目目录下查询具体启用的linters设置
$: golangci-lint linters
golangci-lint配置文件的查询规则是:从当前目录,逐次向上级目录查询。
集成到企业 Go
项目的 CI
中就很简单,在每个项目的构建过程中,增加以下命令即可:
# 项目目录下
$: golangci-lint run
完成了静态代码审查的准备工作,现在看看测试代码覆盖率的方案。
在 Go 1.2
版本就已经提供了代码测试覆盖率的工具。具体操作如下:
# 项目整体测试覆盖率, 以 github.com/x-mod/routine 项目为例
$: go test -cover github.com/x-mod/routine | awk '{print $4 " " $5}'
coverage: 83.0%
具体测试覆盖率详细信息,可以通过命令行的方式也可以通过网页的方式查看,按https://dave.cheney.net提供的脚本,简单修改后如下:
# 测试覆盖率详情
cover() {
t=$(mktemp)
go test $COVERFLAGS -coverprofile=$t $@ && go tool cover -func=$t && unlink $t
}
# 测试覆盖率详情 web方式查看
cover-web() {
t=$(mktemp)
go test $COVERFLAGS -coverprofile=$t $@ && go tool cover -html=$t && unlink $t
}
具体测试覆盖率详情cover-web github.com/x-mod/routine
, 效果如图:
命令行效果,读者可以自己测试一下 cover github.com/x-mod/routine
。
如何集成到 CI
流程,也很简单了,只需要做一件事: 设置好测试覆盖率的通过值,比对项目的测试覆盖率的值。简单提供一下取值与比较的脚本函数:
cover-val(){
cover $@ | grep ^total | awk '{print $3}' | awk -F. '{print $1}'
}
cover-cmp(){
cmp=$1
shift
val=$(cover-val $@)
num=$(($val+0))
if [ $cmp -gt $num ]; then
echo "coverage insufficient."
return 1
fi
return 0
}
下面在CI
过程直接就可以增加相应的覆盖率审查操作:
# 覆盖率 > 60%
$: cover-cmp 60 github.com/x-mod/routine ; echo $?
0
# 覆盖率 > 90%
$: cover-cmp 90 github.com/x-mod/routine ; echo $?
coverage insuffient.
1
# Go 项目路径
$: cover-cmp 60 ./...
具体脚本可参考: liujianping/oh-my-zsh/plugins/alias
标签:secure rev less 参考 jpg flags mpi iat complex
原文地址:https://www.cnblogs.com/gitdig/p/11117281.html