首页 >后端开发 >Golang >为什么 `fmt.Println()` 在 Go 测试中不起作用,如何打印调试信息?

为什么 `fmt.Println()` 在 Go 测试中不起作用,如何打印调试信息?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-28 19:17:10175浏览

Why Doesn't `fmt.Println()` Work in Go Tests, and How Can I Print Debugging Information?

使用“testing”包在 Go 测试中打印

想象一下,您正在对失败的测试进行故障排除,并希望添加打印语句进行调试,但是当您运行测试时什么也没有显示。这是为什么?

在 Go 中,内置的 fmt.Println() 语句在测试中无法按预期工作。相反,“testing”包提供了打印的替代方法。

结构体testing.T和testing.B具有.Log和.Logf方法,提供与fmt.Print和fmt.Printf类似的功能。这些方法允许您在测试中打印语句。

示例:

func TestPrintSomething(t *testing.T) {
    t.Log("Say hi")
}

但是,即使使用这些方法,输出也可能不会立即可见。要查看日志消息,您需要在运行测试时提供 -v 标志(用于详细程度):

go test -v

使用 -v 标志,日志消息将与测试结果一起打印,给出您需要的调试信息。

以上是为什么 `fmt.Println()` 在 Go 测试中不起作用,如何打印调试信息?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn