build: Add option to get test coverage (#5539)

This commit is contained in:
Simon Frei 2019-02-14 23:38:47 +01:00 committed by Audrius Butkevicius
parent d5ff2c41dc
commit e2204d0071
2 changed files with 18 additions and 9 deletions

5
.codecov.yml Normal file
View File

@ -0,0 +1,5 @@
coverage:
range: "40...100"
ignore:
- "**.pb.go"

View File

@ -48,6 +48,7 @@ var (
pkgdir string pkgdir string
cc string cc string
debugBinary bool debugBinary bool
coverage bool
timeout = "120s" timeout = "120s"
gogoProtoVersion = "v1.2.0" gogoProtoVersion = "v1.2.0"
) )
@ -330,24 +331,27 @@ func parseFlags() {
flag.StringVar(&pkgdir, "pkgdir", "", "Set -pkgdir parameter for `go build`") flag.StringVar(&pkgdir, "pkgdir", "", "Set -pkgdir parameter for `go build`")
flag.StringVar(&cc, "cc", os.Getenv("CC"), "Set CC environment variable for `go build`") flag.StringVar(&cc, "cc", os.Getenv("CC"), "Set CC environment variable for `go build`")
flag.BoolVar(&debugBinary, "debug-binary", debugBinary, "Create unoptimized binary to use with delve, set -gcflags='-N -l' and omit -ldflags") flag.BoolVar(&debugBinary, "debug-binary", debugBinary, "Create unoptimized binary to use with delve, set -gcflags='-N -l' and omit -ldflags")
flag.BoolVar(&coverage, "coverage", coverage, "Write coverage profile of tests to coverage.txt")
flag.Parse() flag.Parse()
} }
func test(pkgs ...string) { func test(pkgs ...string) {
lazyRebuildAssets() lazyRebuildAssets()
useRace := runtime.GOARCH == "amd64" args := []string{"test", "-short", "-timeout", timeout, "-tags", "purego"}
if runtime.GOARCH == "amd64" {
switch runtime.GOOS { switch runtime.GOOS {
case "darwin", "linux", "freebsd": // , "windows": # See https://github.com/golang/go/issues/27089 case "darwin", "linux", "freebsd": // , "windows": # See https://github.com/golang/go/issues/27089
default: args = append(args, "-race")
useRace = false }
} }
if useRace { if coverage {
runPrint(goCmd, append([]string{"test", "-short", "-race", "-timeout", timeout, "-tags", "purego"}, pkgs...)...) args = append(args, "-covermode", "atomic", "-coverprofile", "coverage.txt")
} else {
runPrint(goCmd, append([]string{"test", "-short", "-timeout", timeout, "-tags", "purego"}, pkgs...)...)
} }
runPrint(goCmd, append(args, pkgs...)...)
} }
func bench(pkgs ...string) { func bench(pkgs ...string) {