summaryrefslogtreecommitdiffstats
path: root/src/cmd/go/testdata/script/test_json_exit.txt
blob: dc7ffb06cfc83b7d7742a5b48d0774e753893fee (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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
[short] skip

go test -c -o mainpanic.exe ./mainpanic &
go test -c -o mainexit0.exe ./mainexit0 &
go test -c -o testpanic.exe ./testpanic &
go test -c -o testbgpanic.exe ./testbgpanic &
wait

# Test binaries that panic in TestMain should be marked as failing.

! go test -json ./mainpanic
stdout '"Action":"fail"'
! stdout '"Action":"pass"'

! go tool test2json ./mainpanic.exe
stdout '"Action":"fail"'
! stdout '"Action":"pass"'

# Test binaries that exit with status 0 should be marked as passing.

go test -json ./mainexit0
stdout '"Action":"pass"'
! stdout '"Action":"fail"'

go tool test2json ./mainexit0.exe
stdout '"Action":"pass"'
! stdout '"Action":"fail"'

# Test functions that panic should never be marked as passing
# (https://golang.org/issue/40132).

! go test -json ./testpanic
stdout '"Action":"fail"'
! stdout '"Action":"pass"'

! go tool test2json ./testpanic.exe -test.v
stdout '"Action":"fail"'
! stdout '"Action":"pass"'

! go tool test2json ./testpanic.exe
stdout '"Action":"fail"'
! stdout '"Action":"pass"'

# Tests that panic in a background goroutine should be marked as failing.

! go test -json ./testbgpanic
stdout '"Action":"fail"'
! stdout '"Action":"pass"'

! go tool test2json ./testbgpanic.exe -test.v
stdout '"Action":"fail"'
! stdout '"Action":"pass"'

! go tool test2json ./testbgpanic.exe
stdout '"Action":"fail"'
! stdout '"Action":"pass"'

-- go.mod --
module m
go 1.14
-- mainpanic/mainpanic_test.go --
package mainpanic_test

import "testing"

func TestMain(m *testing.M) {
	panic("haha no")
}
-- mainexit0/mainexit0_test.go --
package mainexit0_test

import (
	"fmt"
	"os"
	"testing"
)

func TestMain(m *testing.M) {
	fmt.Println("nothing to do")
	os.Exit(0)
}
-- testpanic/testpanic_test.go --
package testpanic_test

import "testing"

func TestPanic(*testing.T) {
	panic("haha no")
}
-- testbgpanic/testbgpanic_test.go --
package testbgpanic_test

import "testing"

func TestPanicInBackground(*testing.T) {
	c := make(chan struct{})
	go func() {
		panic("haha no")
		close(c)
	}()
	<-c
}