1
0
mirror of https://github.com/golang/go synced 2024-11-17 16:14:42 -07:00

cmd/go: add generated code comment to _testmain.go template

Fixes #31971

Change-Id: I127659be145e348fae20930615666d67dc7971ef
Reviewed-on: https://go-review.googlesource.com/c/go/+/176468
Run-TryBot: Jay Conrod <jayconrod@google.com>
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
This commit is contained in:
Jay Conrod 2019-05-10 16:57:22 -04:00
parent 49a1a01bb1
commit 309ab1ecc8
2 changed files with 37 additions and 0 deletions

View File

@ -641,6 +641,8 @@ var _ = func() bool {
`) `)
var testmainTmpl = lazytemplate.New("main", ` var testmainTmpl = lazytemplate.New("main", `
// Code generated by 'go test'. DO NOT EDIT.
package main package main
import ( import (

View File

@ -0,0 +1,35 @@
# Tests that the generated test main file has a generated code comment.
# This is needed by analyzers that access source files through 'go list'.
# Verifies golang.org/issue/31971.
# TODO(jayconrod): This test is brittle. We should write _testmain.go as
# a build action instead of with an ad-hoc WriteFile call
# in internal/test/test.go. Then we could just grep 'go get -n'.
go test x_test.go
-- x_test.go --
package x
import (
"os"
"path/filepath"
"io/ioutil"
"regexp"
"testing"
)
func Test(t *testing.T) {
exePath, err := os.Executable()
if err != nil {
t.Fatal(err)
}
testmainPath := filepath.Join(filepath.Dir(exePath), "_testmain.go")
source, err := ioutil.ReadFile(testmainPath)
if err != nil {
t.Fatal(err)
}
if matched, err := regexp.Match(`(?m)^// Code generated .* DO NOT EDIT\.$`, source); err != nil {
t.Fatal(err)
} else if !matched {
t.Error("_testmain.go does not have generated code comment")
}
}