aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/go/testdata/script/test_finished_subtest_goroutines.txt
blob: 8db821eb77f2ecee3f1daad4144570f2c50f68f7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
# Regression test for https://golang.org/issue/45127:
# Goroutines for completed parallel subtests should exit immediately,
# not block until earlier subtests have finished.

[short] skip

! go test .
stdout 'panic: slow failure'
! stdout '\[chan send'

-- go.mod --
module golang.org/issue45127

go 1.16
-- issue45127_test.go --
package main

import (
	"fmt"
	"runtime"
	"runtime/debug"
	"sync"
	"testing"
)

func TestTestingGoroutineLeak(t *testing.T) {
	debug.SetTraceback("all")

	var wg sync.WaitGroup
	const nFast = 10

	t.Run("slow", func(t *testing.T) {
		t.Parallel()
		wg.Wait()
		for i := 0; i < nFast; i++ {
			// If the subtest goroutines are going to park on the channel
			// send, allow them to park now. If they're not going to park,
			// make sure they have had a chance to run to completion so
			// that they aren't spuriously parked when we panic.
			runtime.Gosched()
		}
		panic("slow failure")
	})

	wg.Add(nFast)
	for i := 0; i < nFast; i++ {
		t.Run(fmt.Sprintf("leaky%d", i), func(t *testing.T) {
			t.Parallel()
			wg.Done()
		})
	}
}