Go单元测试-testing

在开发程序中,很重要一点就是测试,测试可以保证代码的质量,保证每个函数可以正常运行。但是如何保证写出来的程序是否正确。单元测试一般是用来测试我们的代码逻辑有没有问题,有没有按照我们期望的运行,以保证代码质量。

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方法用来记录测试的信息。

在这里插入图片描述
在这里插入图片描述
喜欢本文的朋友,欢迎关注微信公众号(图一) “程序猿编码” 收看更多精彩文章。扫码二维码(图二);添加本人微信。备注:加群。即可加入“程序猿编码”交流群。

发布了79 篇原创文章 · 获赞 53 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/chen1415886044/article/details/104324688