Golang Go语言中常见“坑”(2)-go test

发布于 1周前 作者 gougou168 来自 Go语言

Golang Go语言中常见“坑”(2)-go test

上会聊了 select 和无缓冲 chan 的作用,这会说下 go test 的输出。

猜下代码输出

如果你觉得会输出
fmt log test1
log test1
fmt error test1
error test1

那就可以继续往下看

package main

import ( “fmt” “testing” “time” )

func TestHelloWorld(t *testing.T) { //t.Fatalf(“fatal test 1\n”) fmt.Printf(“fmt log test1\n”)

    t.Logf("log test1\n")

    fmt.Printf("fmt error test1\n")
    t.Errorf("error test1\n")

    time.Sleep(time.Second * 60)

}

输出分析

  • 运行命令
go test -v
  • 输出
=== RUN   TestHelloWorld
fmt log test1
fmt error test1

什么?这和预期的不符合的。。。看来 t.Logf 此类函数,只有等 TestHelloWorld 函数结束之后才会把真的数据刷新到 os.Stdout。 这点可以从源码得到佐证,Logf 的调用流程:Logf--->log--->logDepth(s,3)--->只是把数据缓存到 c.output 变量里面。

结论

go test 里面的 t.Logf, t.Errorf 之类函数,只有在 Testxxx 函数测试函数结束之后才会打印到终端,如果你的测试依赖日志的输出状态,可以使用 fmt.Printf 之类函数。
对 go test 调用流程感兴趣的童鞋可以看下 testing.go 。runTests-->tRunner-->Run-->report-->flushToParent。这个链条下面会把 c.output 的的数据写到 os.Stdout 里面。

我的 github

https://github.com/guonaihong/gout


更多关于Golang Go语言中常见“坑”(2)-go test的实战系列教程也可以访问 https://www.itying.com/category-94-b0.html

1 回复

更多关于Golang Go语言中常见“坑”(2)-go test的实战系列教程也可以访问 https://www.itying.com/category-94-b0.html


在Go语言(Golang)中,go test 是进行单元测试、基准测试和示例测试的强大工具。然而,在使用 go test 时,开发者经常会遇到一些常见的“坑”。以下是一些关键点和建议,帮助你更有效地使用 go test

  1. 测试文件命名:确保测试文件与被测试文件在同一包内,且文件名以 _test.go 结尾。这是 go test 自动识别测试文件的标准。

  2. 测试函数命名:测试函数应以 Test 开头,后跟描述性名称。例如,TestAddition 表示测试加法功能。基准测试函数则以 Benchmark 开头,示例测试函数以 Example 开头。

  3. 并行测试:使用 -p 标志可以指定并行运行的测试包数量。默认情况下,go test 会根据系统CPU核心数自动调整。

  4. 覆盖率报告:使用 -cover 标志生成覆盖率报告,-coverprofile 可以将覆盖率数据保存到文件中,便于后续分析。

  5. 短测试:使用 -short 标志可以运行只标记为 Short 的测试,这对于快速验证关键路径特别有用。

  6. 构建标签:通过 -tags 标志可以指定构建标签,用于条件编译和测试特定功能。

  7. 忽略缓存:使用 -count=1 强制重新运行测试,忽略测试缓存,确保每次运行都是最新的结果。

掌握这些技巧和注意事项,可以帮助你更有效地使用 go test,避免常见“坑”,提高代码质量和测试覆盖率。

回到顶部