golang测试

单元测试

在学习单元测试之前,测试代码一般都是些在main函数里去调用我们写的函数,以此来判断函数的正确性。学习单元测试后,我们可以直接在测试函数里去测试,提提高代码的可读性和测试效率。

go测试

golang中提供了非常完善的测试功能。所有测试代码文件以*_test.go命名,测试函数以Test被测函数名(TestAdd)命名,测试命令以go test开头。
golang中有3中测试函数,分别为单元测试函数、性能测试函数、示例函数。

类型 格式 作用
单元测试函数 函数名以Test为前缀 测试代码逻辑是否正确
性能测试函数(基准函数) 函数名以Benchmark为前缀 测试函数的性能
示例函数 函数名前缀为Example 为文档提供示例文档

单元测试函数

每个测试函数必须导入test包,函数名以Test为前缀,*testing.T用于报告测试失败和附加的日志信息。单元测试函数格式如下

func TestAdd(t *testing.T) {
  // todo
}

简单测试函数示例

定义一个test包,并编写函数Add

package test

func Add(m int, n int) (sum int) {
    sum = m + n
    return
}

接下来,在当前目录下创建add_test.go文件,并定义测试函数:

//测试函数名必须以Test开头,必须接收一个*testing.T类型参数
func TestAdd(t *testing.T) {

    /**
    * 简单测试
    */
    got := Add(3, 5)  // 程序计算得出的结果
    want := 8  // 期望结果
    if got != want  {  // 程序计算出的结果与期望结果比较
        t.Errorf("excepted:%v, got:%v", want, got)
    }
}

在test包目录下执行go test命令,得到结果:

  • 程序得到结果与预期结果相同:


    image.png
  • 程序得到结果与预期结果不同:


    image.png

子测试函数示例

在简单测试函数示例中,我们一次只能测试一组数据,如果有多组测试数据的话要么在创建一个函数来测试,要么使用循环。使用循环测试的情况下,我们无法得出哪条测试数据有问题。golang中提供子测试方法,我们可以通过*testing.T.Run方法来执行子测试。

func TestAdd(t *testing.T) {
    // 测试数据,期望结果结构体
    type data struct {
        m int
        n int
        want int
    }
    // 测试组需要使用map类型,后续查看测试结果比较方便
    tests := map[string]data{
        "one": {m: 1, n: 2, want: 3},
        "two": {m: 10, n: 5, want: 15},
        "three": {m: 25, n: 16, want: 41},
        "four": {m: 10, n: 6, want: 16},
        "five": {m: 0, n: 0, want: 1},
    }
    for name, d := range tests{
        //  t.Run函数,需要传入测试数据的name,即上面map中的one\two\three
        t.Run(name, func(t *testing.T) {
            got := Add(d.m, d.n)
            if got != d.want {
                t.Errorf("name:%s excepted:%#v, got:%#v", name, d.want, got) // 将测试用例的name格式化输出
            }
        })
    }
}

执行go test -v查看测试结果的详细信息

image.png

性能测试函数

性能测试函数也叫基准测试函数,函数名以Benchmark为前缀。性能测试函数格式如下:
性能测试函数需要执行b.N次,这个由系统决定的。

func BenchmarkAdd(b *testing.B) {
    for i := 0; i < b.N; i++ {
        // todo
    }
}

性能测试示例:

func BenchmarkAdd(b *testing.B) {
    for i := 0; i < b.N; i++ {
        Add(999999, 99999)
    }
}

执行基准函数:go test -bench=函数名 -benchmem(go test -bench=Add -benchmem)

  • 基准函数默认是不会执行的,需要参数-bench
  • -benchmen会显示一些内存分配的统计数据
    image.png

    统计数据的意义:
  • BenchmarkAdd-8:表示GOMAXPROCS(线程数)的值为8
  • 2000000000:表示执行的次数
  • 0.26 ns/op:表示每次执行时间0.26ns
  • 0B/op:表示每次执行分配内存0B
  • 0 allocs/op:表示每次执行分配内存的次数

覆盖率测试

覆盖率测试表示代码被测试套件覆盖的百分比。
执行命令:go test -cover
可以看到,当前代码的覆盖率是50%

image.png

-coverprofile参数可以将覆盖率的相关信息输出到一个文件中
将函数覆盖率相关信息输出到a.out,a.out在当前目录下生成。
image.png

执行命令:go tool cover -html=a.out,可以在浏览器上看到覆盖率相关信息
image.png

测试命令总结

  • 测试包下所有测试文件:go test
  • 打印测试详细信息:go test -v
  • 测试单个方法:go test -v -run=方法名 // go test -v -run=Add
  • 覆盖率测试:go test -cover
  • 覆盖率测试,并输出到文件中:go test -cover -coverprofile=c.out
  • 浏览器查看覆盖率文件:go tool cover -html=c.out
  • 性能测试:go test -bench=方法名
  • 性能测试显示详细信息:go test -bench=方法名 -benchmem
  • 只执行性能测试不执行单元测试 :go test -v -run=none -bench=方法名
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352