0

0

如何在Golang中使用testing标准库_Golang单元测试基础用法

P粉602998670

P粉602998670

发布时间:2026-02-09 14:47:02

|

169人浏览过

|

来源于php中文网

原创

Go测试函数必须命名为func TestXxx(*testing.T),Xxx首字母大写且文件以_test.go结尾;失败用t.Error或t.Fatal,推荐表格驱动测试和t.Run分组。

如何在golang中使用testing标准库_golang单元测试基础用法

Go 的 testing 库不依赖第三方,开箱即用,但写法和主流框架差异大——它靠命名约定驱动,不是靠注解或断言函数;测试函数必须以 Test 开头且接收 *testing.T,否则根本不会被 go test 发现。

如何命名和定义一个可运行的测试函数

Go 不识别 test__test 或任意前缀后缀,只认准 func TestXxx(*testing.T) 这一签名。Xxx 必须是大写字母开头(即导出名),否则 go test 会静默跳过。

  • func TestAdd(t *testing.T) ✅ 可执行
  • func testAdd(t *testing.T) ❌ 不会被发现
  • func Test_add(t *testing.T) ❌ Xxx 首字母必须大写
  • func TestAdd(t int) ❌ 参数类型必须是 *testing.T

测试文件也需遵守命名规则:必须以 _test.go 结尾,且和待测代码在同一个包内(比如 math.go 对应 math_test.go)。

如何在测试中报告失败并提前退出

*testing.T 提供了 Fail()FailNow()Error()Fatal() 等方法,区别在于是否终止当前函数执行:

立即学习go语言免费学习笔记(深入)”;

  • t.Error("msg") 打印错误但继续执行后续语句
  • t.Fatal("msg") 打印错误并立即 return,不再跑该测试函数剩余逻辑
  • t.Errorf("want %v, got %v", want, got) 是最常用写法,支持格式化输出
  • 避免混用 log.Printfmt.Println ——它们不会被标记为失败,也不会计入测试统计

示例:

SciMaster
SciMaster

全球首个通用型科研AI智能体

下载
func TestDivide(t *testing.T) {
    result := divide(10, 0)
    if result != 0 {
        t.Fatalf("divide by zero should return 0, got %v", result)
    }
}

如何为同一函数写多个测试用例(表格驱动)

Go 官方推荐“表格驱动测试”(table-driven tests),用切片定义多组输入/期望值,避免重复写 TestXxx 函数。关键点是:每个子测试用 t.Run() 包裹,便于定位失败项,且支持并发执行(加 t.Parallel())。

  • 子测试名建议可读,如 "positive_numbers",不要用索引 "case 0"
  • t.Run() 内部的逻辑独立,t.Fatal 只终止当前子测试,不影响其他子测试
  • 若想让子测试并发运行,必须在 t.Run() 内第一行调用 t.Parallel()

示例:

func TestAddTable(t *testing.T) {
    tests := []struct {
        a, b, want int
    }{
        {1, 2, 3},
        {-1, 1, 0},
        {0, 0, 0},
    }
    for _, tt := range tests {
        t.Run(fmt.Sprintf("%d+%d", tt.a, tt.b), func(t *testing.T) {
            t.Parallel()
            got := Add(tt.a, tt.b)
            if got != tt.want {
                t.Errorf("Add(%d,%d) = %d, want %d", tt.a, tt.b, got, tt.want)
            }
        })
    }
}

如何运行测试并查看覆盖率和详细输出

go test 命令本身足够轻量,但参数组合决定你能看到什么信息:

  • go test —— 默认只运行当前目录下所有 *_test.go 中的 TestXxx 函数
  • go test -v —— 显示每个测试函数名和 t.Log() 输出,便于调试
  • go test -run=^TestAdd$ —— 正则匹配测试名,精确运行单个函数(^$ 防止误匹配 TestAddWithCache
  • go test -cover —— 输出整体测试覆盖率(如 coverage: 85.7% of statements
  • go test -coverprofile=c.out && go tool cover -html=c.out —— 生成 HTML 覆盖率报告,标出未覆盖的行

注意:-cover 统计的是「被至少一个测试执行到的源码行」,不是「是否断言正确」;一行代码即使逻辑错,只要被执行了就算覆盖。

最容易被忽略的是:子测试名重复会导致后一个覆盖前一个,t.Run("same_name", ...) 在同一作用域内多次调用时,最终报告里只显示最后一次的结果;还有,测试文件里如果写了 func BenchmarkXxx(*testing.B)func ExampleXxx(),它们不会干扰单元测试,但需要对应参数类型,写错也不会报错,只是静默无效。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

185

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

233

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

345

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

211

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

400

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

302

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

196

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

722

2025.06.17

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

130

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.3万人学习

AngularJS教程
AngularJS教程

共24课时 | 3.5万人学习

CSS教程
CSS教程

共754课时 | 29.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号