Commit f395e878 authored by David Lazar's avatar David Lazar

io: fix test when MultiReader is inlined with -l=3

This ensures there isn't a live reference to buf1 on our stack
when MultiReader is inlined.

Fixes #18819.

Change-Id: I96a8cdc1ffad8f8a10c0ddcbf0299005f3176b61
Reviewed-on: https://go-review.googlesource.com/35931
Run-TryBot: David Lazar <lazard@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarAustin Clements <austin@google.com>
Reviewed-by: default avatarRuss Cox <rsc@golang.org>
parent 16e430e1
...@@ -239,14 +239,17 @@ func TestMultiReaderFinalEOF(t *testing.T) { ...@@ -239,14 +239,17 @@ func TestMultiReaderFinalEOF(t *testing.T) {
func TestMultiReaderFreesExhaustedReaders(t *testing.T) { func TestMultiReaderFreesExhaustedReaders(t *testing.T) {
var mr Reader var mr Reader
closed := make(chan struct{}) closed := make(chan struct{})
{ // The closure ensures that we don't have a live reference to buf1
// on our stack after MultiReader is inlined (Issue 18819). This
// is a work around for a limitation in liveness analysis.
func() {
buf1 := bytes.NewReader([]byte("foo")) buf1 := bytes.NewReader([]byte("foo"))
buf2 := bytes.NewReader([]byte("bar")) buf2 := bytes.NewReader([]byte("bar"))
mr = MultiReader(buf1, buf2) mr = MultiReader(buf1, buf2)
runtime.SetFinalizer(buf1, func(*bytes.Reader) { runtime.SetFinalizer(buf1, func(*bytes.Reader) {
close(closed) close(closed)
}) })
} }()
buf := make([]byte, 4) buf := make([]byte, 4)
if n, err := ReadFull(mr, buf); err != nil || string(buf) != "foob" { if n, err := ReadFull(mr, buf); err != nil || string(buf) != "foob" {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment