go test 命令介绍

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了go test 命令介绍相关的知识,希望对你有一定的参考价值。

参考技术A 是 go 语言 自带 的 测试 工具,
其中包含的是 两类 ,

通过 go help test 可以看到 go test 的 使用 说明:

go test [-c] [-i] [build flags] [packages] [flags for test binary]
参数解读:

-test.v : 是否输出全部的单元测试用例(不管成功或者失败),默认没有加上,所以只输出失败的单元测试用例。
-test.run pattern: 只跑哪些单元测试用例
-test.bench patten: 只跑那些性能测试用例
-test.benchmem : 是否在性能测试的时候输出内存情况
-test.benchtime t : 性能测试运行的时间,默认是1s
-test.cpuprofile cpu.out : 是否输出cpu性能分析文件
-test.memprofile mem.out : 是否输出内存性能分析文件
-test.blockprofile block.out : 是否输出内部goroutine阻塞的性能分析文件
-test.memprofilerate n : 内存性能分析的时候有一个分配了多少的时候才打点记录的问题。这个参数就是设置打点的内存分配间隔,也就是profile中一个sample代表的内存大小。默认是设置为512 * 1024的。如果你将它设置为1,则每分配一个内存块就会在profile中有个打点,那么生成的profile的sample就会非常多。如果你设置为0,那就是不做打点了。
你可以通过设置memprofilerate=1和GOGC=off来关闭内存回收,并且对每个内存块的分配进行观察。
-test.blockprofilerate n: 基本同上,控制的是goroutine阻塞时候打点的纳秒数。默认不设置就相当于-test.blockprofilerate=1,每一纳秒都打点记录一下
-test.parallel n : 性能测试的程序并行cpu数,默认等于GOMAXPROCS。
-test.timeout t : 如果测试用例运行时间超过t,则抛出panic
-test.cpu 1,2,4 : 程序运行在哪些CPU上面,使用二进制的1所在位代表,和nginx的nginx_worker_cpu_affinity是一个道理
-test.short : 将那些运行时间较长的测试用例运行时间缩短

Go单元测试命令

Go 语言推荐测试文件和源代码文件放在一块,测试文件以 _test.go 结尾。比如,当前 package 有 calc.go 一个文件,我们想测试 calc.go 中的 Add 和 Mul 函数,那么应该新建 calc_test.go 作为测试文件。

example/
   |--calc.go
   |--calc_test.go

假如 calc.go 的代码如下:

1 package main
2 
3 func Add(a int, b int) int {
4     return a + b
5 }
6 
7 func Mul(a int, b int) int {
8     return a * b
9 }

那么 calc_test.go 中的测试用例可以这么写:

 1 package main
 2 
 3 import "testing"
 4 
 5 func TestAdd(t *testing.T) {
 6     if ans := Add(1, 2); ans != 3 {
 7         t.Errorf("1 + 2 expected be 3, but %d got", ans)
 8     }
 9 
10     if ans := Add(-10, -20); ans != -30 {
11         t.Errorf("-10 + -20 expected be -30, but %d got", ans)
12     }
13 }
  • 测试用例名称一般命名为 Test 加上待测试的方法名。
  • 测试用的参数有且只有一个,在这里是 t *testing.T
  • 基准测试(benchmark)的参数是 *testing.B,TestMain 的参数是 *testing.M 类型。

运行 go test,该 package 下所有的测试用例都会被执行。

$ go test
ok      example 0.009s

或 go test -v-v 参数会显示每个用例的测试结果,另外 -cover 参数可以查看覆盖率。

$ go test -v
=== RUN   TestAdd
--- PASS: TestAdd (0.00s)
=== RUN   TestMul
--- PASS: TestMul (0.00s)
PASS
ok      example 0.007s

如果只想运行其中的一个用例,例如 TestAdd,可以用 -run 参数指定,该参数支持通配符 *,和部分正则表达式,例如 ^$

1 $ go test -run TestAdd -v
2 === RUN   TestAdd
3 --- PASS: TestAdd (0.00s)
4 PASS
5 ok      example 0.007s

遇到如下报错的解决方法

技术图片

 

以上是关于go test 命令介绍的主要内容,如果未能解决你的问题,请参考以下文章

Go Test

CentOS「linux」学习笔记8:压缩和解压类命令

2.go命令源文件分析

Go语言常用命令介绍

生成漂亮报告的Go语言代码检查工具

设计模式-命令模式(Go语言描述)