0

0

Go测试函数怎么写_Go Test函数标准写法

P粉602998670

P粉602998670

发布时间:2026-02-01 14:10:02

|

866人浏览过

|

来源于php中文网

原创

Go测试函数必须命名为TestXxx且参数为*testing.T,定义在_test.go文件中、同包名下;需用t.Error/Fatal报告失败,推荐表驱动测试。

go测试函数怎么写_go test函数标准写法

Go测试函数必须叫TestXxx,且参数固定为*testing.T

Go的测试函数不是随便命名的,必须以Test开头,后接**大写字母开头的驼峰名**(如TestAddTestParseURL),不能是test_addtestAdd。函数签名也严格限定为func(t *testing.T)——少一个星号、换类型、加参数都会导致go test直接忽略该函数。

常见错误现象:go test运行后显示no tests to run,但文件里明明写了函数——八成是命名不合规或参数不对。

  • 函数必须定义在_test.go结尾的文件中(如math_test.go
  • 函数必须是包级导出函数(首字母大写),但名字本身不需导出,TestXxx已满足导出要求
  • 不能用*testing.B代替*testing.T,那是基准测试用的

t.Errorft.Fatal报告失败,别用panic或log

测试中检查逻辑失败时,必须调用t.Error*系列方法,比如t.Errorf("expected %v, got %v", want, got)。这些方法会标记当前测试失败,但允许继续执行后续断言;而t.Fatal*会立即终止当前测试函数。

绝对不要在测试里写paniclog.Fatalos.Exit——它们会让go test无法正确统计失败数,甚至中断整个测试套件。

  • t.Error:记录错误,继续执行
  • t.Fatal:记录错误,立刻返回(适合前置条件不满足,如文件不存在)
  • t.Log:只输出日志,不影响测试结果
  • 所有t.*方法只能在测试函数内调用,不能传给子函数再调(除非显式传*testing.T

表驱动测试是Go推荐写法,用struct切片组织用例

Go标准库和主流项目几乎都用表驱动(table-driven)方式写测试,把输入、期望输出、说明打包进一个结构体切片,然后range循环执行。这样比重复写一堆TestXxx1/TestXxx2更易维护、覆盖更全。

宣小二
宣小二

宣小二:媒体发稿平台,自媒体发稿平台,短视频矩阵发布平台,基于AI驱动的企业自助式投放平台。

下载
func TestSplit(t *testing.T) {
    tests := []struct {
        name  string
        input string
        sep   string
        want  []string
    }{
        {"empty", "", ",", []string{}},
        {"single", "a", ",", []string{"a"}},
        {"multi", "a,b,c", ",", []string{"a", "b", "c"}},
    }
    for _, tt := range tests {
        t.Run(tt.name, func(t *testing.T) {
            got := Split(tt.input, tt.sep)
            if !reflect.DeepEqual(got, tt.want) {
                t.Errorf("Split() = %v, want %v", got, tt.want)
            }
        })
    }
}

注意:t.Run创建子测试,让每个用例独立显示、可单独运行(如go test -run=TestSplit/empty),还能避免变量闭包陷阱(循环中tt被复用)。

测试文件路径和包名要和被测代码对齐

测试文件必须和被测代码在**同一目录**,且声明相同的包名(通常是package xxx,不是package xxx_test)。只有想测试包私有符号(如未导出函数、变量)时,才需要另建xxx_internal_test.go并用package xxx_test——但这属于高级用法,日常80%场景不需要。

  • 错误做法:把http_test.go放在test/子目录下 → go test找不到
  • 错误做法:测试文件写package main → 编译失败
  • 如果被测代码在cmd/mytool/下,测试文件也得放那儿,不能挪到根目录

路径和包名错一个字符,测试就静默失效——这是最常被忽略的硬性约束。

热门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 :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

182

2024.02.23

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

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

229

2024.02.23

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

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

344

2024.02.23

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

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

210

2024.03.05

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

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

397

2024.05.21

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

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

262

2025.06.09

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

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

194

2025.06.10

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

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

498

2025.06.17

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

30

2026.01.31

热门下载

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

精品课程

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

共32课时 | 4.5万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

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

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