testing - 测试基本使用接口

当你写完一个函数,结构体,main之后,你下一步需要的就是测试了。testing包提供了很简单易用的测试包。

写一个基本的测试用例#

测试文件的文件名需要以_test.go为结尾,测试用例需要以TestXxxx的样式存在。

比如我要测试utils包的sql.go中的函数:

func GetOne(db *sql.DB, query string, args ...interface{}) (map[string][]byte, error) {

就需要创建一个sql_test.go

package utils

import (
"database/sql"
_ "fmt"
_ "github.com/go-sql-driver/mysql"
"strconv"
"testing"
) func Test_GetOne(t *testing.T) {
db, err := sql.Open("mysql", "root:123.abc@tcp(192.168.33.10:3306)/test")
defer func() {
db.Close()
}()
if err != nil {
t.Fatal(err)
} // 测试empty
car_brand, err := GetOne(db, "select * from user where id = 999999")
if (car_brand != nil) || (err != nil) {
t.Fatal("emtpy测试错误")
}
}

testing的测试用例形式#

测试用例有四种形式:

TestXxxx(t *testing.T) // 基本测试用例

BenchmarkXxxx(b *testing.B) // 压力测试的测试用例

Example_Xxx() // 测试控制台输出的例子

TestMain(m *testing.M) // 测试Main函数

给个Example的例子:(Example需要在最后用注释的方式确认控制台输出和预期是不是一致的)

func Example_GetScore() {
score := getScore(100, 100, 100, 2.1)
fmt.Println(score)
// Output:
// 31.1
}

testing的变量#

gotest的变量有这些:

  • test.short : 一个快速测试的标记,在测试用例中可以使用testing.Short()来绕开一些测试
  • test.outputdir : 输出目录
  • test.coverprofile : 测试覆盖率参数,指定输出文件
  • test.run : 指定正则来运行某个/某些测试用例
  • test.memprofile : 内存分析参数,指定输出文件
  • test.memprofilerate : 内存分析参数,内存分析的抽样率
  • test.cpuprofile : cpu分析输出参数,为空则不做cpu分析
  • test.blockprofile : 阻塞事件的分析参数,指定输出文件
  • test.blockprofilerate : 阻塞事件的分析参数,指定抽样频率
  • test.timeout : 超时时间
  • test.cpu : 指定cpu数量
  • test.parallel : 指定运行测试用例的并行数

testing包内的结构#

  • B : 压力测试
  • BenchmarkResult : 压力测试结果
  • Cover : 代码覆盖率相关结构体
  • CoverBlock : 代码覆盖率相关结构体
  • InternalBenchmark : 内部使用的结构
  • InternalExample : 内部使用的结构
  • InternalTest : 内部使用的结构
  • M : main测试使用的结构
  • PB : Parallel benchmarks 并行测试使用结果
  • T : 普通测试用例
  • TB : 测试用例的接口

testing的通用方法#

T结构内部是继承自common结构,common结构提供集中方法,是我们经常会用到的:

当我们遇到一个断言错误的时候,我们就会判断这个测试用例失败,就会使用到:

Fail  : case失败,测试用例继续
FailedNow : case失败,测试用例中断

当我们遇到一个断言错误,只希望跳过这个错误,但是不希望标示测试用例失败,会使用到:

SkipNow : case跳过,测试用例不继续

当我们只希望在一个地方打印出信息,我们会用到:

Log : 输出信息
Logf : 输出有format的信息

当我们希望跳过这个用例,并且打印出信息:

Skip : Log + SkipNow
Skipf : Logf + SkipNow

当我们希望断言失败的时候,测试用例失败,打印出必要的信息,但是测试用例继续:

Error : Log + Fail
Errorf : Logf + Fail

当我们希望断言失败的时候,测试用例失败,打印出必要的信息,测试用例中断:

Fatal : Log + FailNow
Fatalf : Logf + FailNow

最新文章

  1. spring mvc 和spring security配置 spring-servlet.xml和spring-security.xml设置
  2. boost.python笔记
  3. SQL Server 数据库查找重复记录的几种方法
  4. make命令以及makefile
  5. codeforces B.Fixed Points
  6. Excel2016右键新建工作表,打开时提示“因为文件格式或文件扩展名无效。请确定文件未损坏,并且文件扩展名与文件的格式匹配。”的解决办法
  7. linq简介
  8. BootStrap2学习日记1--网格系统
  9. spring定时器用Annotation兑现
  10. javascript关于检测浏览器和操作系统的问题
  11. SQL Server 数据的创建、增长、收缩
  12. 从零开始学Xamarin.Forms(三) Android 制作启动画面
  13. 使用Windows2003创建FTP服务器 - 进阶者系列 - 学习者系列文章
  14. CF1129B 【Wrong Answer】
  15. vue开发项目详细教程(第一篇 搭建环境篇)
  16. git使用:本地项目推送到gitlab
  17. Linux下自动清理超过指定大小文件
  18. 小程序微信支付java
  19. POJ3281(KB11-B 最大流)
  20. JavaWeb 返回json数据的两种方式

热门文章

  1. 在 Cloud 9 中搭建和运行 Go
  2. Java多线程12:ReentrantLock中的方法
  3. 换个角度理解云计算之HDFS
  4. js模版引擎handlebars.js实用教程——with-终极this应用
  5. Node.js使用fs.renameSync报cross-device link not permitted错误
  6. C# 加密–RSA前端与后台的加密&解密
  7. Java中static的理解
  8. [Java面试十]浏览器跨域问题.
  9. Atitit 泛型原理与理解attilax总结
  10. js 事件