aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/go/testdata/script/test_chatty_parallel_success_sleepy.txt
blob: 5952a87beaba88f2fd87c01b37bf857e31090f05 (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
# Run parallel chatty tests. Assert on CONT lines. This test makes sure that
# multiple parallel outputs have the appropriate CONT lines between them.
go test -parallel 3 chatty_parallel_test.go -v

stdout '--- PASS: TestFast \([0-9.]{4}s\)\n=== CONT  TestSlow\n    chatty_parallel_test.go:31: this is the second TestSlow log\n--- PASS: TestSlow \([0-9.]{4}s\)'

-- chatty_parallel_test.go --
package chatty_paralell_test

import (
	"testing"
	"time"
)

var (
	run           = make(chan struct{})
	afterFirstLog = make(chan struct{})
	afterPass     = make(chan struct{})
)

func TestFast(t *testing.T) {
	t.Parallel()

	<-afterFirstLog
	t.Cleanup(func() {
		close(afterPass)
	})
}

func TestSlow(t *testing.T) {
	t.Parallel()

	t.Logf("this is the first TestSlow log")
	close(afterFirstLog)

	<-afterPass
	time.Sleep(100 * time.Millisecond)
	t.Logf("this is the second TestSlow log")
}