GO随笔-单元测试-基础测试

单元测试

前几天,Leader让我学习GO单元测试并且组内分享。经过这些天在网上查阅资料和实践。总结出以下内容。


基础知识:
GO为我们提供了测试框架,go test,让我们能够很容易的进行单元测试。
但必须遵守以下几点规则:

  • 测试文件必须以_test.go结尾
  • 单元测试文件名_test.go前面的部分最好是被测方法所在go文件的文件名。(不一样也可以运行go test,但是应该遵守统一的规范)
  • 单元测试的函数必须以Test开头,是公开函数
  • 测试函数必须接收一个指向testing.T类型的指针(依测试目的而定,如主要是测试性能,则用testing.B等),并且不能返回任何值。
  • 函数名最好是Test+测试函数名(依测试类型而定,Benchmark等)。

只要遵守以上规则,很容易可以编写一个GO单元测试。

在网上查阅资料时,看到有一篇文章写道:
GO随笔-单元测试-基础测试

测试代码的文件放置的位置可以随意?
顿时感觉GO真的好智能,迫不及待的尝试了一下:
GO随笔-单元测试-基础测试

难道需要指定路径?
GO随笔-单元测试-基础测试

可能是我没有理解这句话的含义,但我个人感觉,还是放在一个目录(包)下吧。
package也可以随意写?
尝试后结论,不能。

写一个简单的单元测试用例
add.go

package add

func Add(a, b int) int{
    return a+b
}

add_test.go

package add

import "testing"

func TestAdd(t *testing.T){
    if sum:=Add(1,2); sum!=3{
        t.Error("fail")//日志一般要写成f(x)=y, want z的形式
    } else {
        t.Log("success")
    }
}

go test -v即可看到测试结果
GO随笔-单元测试-基础测试

(这里有一点我踩过的小坑,当想指定测试文件的时候go test file_test.go会报错,因为需要后面还需要接上被测试的文件:go test file_test.go file.go

只是一个最简单的基本测试。另一种测试方法叫做:表组测试。其实就是多个基本测试。
将上面test简单改造

package add

import "testing"

func TestAdd(t *testing.T){
    var tests = []struct{
        date []int
        want int
    }{
        {[]int{1, 2}, 3},
        {[]int{2, 5}, 7},
        {[]int{3, 9}, 11},
    }

    for _,v := range tests{
        if sum:=Add(v.date[0], v.date[1]); sum!=v.want{
            t.Errorf("Add(%d, %d) = %d, want %d", v.date[0], v.date[1], v.date[0]+v.date[1], v.want)
        } else {
            t.Log("success")
        }
    }
}

运行结果
GO随笔-单元测试-基础测试
能够清楚看到每组测试结果。这种形式能够轻易添加测试用例。

相关推荐