1
0
mirror of https://github.com/golang/go synced 2024-11-23 10:20:03 -07:00
go/test/fixedbugs/issue4388.go
Mikio Hara 147a21456e test: fix flakey test case for issue 4388
Seems like we need to drag the stack for <autogenerated>:1 on Plan 9.

See http://build.golang.org/log/283b996102b833dd81c58301d78aceaa4fe9838b.

LGTM=rsc
R=rsc
CC=golang-codereviews
https://golang.org/cl/95390043
2014-05-15 06:39:15 +09:00

57 lines
1022 B
Go

// run
// Copyright 2014 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package main
import (
"fmt"
"io"
"runtime"
)
type T struct {
io.Closer
}
func f1() {
// The 4 here and below depends on the number of internal runtime frames
// that sit between a deferred function called during panic and
// the original frame. If that changes, this test will start failing and
// the number here will need to be updated.
defer checkLine(4)
var t *T
var c io.Closer = t
c.Close()
}
func f2() {
defer checkLine(4)
var t T
var c io.Closer = t
c.Close()
}
func main() {
f1()
f2()
}
func checkLine(n int) {
if err := recover(); err == nil {
panic("did not panic")
}
var file string
var line int
for i := 1; i <= n; i++ {
_, file, line, _ = runtime.Caller(i)
if file != "<autogenerated>" || line != 1 {
continue
}
return
}
panic(fmt.Sprintf("expected <autogenerated>:1 have %s:%d", file, line))
}