mirror of
https://github.com/golang/go
synced 2024-11-17 14:04:48 -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:
parent
49a1a01bb1
commit
309ab1ecc8
@ -641,6 +641,8 @@ var _ = func() bool {
|
||||
`)
|
||||
|
||||
var testmainTmpl = lazytemplate.New("main", `
|
||||
// Code generated by 'go test'. DO NOT EDIT.
|
||||
|
||||
package main
|
||||
|
||||
import (
|
||||
|
35
src/cmd/go/testdata/script/test_generated_main.txt
vendored
Normal file
35
src/cmd/go/testdata/script/test_generated_main.txt
vendored
Normal 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")
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user