在开发程序中,很重要一点就是测试,测试可以保证代码的质量,保证每个函数可以正常运行。但是如何保证写出来的程序是否正确。单元测试一般是用来测试我们的代码逻辑有没有问题,有没有按照我们期望的运行,以保证代码质量。
testing - 单元测试
Go语言自带有一个轻量级的测试框架testing和自带的go test命令来实现单元测试(T类型)和性能测试(B类型)。testing框架和其他语言中的测试框架类似,你可以基于这个框架写针对相应函数的测试用例,也可以基于该框架写相应的压力测试用例。下面主要以单元测试讲解。
如何编写测试用例
由于go test命令只能在一个相应的目录下执行所有文件,所以我们接下来新建一个项目目录gotest,这样我们 所有的代码和测试代码都在这个目录下。
接下来我们在该目录下面创建两个文件:gotest.go和gotest_test.go
gotest.go
package gotest
import (
"fmt"
"io/ioutil"
"encoding/json"
)
type Monster struct{
Name string
Age int
Skill string
}
//给Monster绑定方法,可以将一个Monster变量(对象),序列化后保存到文件中
func (this *Monster)Store()bool{
//先序列化
data,err := json.Marshal(this)
if err != nil{
fmt.Println("marshal err = ",err)
return false
}
//保存到文件
filePath := "./monster.ser"
err = ioutil.WriteFile(filePath,data,0666)
if err != nil{
fmt.Println("write file err = ",err)
return false
}
return true
}
//给Monster 绑定方法Restore,可以将一个序列化的Marshal(),从文件中读取
//并反序列化为Monster对象,检查反序列化,名字正确
func (this *Monster) ReStore()bool{
//1、先从文件中,读取序列化的字符串
filePath := "monster.ser"
data ,err := ioutil.ReadFile(filePath)
if err != nil{
fmt.Println("Readfile err =",err)
return false
}
//2.使用读取到data []byte,对反序列化
err = json.Unmarshal(data,this)
if err != nil{
fmt.Println("Unmarshal err = ",err)
return false
}
return true
}
gotest_test.go
这是我们的单元测试文件。通过 go test 命令,能够自动执行如下形式的任何函数:
package gotest
import (
"testing"
)
//测试用例,测试store方法
func TestStore(t *testing.T){
//先创建一个Monster实例
monster := &Monster{
Name : "minger",
Age : 23,
Skill : "Linux c/c++",
}
res := monster.Store()
if !res {
t.Fatalf("monster.Store() 错误,希望为 = %v 实际为 = %v",true,res)
}
t.Logf("monster.Store(),测试成功!")
}
func TestReStore(t *testing.T){
//先创建一个 Monster 实例,不需要指定字段的值
var monster = & Monster{}
res := monster.ReStore()
if !res{
t.Fatalf("monster.ReStore()错误,希望为 = %v 实际为 = %v",true,res)
}
//进一步判断
if monster.Name != "minger"{
t.Fatalf("monster.Restore() 错误,希望为 = %v ,实际为 = %v","minger",monster.Name)
}
t.Logf("monster.ReStore() 测试成功!")
}
然后我们在终端的项目目录下运行go test -v就可以看到测试结果了。go test -v:显示所有测试函数运行细节
go test -v
monster.ser 文件内容:
go test -run TestStore 指定要执行的测试函数。
gotest_test.go:这是我们的单元测试文件,但是记住下面的这些原则:
1、文件名必须是_test.go结尾的,这样在执行go test的时候才会执行到相应的代码
2、单元测试的函数名必须以Test开头,是可导出公开的函数
3、测试函数TestXxx()的传递给测试函数的参数是 *testing.T 类型。它用于管理测试状态并支持格式化测试日志。
4、测试格式:func TestXxx (t *testing.T),Xxx部分可以为任意的字母数字的组合,但是首字母不能是小写字母[a-z],例如Testintdiv是错误的函数名。
5、函数中通过调用testing.T的Error, Errorf, FailNow, Fatal, FatalIf方法,说明测试不通过,调用Log、Logf方法用来记录测试的信息。