From d6eeb94e30717fdeef4a606a6524e9b0a34c803a Mon Sep 17 00:00:00 2001 From: Matt Schallert Date: Wed, 29 May 2019 00:52:20 -0400 Subject: [PATCH] [ci] build + release with go1.12 (again) --- .buildkite/pipeline.yml | 4 ++-- .ci | 2 +- Makefile | 26 ++++++++++++++------------ docker-compose.yml | 2 +- docker/m3aggregator/Dockerfile | 2 +- docker/m3collector/Dockerfile | 2 +- docker/m3coordinator/Dockerfile | 2 +- docker/m3dbnode/Dockerfile | 4 ++-- docker/m3nsch/Dockerfile | 2 +- docker/m3query/Dockerfile | 2 +- scripts/thriftgen.Dockerfile | 2 +- src/query/util/logging/log_test.go | 6 ++++-- 12 files changed, 30 insertions(+), 26 deletions(-) diff --git a/.buildkite/pipeline.yml b/.buildkite/pipeline.yml index 9c9b951c96..b335bab3fd 100644 --- a/.buildkite/pipeline.yml +++ b/.buildkite/pipeline.yml @@ -14,7 +14,7 @@ steps: command: make clean install-vendor test-all-gen env: CGO_ENABLED: 0 - GIMME_GO_VERSION: 1.10.x + GIMME_GO_VERSION: 1.12.x plugins: gopath-checkout#v1.0.1: import: github.com/m3db/m3 @@ -46,7 +46,7 @@ steps: command: make clean install-vendor docker-integration-test env: CGO_ENABLED: 0 - GIMME_GO_VERSION: 1.10.x + GIMME_GO_VERSION: 1.12.x plugins: gopath-checkout#v1.0.1: import: github.com/m3db/m3 diff --git a/.ci b/.ci index 4cb3c72388..5ebad82378 160000 --- a/.ci +++ b/.ci @@ -1 +1 @@ -Subproject commit 4cb3c723883e69b50f1f259de1d2f5c4576ec186 +Subproject commit 5ebad82378721413910c5a450953db8274c028b3 diff --git a/Makefile b/Makefile index 9d067c58ec..994450d753 100644 --- a/Makefile +++ b/Makefile @@ -7,6 +7,7 @@ $(SELF_DIR)/.ci/common.mk: include $(SELF_DIR)/.ci/common.mk SHELL=/bin/bash -o pipefail +GOPATH=$(shell eval $$(go env | grep GOPATH) && echo $$GOPATH) auto_gen := scripts/auto-gen.sh process_coverfile := scripts/process-cover.sh @@ -16,6 +17,7 @@ m3_package := github.com/m3db/m3 m3_package_path := $(gopath_prefix)/$(m3_package) mockgen_package := github.com/golang/mock/mockgen retool_bin_path := $(m3_package_path)/_tools/bin +combined_bin_paths := $(retool_bin_path):$(gopath_bin_path) retool_src_prefix := $(m3_package_path)/_tools/src retool_package := github.com/twitchtv/retool metalint_check := .ci/metalint.sh @@ -267,7 +269,7 @@ ifeq ($(SUBDIR), kube) all-gen-kube: install-tools @echo "--- Generating kube bundle" @./kube/scripts/build_bundle.sh - find kube -name '*.yaml' -print0 | PATH=$(retool_bin_path):$(PATH) xargs -0 kubeval -v=1.12.0 + find kube -name '*.yaml' -print0 | PATH=$(combined_bin_paths):$(PATH) xargs -0 kubeval -v=1.12.0 else @@ -275,37 +277,37 @@ else mock-gen-$(SUBDIR): install-tools @echo "--- Generating mocks $(SUBDIR)" @[ ! -d src/$(SUBDIR)/$(mocks_rules_dir) ] || \ - PATH=$(retool_bin_path):$(PATH) PACKAGE=$(m3_package) $(auto_gen) src/$(SUBDIR)/$(mocks_output_dir) src/$(SUBDIR)/$(mocks_rules_dir) + PATH=$(combined_bin_paths):$(PATH) PACKAGE=$(m3_package) $(auto_gen) src/$(SUBDIR)/$(mocks_output_dir) src/$(SUBDIR)/$(mocks_rules_dir) .PHONY: thrift-gen-$(SUBDIR) thrift-gen-$(SUBDIR): install-tools @echo "--- Generating thrift files $(SUBDIR)" @[ ! -d src/$(SUBDIR)/$(thrift_rules_dir) ] || \ - PATH=$(retool_bin_path):$(PATH) PACKAGE=$(m3_package) $(auto_gen) src/$(SUBDIR)/$(thrift_output_dir) src/$(SUBDIR)/$(thrift_rules_dir) + PATH=$(combined_bin_paths):$(PATH) PACKAGE=$(m3_package) $(auto_gen) src/$(SUBDIR)/$(thrift_output_dir) src/$(SUBDIR)/$(thrift_rules_dir) .PHONY: proto-gen-$(SUBDIR) proto-gen-$(SUBDIR): install-tools @echo "--- Generating protobuf files $(SUBDIR)" @[ ! -d src/$(SUBDIR)/$(proto_rules_dir) ] || \ - PATH=$(retool_bin_path):$(PATH) PACKAGE=$(m3_package) $(auto_gen) src/$(SUBDIR)/$(proto_output_dir) src/$(SUBDIR)/$(proto_rules_dir) + PATH=$(combined_bin_paths):$(PATH) PACKAGE=$(m3_package) $(auto_gen) src/$(SUBDIR)/$(proto_output_dir) src/$(SUBDIR)/$(proto_rules_dir) .PHONY: asset-gen-$(SUBDIR) asset-gen-$(SUBDIR): install-tools @echo "--- Generating asset files $(SUBDIR)" @[ ! -d src/$(SUBDIR)/$(assets_rules_dir) ] || \ - PATH=$(retool_bin_path):$(PATH) PACKAGE=$(m3_package) $(auto_gen) src/$(SUBDIR)/$(assets_output_dir) src/$(SUBDIR)/$(assets_rules_dir) + PATH=$(combined_bin_paths):$(PATH) PACKAGE=$(m3_package) $(auto_gen) src/$(SUBDIR)/$(assets_output_dir) src/$(SUBDIR)/$(assets_rules_dir) .PHONY: genny-gen-$(SUBDIR) genny-gen-$(SUBDIR): install-tools @echo "--- Generating genny files $(SUBDIR)" @[ ! -f $(SELF_DIR)/src/$(SUBDIR)/generated-source-files.mk ] || \ - PATH=$(retool_bin_path):$(PATH) make -f $(SELF_DIR)/src/$(SUBDIR)/generated-source-files.mk genny-all - @PATH=$(retool_bin_path):$(PATH) bash -c "source ./scripts/auto-gen-helpers.sh && gen_cleanup_dir '*_gen.go' $(SELF_DIR)/src/$(SUBDIR)/ && gen_cleanup_dir '*_gen_test.go' $(SELF_DIR)/src/$(SUBDIR)/" + PATH=$(combined_bin_paths):$(PATH) make -f $(SELF_DIR)/src/$(SUBDIR)/generated-source-files.mk genny-all + @PATH=$(combined_bin_paths):$(PATH) bash -c "source ./scripts/auto-gen-helpers.sh && gen_cleanup_dir '*_gen.go' $(SELF_DIR)/src/$(SUBDIR)/ && gen_cleanup_dir '*_gen_test.go' $(SELF_DIR)/src/$(SUBDIR)/" .PHONY: license-gen-$(SUBDIR) license-gen-$(SUBDIR): install-tools @echo "--- Updating license in files $(SUBDIR)" - @find $(SELF_DIR)/src/$(SUBDIR) -name '*.go' | PATH=$(retool_bin_path):$(PATH) xargs -I{} update-license {} + @find $(SELF_DIR)/src/$(SUBDIR) -name '*.go' | PATH=$(combined_bin_paths):$(PATH) xargs -I{} update-license {} .PHONY: all-gen-$(SUBDIR) # NB(prateek): order matters here, mock-gen needs to be after proto/thrift because we sometimes @@ -363,7 +365,7 @@ test-ci-integration-$(SUBDIR): .PHONY: metalint-$(SUBDIR) metalint-$(SUBDIR): install-gometalinter install-linter-badtime install-linter-importorder @echo "--- metalinting $(SUBDIR)" - @(PATH=$(retool_bin_path):$(PATH) $(metalint_check) \ + @(PATH=$(combined_bin_paths):$(PATH) $(metalint_check) \ $(metalint_config) $(metalint_exclude) src/$(SUBDIR)) endif @@ -436,7 +438,7 @@ endif metalint: install-gometalinter install-linter-badtime install-linter-importorder @echo "--- metalinting src/" @(PATH=$(retool_bin_path):$(PATH) $(metalint_check) \ - $(metalint_config) $(metalint_exclude) src/) + $(metalint_config) $(metalint_exclude) $(m3_package_path)/src/) # Tests that all currently generated types match their contents if they were regenerated .PHONY: test-all-gen @@ -447,12 +449,12 @@ test-all-gen: all-gen # Runs a fossa license report .PHONY: fossa fossa: install-tools - PATH=$(retool_bin_path):$(PATH) fossa --option allow-nested-vendor:true --option allow-deep-vendor:true + PATH=$(combined_bin_paths):$(PATH) fossa --option allow-nested-vendor:true --option allow-deep-vendor:true # Waits for the result of a fossa test and exits success if pass or fail if fails .PHONY: fossa-test fossa-test: fossa - PATH=$(retool_bin_path):$(PATH) fossa test + PATH=$(combined_bin_paths):$(PATH) fossa test .PHONY: clean clean: diff --git a/docker-compose.yml b/docker-compose.yml index ee63f56624..6105403495 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -1,5 +1,5 @@ app: - image: golang:1.10.4-stretch + image: golang:1.12.1-stretch volumes: - .:/go/src/github.com/m3db/m3 - /usr/bin/buildkite-agent:/usr/bin/buildkite-agent diff --git a/docker/m3aggregator/Dockerfile b/docker/m3aggregator/Dockerfile index b4f2ad9828..38f8f55bdb 100644 --- a/docker/m3aggregator/Dockerfile +++ b/docker/m3aggregator/Dockerfile @@ -1,5 +1,5 @@ # stage 1: build -FROM golang:1.10-alpine AS builder +FROM golang:1.12-alpine AS builder LABEL maintainer="The M3DB Authors " # Install Glide diff --git a/docker/m3collector/Dockerfile b/docker/m3collector/Dockerfile index 44bc4b9663..88b3056bfc 100644 --- a/docker/m3collector/Dockerfile +++ b/docker/m3collector/Dockerfile @@ -1,5 +1,5 @@ # stage 1: build -FROM golang:1.10-alpine AS builder +FROM golang:1.12-alpine AS builder LABEL maintainer="The M3DB Authors " # Install Glide diff --git a/docker/m3coordinator/Dockerfile b/docker/m3coordinator/Dockerfile index d586d3dc07..1c500594be 100644 --- a/docker/m3coordinator/Dockerfile +++ b/docker/m3coordinator/Dockerfile @@ -1,5 +1,5 @@ # stage 1: build -FROM golang:1.10-alpine AS builder +FROM golang:1.12-alpine AS builder LABEL maintainer="The M3DB Authors " # Install Glide diff --git a/docker/m3dbnode/Dockerfile b/docker/m3dbnode/Dockerfile index 6a306910a7..24fd4d34b5 100644 --- a/docker/m3dbnode/Dockerfile +++ b/docker/m3dbnode/Dockerfile @@ -1,5 +1,5 @@ -# Stage 1: build -FROM golang:1.10-alpine AS builder +# stage 1: build +FROM golang:1.12-alpine AS builder LABEL maintainer="The M3DB Authors " # Install Glide diff --git a/docker/m3nsch/Dockerfile b/docker/m3nsch/Dockerfile index 3763a1e326..53c9a3fd47 100644 --- a/docker/m3nsch/Dockerfile +++ b/docker/m3nsch/Dockerfile @@ -1,5 +1,5 @@ # stage 1: build -FROM golang:1.10-alpine AS builder +FROM golang:1.12-alpine AS builder LABEL maintainer="The M3DB Authors " # Install Glide diff --git a/docker/m3query/Dockerfile b/docker/m3query/Dockerfile index 9d3d298a15..ee882d2373 100644 --- a/docker/m3query/Dockerfile +++ b/docker/m3query/Dockerfile @@ -1,5 +1,5 @@ # stage 1: build -FROM golang:1.10-alpine AS builder +FROM golang:1.12-alpine AS builder LABEL maintainer="The M3DB Authors " # Install Glide diff --git a/scripts/thriftgen.Dockerfile b/scripts/thriftgen.Dockerfile index a914385050..b15cb238e5 100644 --- a/scripts/thriftgen.Dockerfile +++ b/scripts/thriftgen.Dockerfile @@ -1,7 +1,7 @@ # built artifacts maintained externally at https://quay.io/repository/m3db/thrift-gen # stage 1: build thrift-gen binary -FROM golang:1.10-alpine AS thriftgen +FROM golang:1.12-alpine AS thriftgen LABEL maintainer="The M3DB Authors " # install git diff --git a/src/query/util/logging/log_test.go b/src/query/util/logging/log_test.go index 4122bf0448..d86cd185ba 100644 --- a/src/query/util/logging/log_test.go +++ b/src/query/util/logging/log_test.go @@ -140,7 +140,7 @@ func TestPanicErrorResponder(t *testing.T) { } } - assert.Equal(t, 4, count) + assert.Equal(t, 3, count) // `log_test` should appear in the output twice, once for the call in the // deadbeef method, and once for the ServeHttp call. @@ -187,7 +187,7 @@ func assertPanicLogsWritten(t *testing.T, stdout, stderr *os.File) { } } - assert.Equal(t, 5, count) + assert.Equal(t, 4, count) // `log_test` should appear in the output twice, once for the call in the // deadbeef method, and once for the ServeHttp call. @@ -197,6 +197,8 @@ func assertPanicLogsWritten(t *testing.T, stdout, stderr *os.File) { count++ } } + + assert.Equal(t, 2, count) } func TestPanicErrorResponderOnlyIfNotWrittenRequest(t *testing.T) {