命名规则: xxx_test.go
关于测试文件的存放位置,常见的做法实际上是和源代码放在一起
假如需要测试的有两个功能函数:
GetData()
ReadData()
单元测试时,可以将测试单元TestGetData以及TestReadData放在同一个文件中,也可以将它们放在不同的文件中。为了测试方便,采用将它们放在同一个文件中这种处理方法。假如该文件名为:
get_function_test.go
那么,两个测试单元的函数定义为:
func TestGetData(t *testing.T) func TestReadData(t *testing.T)
如果想要测试TestGetData,则执行:
go test get_function_test.go -test.run TestGetData
如果在测试文件中仅包含一个测试单元,那么就无需特别用test.run指定测试的单元
另外可以在测试代码中,通过:
t.Log(content)来打印自己感兴趣的内容,但同时需要在测试命令中添加-v参数,如:
go test -v get_function_test.go
关于踩的坑:
1. 测试函数中,fmt.Println这样的语句是无法打印出消息的,但是可以使用go-logging打印出日志消息, 将t作为参数传入源代码,在源代码内部执行t.Log,经验证,也是无效的
2. 在测试代码中如果使用到了其他文件的源代码,在执行go test时,需要同时将这些文件名列出来,否则会报undefined错误
3. 多次进行测试时,如果测试代码和功能代码都没有修改,则后面的结果都是使用的缓存的结果(在结果输出的最后有类似cached的字样),有的时候,我们是不希望这种情况发生的。这个时候,可以使用-count=1来禁用缓存