golang单元测试

单元测试

类型 前缀 签名 用途
测试函数 Test func TestXxx(t *testing.T) 功能测试、验证逻辑正确性
基准函数 Benchmark func BenchmarkXxx(b *testing.B) 性能测试、效率评估
示例函数 Example func ExampleXxx() 用法展示、生成文档

testing框架

  1. 文件名以_test.go结尾,放在与被测试包相同的包中
  2. 测试用例函数名以Test开头,一般为Test+被测试的函数名)
  3. **TestaddUpper(*testing.T)**的形参类型必须是*testing.T
  4. 一个测试用例文件中,可以有很多测试用例函数,比如TestAddUpper、TestSub
  5. 运行测试用例指令
    • cmd>go test [运行正确,无日志;运行错误,输出日志]
    • cmd>go test -v [运行正确或是错误,都将输出日志]
  6. t.Fatalf方法可以格式化输出错误信息,并退出程序
  7. t.Logf方法可以输出相应日志
  8. PASS表示运行成功,FAIL表示运行失败
go 复制代码
func addUpper(n int) int {
	res := 0
	for i := 1; i <= n; i++ {
		res += i
	}
	return res
}

func TestAddUpper(t *testing.T) {

	res := addUpper(10)
	if res != 55 {
		//fmt.Println("AddUpper(10) 执行错误,期望值=%v 实际值=%v", 55, res)
		t.Fatalf("AddUpper(10) 执行错误,期望值=%v 实际值=%v", 55, res)
	}

	//如果正确,输出日志
	t.Logf("AddUpper(10) 执行正确...")
}

实例:

go 复制代码
// 给Monster绑定方法Store,可以将一个Monster变量(对象),序列化后保存到文件中
func (this *Monster) Store() bool {

	//先序列化
	data, err := json.Marshal(this)
	if err != nil {
		fmt.Println("marshal err =", err)
		return false
	}
	//保存到文件
	filePath := "D:\\GoLand-go\\filedemo.txt"
	err = ioutil.WriteFile(filePath, data, 0666)
	if err != nil {
		fmt.Println("write file err =", err)
		return false
	}
	return true
}

// 给Monster绑定方法ReStore,可以将一个序列化的Monster,从文件中读取
// 并且反序列化为monster对象,检查反序列化,名字正确
func (this *Monster) ReStore() bool {

	//先从文件中,读取序列化的字符串
	filePath := "D:\\GoLand-go\\filedemo.txt"
	data, err := ioutil.ReadFile(filePath)
	if err != nil {
		fmt.Println("ReadFile err =", err)
		return false
	}

	//使用读取到data []byte,对反序列化
	err = json.Unmarshal(data, this)
	if err != nil {
		fmt.Println("UnMarshal err = ", err)
		return false
	}
	return true
}

// 测试用例,测试Store方法
func TestMonster_Store(t *testing.T) {

	//先创建一个Monster实例
	monster := Monster{
		Name:  "红孩儿",
		Age:   10,
		Skill: "吐火",
	}
	res := monster.Store()
	if !res {
		t.Fatalf("monster.Store() 错误,希望为=%v 实际为=%v", true, res)
	}
	t.Logf("monster.Store() 测试成功!")
}

// 测试用例,测试ReStore方法
func TestMonster_ReStore(t *testing.T) {

	//先创建一个Monster实例,不需要指定字段的值
	var monster Monster

	res := monster.ReStore()
	if !res {
		t.Fatalf("monster.ReStore() 错误,希望为=%v 实际为=%v", true, res)
	}
	//进一步判断
	if monster.Name != "红孩儿" {
		t.Fatalf("monster.ReStore() 错误,希望为=%v 实际为=%v", "红孩儿", monster.Name)

	}

	t.Logf("monster.ReStore() 测试成功!")
}

基准测试

基准测试以Benchmark为前缀,需要一个testing.B类型的参数 b*,基准测试必须要执行b.N次,这样的测试才有对照性,b.N的值是系统根据实际情况去调整的,从而保证测试的稳定性

基准测试并不会默认执行,需要增加**-bench参数(还可以为基准测试添加-benchmem**参数,来获得内存分配的统计数据)

默认情况下,每个基准测试至少运行1秒。如果在Benchmark函数返回时没有到1秒,则b.N的值会按1,2,5,10,20,50,...增加,并且函数再次运行

b.ResetTimer之前的处理不会放到执行时间里,也不会输出到报告中,所以可以在之前做一些不计划作为测试报告的操作

相关推荐
倔强青铜33 小时前
苦练Python第18天:Python异常处理锦囊
开发语言·python
u_topian3 小时前
【个人笔记】Qt使用的一些易错问题
开发语言·笔记·qt
珊瑚里的鱼4 小时前
LeetCode 692题解 | 前K个高频单词
开发语言·c++·算法·leetcode·职场和发展·学习方法
AI+程序员在路上4 小时前
QTextCodec的功能及其在Qt5及Qt6中的演变
开发语言·c++·qt
xingshanchang4 小时前
Matlab的命令行窗口内容的记录-利用diary记录日志/保存命令窗口输出
开发语言·matlab
Risehuxyc4 小时前
C++卸载了会影响电脑正常使用吗?解析C++运行库的作用与卸载后果
开发语言·c++
AI视觉网奇4 小时前
git 访问 github
运维·开发语言·docker
不知道叫什么呀5 小时前
【C】vector和array的区别
java·c语言·开发语言·aigc
liulilittle5 小时前
.NET ExpandoObject 技术原理解析
开发语言·网络·windows·c#·.net·net·动态编程
wan_da_ren5 小时前
JVM监控及诊断工具-GUI篇
java·开发语言·jvm·后端