-
Notifications
You must be signed in to change notification settings - Fork 18.8k
Closed
Labels
FrozenDueToAgeNeedsInvestigationSomeone must examine and confirm this is a valid issue and not a duplicate of an existing one.Someone must examine and confirm this is a valid issue and not a duplicate of an existing one.
Milestone
Description
What version of Go are you using (go version)?
$ go version go version go1.14rc1 darwin/amd64
Does this issue reproduce with the latest release?
What operating system and processor architecture are you using (go env)?
go env Output
$ go env go1.14rc1 env GO111MODULE="on" GOARCH="amd64" GOBIN="" GOCACHE="/Users/lestrrat/Library/Caches/go-build" GOENV="/Users/lestrrat/Library/Application Support/go/env" GOEXE="" GOFLAGS="" GOHOSTARCH="amd64" GOHOSTOS="darwin" GOINSECURE="" GONOPROXY="" GONOSUMDB="" GOOS="darwin" GOPATH="/Users/lestrrat/dev" GOPRIVATE="" GOPROXY="https://proxy.golang.org,direct" GOROOT="/Users/lestrrat/sdk/go1.14rc1" GOSUMDB="sum.golang.org" GOTMPDIR="" GOTOOLDIR="/Users/lestrrat/sdk/go1.14rc1/pkg/tool/darwin_amd64" GCCGO="gccgo" AR="ar" CC="clang" CXX="clang++" CGO_ENABLED="1" GOMOD="/Users/lestrrat/dev/src/gitlab.com/endeworks/gihyo-wdpress/go.mod" CGO_CFLAGS="-g -O2" CGO_CPPFLAGS="" CGO_CXXFLAGS="-g -O2" CGO_FFLAGS="-g -O2" CGO_LDFLAGS="-g -O2" PKG_CONFIG="pkg-config" GOGCCFLAGS="-fPIC -m64 -pthread -fno-caret-diagnostics -Qunused-arguments -fmessage-length=0 -fdebug-prefix-map=/var/folders/lj/kxy3y5j545772wn23sg34qk00000gn/T/go-build418226800=/tmp/go-build -gno-record-gcc-switches -fno-common"
What did you do?
package foo_test
import (
"testing"
)
func TestCleanup(t *testing.T) {
t.Logf("In test")
t.Cleanup(func() { t.Logf("Hello, test cleanup!") })
}
func BenchmarkCleanup(b *testing.B) {
b.Logf("In benchmark")
b.Cleanup(func() { b.Logf("Hello, benchmark cleanup!") })
}What did you expect to see?
finch% go1.14rc1 test -bench . -benchmem ./src -v
=== RUN TestCleanup
TestCleanup: foo_test.go:8: In test
TestCleanup: foo_test.go:9: Hello, test cleanup!
--- PASS: TestCleanup (0.00s)
goos: darwin
goarch: amd64
pkg: <snip>
BenchmarkCleanup: foo_test.go:13: In benchmark
BenchmarkCleanup: foo_test.go:13: In benchmark
BenchmarkCleanup: foo_test.go:13: In benchmark
BenchmarkCleanup: foo_test.go:13: In benchmark
BenchmarkCleanup: foo_test.go:13: In benchmark
BenchmarkCleanup: foo_test.go:13: In benchmark
BenchmarkCleanup: foo_test.go:14: Hello, benchmark cleanup! <<< This
BenchmarkCleanup-4 1000000000 0.000015 ns/op 0 B/op 0 allocs/op
PASS
What did you see instead?
finch% go1.14rc1 test -bench . -benchmem ./src -v
=== RUN TestCleanup
TestCleanup: foo_test.go:8: In test
TestCleanup: foo_test.go:9: Hello, test cleanup!
--- PASS: TestCleanup (0.00s)
goos: darwin
goarch: amd64
pkg: <snip>
BenchmarkCleanup: foo_test.go:13: In benchmark
BenchmarkCleanup: foo_test.go:13: In benchmark
BenchmarkCleanup: foo_test.go:13: In benchmark
BenchmarkCleanup: foo_test.go:13: In benchmark
BenchmarkCleanup: foo_test.go:13: In benchmark
BenchmarkCleanup: foo_test.go:13: In benchmark
BenchmarkCleanup-4 1000000000 0.000015 ns/op 0 B/op 0 allocs/op
PASS
I'm not sure if the Cleanup isn't being fired at all, or the b.Logf is just not outputting anything. FWIW, I tried replacing b.Logf with a panic, and I didn't see anything different so I'm inclined to say that b.Cleanup just isn't firing?
(Edit: expected and actual output were flipped)
Reactions are currently unavailable
Metadata
Metadata
Assignees
Labels
FrozenDueToAgeNeedsInvestigationSomeone must examine and confirm this is a valid issue and not a duplicate of an existing one.Someone must examine and confirm this is a valid issue and not a duplicate of an existing one.