0

0

如何在Golang中使用testing编写单元测试_验证函数逻辑正确性

P粉602998670

P粉602998670

发布时间:2025-12-30 08:36:09

|

636人浏览过

|

来源于php中文网

原创

Go单元测试需写Test开头、*testing.T参数的函数,用t.Run组织子测试、t.Errorf报告失败,配合go test运行;测试文件名以_test.go结尾且与被测代码同包。

如何在golang中使用testing编写单元测试_验证函数逻辑正确性

在 Go 中用 testing 包写单元测试,核心是写以 Test 开头、参数为 *testing.T 的函数,然后用 t.Run 组织子测试、t.Errorf 报告失败,配合 go test 运行验证逻辑是否符合预期。

基础测试结构:从一个简单函数开始

假设你有一个计算两个整数最大值的函数:

func Max(a, b int) int {
    if a > b {
        return a
    }
    return b
}

对应测试文件(如 max_test.go)中这样写:

func TestMax(t *testing.T) {
    tests := []struct {
        name string
        a, b int
        want int
    }{
        {"positive", 3, 5, 5},
        {"equal", 4, 4, 4},
        {"negative", -2, -7, -2},
    }

    for _, tt := range tests {
        t.Run(tt.name, func(t *testing.T) {
            got := Max(tt.a, tt.b)
            if got != tt.want {
                t.Errorf("Max(%d, %d) = %d, want %d", tt.a, tt.b, got, tt.want)
            }
        })
    }
}
  • 测试文件名必须以 _test.go 结尾,且与被测代码在同一包内
  • t.Run 支持命名子测试,便于定位失败用例,也支持并行(加 t.Parallel()
  • 用结构体切片组织多组输入/期望输出,避免重复代码,提升可读性和覆盖度

验证边界与错误路径:不只是“正常情况”

真实逻辑常涉及空值、零值、错误返回等。比如一个解析 JSON 字符串的函数:

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

HIX Translate
HIX Translate

由 ChatGPT 提供支持的智能AI翻译器

下载
func ParseUser(s string) (*User, error) {
    var u User
    if err := json.Unmarshal([]byte(s), &u); err != nil {
        return nil, fmt.Errorf("parse user: %w", err)
    }
    return &u, nil
}

测试要覆盖成功、空字符串、非法 JSON、字段缺失等情况:

  • 成功解析:检查字段值是否正确赋值
  • 空输入:ParseUser("") 应返回非 nil error
  • 非法 JSON:ParseUser("{invalid") 同样应报错,且错误信息包含预期前缀
  • if err != nil + t.Errorassert.ErrorContains(需引入 github.com/stretchr/testify)判断错误内容

模拟依赖与控制副作用

如果函数依赖外部调用(如 HTTP 请求、数据库查询),不能在单元测试中真实发起网络请求。推荐做法是抽象接口、注入依赖:

type Fetcher interface {
    Get(url string) ([]byte, error)
}

func DownloadAndParse(f Fetcher, url string) (string, error) {
    data, err := f.Get(url)
    if err != nil {
        return "", err
    }
    return strings.TrimSpace(string(data)), nil
}

测试时传入一个内存实现:

type mockFetcher struct {
    data []byte
    err  error
}

func (m mockFetcher) Get(_ string) ([]byte, error) {
    return m.data, m.err
}

func TestDownloadAndParse(t *testing.T) {
    t.Run("success", func(t *testing.T) {
        got, err := DownloadAndParse(mockFetcher{data: []byte(" hello ")}, "http://x")
        if err != nil || got != "hello" {
            t.Errorf("unexpected result: %v, %v", got, err)
        }
    })

    t.Run("fetch error", func(t *testing.T) {
        _, err := DownloadAndParse(mockFetcher{err: errors.New("timeout")}, "http://x")
        if err == nil {
            t.Error("expected error, got nil")
        }
    })
}
  • 不直接调用 http.Get,而是通过接口接收行为,测试更可控、更快、无副作用
  • mock 实现只需满足接口,无需完整逻辑,聚焦验证被测函数对依赖返回的处理是否正确

运行与调试技巧

使用标准命令快速验证:

  • go test:运行当前目录所有测试
  • go test -v:显示每个测试名称和日志(t.Log 输出可见)
  • go test -run=^TestMax$:只运行指定测试函数
  • go test -cover:查看测试覆盖率(建议配合 -coverprofile=c.out && go tool cover -html=c.out 生成可视化报告)
  • 在测试中用 t.Fatalt.Fatalf 遇错终止当前子测试,避免后续断言干扰判断

相关专题

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

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

173

2024.02.23

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

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

224

2024.02.23

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

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

335

2024.02.23

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

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

206

2024.03.05

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

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

388

2024.05.21

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

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

193

2025.06.09

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

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

187

2025.06.10

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

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

191

2025.06.17

俄罗斯搜索引擎Yandex最新官方入口网址
俄罗斯搜索引擎Yandex最新官方入口网址

Yandex官方入口网址是https://yandex.com;用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1

2025.12.29

热门下载

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

精品课程

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

共46课时 | 2.7万人学习

AngularJS教程
AngularJS教程

共24课时 | 2.1万人学习

CSS教程
CSS教程

共754课时 | 17万人学习

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

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