电话
400 9058 355
Go代码覆盖率需用go test -coverprofile生成coverage.out再通过go tool cover -html生成HTML报告查看具体覆盖情况,绿色为覆盖、红色为未覆盖、灰色为不可覆盖代码。
go test -cover 查看整体覆盖率百分比,但这个数字太笼统,实际开发中更常用的是生成 HTML 报告来定位具体哪行没覆盖到。
执行以下命令生成可交互的覆盖率报告:
go test -coverprofile=coverage.out -covermode=count ./... go tool cover -html=coverage.out -o coverage.html
打开 coverage.html 就能看到每行代码的执行次数(covermode=count 模式),绿色表示覆盖,红色表示未覆盖,灰色是不可覆盖的代码(比如 default 分支、空行、函数签名等)。
注意:go test -cover 默认只跑当前包,如果想包含子包,得加 ./...;漏掉这点会导致覆盖率虚高。
err != nil 分支):比如文件打开失败、网络超时、JSON 解析出错——这些需要 mock 或构造异常输入,很多人直接跳过if len(s) == 0 这种分支就悬在那里
log.Printf、prometheus.Inc() 这类副作用调用,不 mock 就无法触发,但 mock 又容易让测试变重assert 类函数或显式 panic("should not happen"),需用 defer recover() 捕获,否则测试直接退出优先确保以下三类代码有对应测试:
func DoX(...)),哪怕只是简单封装,也要验证输入输出和 error 返回switch 的非 default 分支,以及 default 本身(哪怕它只打日志)if err != nil 的地方,必须有至少一个测试让 err 非 nil —— 用 testify/mock、io.ErrUnexpectedEOF 或自定义 error 实现避免陷阱:covermode=count 比 atomic 更准,适合增量推进;别依赖 -coverpkg 强行拉高数字,那只是把依赖包的覆盖率算进来,对本包质量无意义。
func main()),它只做初始化和入口调用,逻辑应下沉到可测函数fmt.Errorf("failed: %w", err),只要上游已覆盖,这里无需单独测w.WriteHeader(500) 这类状态码设置,重点测业务逻辑,而不是 net/http 的行为真正难的是判断“哪里该停”。90% 是个实用分水岭:再往上投入产出比断崖下跌,而低于 85% 往往意味着核心错误流或边界没兜住。
邮箱:8955556@qq.com
Q Q:8955556
本文详解如何将Go官方present工具(用于生成HTML5...
PySNMP在不同版本中对SNMP错误状态(errorSta...
time.Sleep仅阻塞当前goroutine,其他gor...
PHPfopen()创建含特殊符号的文件名失败主因是操作系统...
WooCommerce中通过代码为分组产品动态聚合子商品的属...
io.ReadFull返回io.ErrUnexpectedE...
本文详解Yii2中控制器向视图传递ActiveRecord数...
本文详解为何通过wp_set_object_terms()为...
Pytest中使用@mock.patch类装饰器会导致补丁泄...
带缓冲的channel是并发安全的FIFO队列;make(c...