release.bash: add support for building release binaries

Updates golang/protobuf#738

Change-Id: I6dd85ff0129bfcfb67b12b06549c568eebfd68e3
Reviewed-on: https://go-review.googlesource.com/c/protobuf/+/189342
Reviewed-by: Damien Neil <dneil@google.com>
This commit is contained in:
Joe Tsai 2019-08-07 19:33:51 -07:00
parent 769cbd0041
commit 4f3de44102
3 changed files with 64 additions and 20 deletions

15
.gitignore vendored
View File

@ -1,10 +1,11 @@
.cache
.gocache
vendor
cmd/protoc-gen-go/protoc-gen-go
cmd/protoc-gen-go/testdata/go.sum
cmd/protoc-gen-go-grpc/protoc-gen-go-grpc
cmd/protoc-gen-go-grpc/testdata/go.sum
/.cache
/.gocache
/bin
/cmd/protoc-gen-go/protoc-gen-go
/cmd/protoc-gen-go/testdata/go.sum
/cmd/protoc-gen-go-grpc/protoc-gen-go-grpc
/cmd/protoc-gen-go-grpc/testdata/go.sum
/vendor
# This file includes artifacts of the system test that should not be checked in.
# For files created by specific development environment (e.g. editor),

View File

@ -25,10 +25,13 @@ import (
"sync"
"testing"
"time"
"google.golang.org/protobuf/runtime/protoimpl"
)
var (
regenerate = flag.Bool("regenerate", false, "regenerate files")
regenerate = flag.Bool("regenerate", false, "regenerate files")
buildRelease = flag.Bool("buildRelease", false, "build release binaries")
protobufVersion = "3.9.1"
golangVersions = []string{"1.9.7", "1.10.8", "1.11.13", "1.12.9"}
@ -45,16 +48,7 @@ var (
func Test(t *testing.T) {
mustInitDeps(t)
if *regenerate {
t.Run("Generate", func(t *testing.T) {
fmt.Print(mustRunCommand(t, "go", "run", "-tags", "protolegacy", "./internal/cmd/generate-types", "-execute"))
fmt.Print(mustRunCommand(t, "go", "run", "-tags", "protolegacy", "./internal/cmd/generate-protos", "-execute"))
files := strings.Split(strings.TrimSpace(mustRunCommand(t, "git", "ls-files", "*.go")), "\n")
mustRunCommand(t, append([]string{"gofmt", "-w"}, files...)...)
})
t.SkipNow()
}
mustHandleFlags(t)
var wg sync.WaitGroup
sema := make(chan bool, (runtime.NumCPU()+1)/2)
@ -382,6 +376,55 @@ func patchProtos(check func(error), repoRoot string) {
}
}
func mustHandleFlags(t *testing.T) {
if *regenerate {
t.Run("Generate", func(t *testing.T) {
fmt.Print(mustRunCommand(t, "go", "run", "-tags", "protolegacy", "./internal/cmd/generate-types", "-execute"))
fmt.Print(mustRunCommand(t, "go", "run", "-tags", "protolegacy", "./internal/cmd/generate-protos", "-execute"))
files := strings.Split(strings.TrimSpace(mustRunCommand(t, "git", "ls-files", "*.go")), "\n")
mustRunCommand(t, append([]string{"gofmt", "-w"}, files...)...)
})
}
if *buildRelease {
t.Run("BuildRelease", func(t *testing.T) {
v := protoimpl.VersionString()
for _, goos := range []string{"linux", "darwin", "windows"} {
for _, goarch := range []string{"386", "amd64"} {
binPath := filepath.Join("bin", fmt.Sprintf("protoc-gen-go.%v.%v.%v", v, goos, goarch))
// Build the binary.
cmd := command{Env: append(os.Environ(), "GOOS="+goos, "GOARCH="+goarch)}
cmd.mustRun(t, "go", "build", "-trimpath", "-ldflags", "-s -w", "-o", binPath, "./cmd/protoc-gen-go")
// Archive and compress the binary.
in, err := ioutil.ReadFile(binPath)
if err != nil {
t.Fatal(err)
}
out := new(bytes.Buffer)
gz, _ := gzip.NewWriterLevel(out, gzip.BestCompression)
gz.Comment = fmt.Sprintf("protoc-gen-go VERSION=%v GOOS=%v GOARCH=%v", v, goos, goarch)
tw := tar.NewWriter(gz)
tw.WriteHeader(&tar.Header{
Name: "protoc-gen-go",
Mode: int64(0775),
Size: int64(len(in)),
})
tw.Write(in)
tw.Close()
gz.Close()
if err := ioutil.WriteFile(binPath+".tar.gz", out.Bytes(), 0664); err != nil {
t.Fatal(err)
}
}
}
})
}
if *regenerate || *buildRelease {
t.SkipNow()
}
}
type command struct {
Dir string
Env []string

View File

@ -74,8 +74,8 @@ if ! [[ -z $MIN_VERSION ]]; then
fi
git commit -a -m "all: release $(version_string)"
# TODO: Build release binaries.
# go test -mod=vendor -timeout=60m -count=1 integration_test.go "$@" -buildRelease
# Build release binaries.
go test -mod=vendor -timeout=60m -count=1 integration_test.go "$@" -buildRelease
# Create commit to start development after release.
VERSION_PRERELEASE="${VERSION_PRERELEASE}.devel" # append ".devel"