首页 >后端开发 >Golang >如何在Go测试中打印调试信息?

如何在Go测试中打印调试信息?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-04 00:02:10926浏览

How Do I Print Debugging Information in Go Tests?

使用“testing”包登录 Go 测试

编写 Go 测试时,可能会出现需要打印信息以进行调试的情况。但是,仅在测试函数中调用 fmt.Println 不会产生可见的输出。

默认情况下,测试中 fmt.Println 语句的输出被抑制。要显示此类输出,必须使用testing.T结构提供的.Log或.Logf方法。

使用.Log和.Logf

类似于fmt.Print和fmt.Printf 、.Log 和.Logf 允许您打印格式化输出。例如,不应使用:

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

您应该使用:

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

使用详细信息查看输出

即使使用 .Log,输出也可能不可见除非您在运行 go test 时提供 -v (详细程度)标志。可以使用以下语法指定此标志:

go test -v your_test_file.go

通过添加 -v 标志,.Log 语句的输出将显示在控制台上。

为什么隐藏打印语句

fmt.X 打印语句确实在测试中起作用。然而,它们的输出通常不会显示在预期位置,因为测试结果在打印之前由 Go 测试基础设施进行处理。另一方面,.Log 方法专门设计用于在测试环境中显示格式化输出,并且可以使用详细标志进行控制。

以上是如何在Go测试中打印调试信息?的详细内容。更多信息请关注PHP中文网其他相关文章!

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