diff --git a/.travis.yml b/.travis.yml index aa214be8bc..fb29df5f6f 100644 --- a/.travis.yml +++ b/.travis.yml @@ -7,7 +7,7 @@ services: - docker go: - - 1.9 + - 1.9.1 matrix: allow_failures: diff --git a/Makefile b/Makefile index 68c9543eec..8aa19d1712 100644 --- a/Makefile +++ b/Makefile @@ -7,6 +7,8 @@ EXTERNAL_TOOLS=\ BUILD_TAGS?=vault GOFMT_FILES?=$$(find . -name '*.go' | grep -v vendor) +GO_VERSION_MIN=1.9.1 + default: dev # bin generates the releaseable binaries for Vault @@ -61,6 +63,7 @@ vet: # prep runs `go generate` to build the dynamically generated # source files. prep: + @sh -c "'$(CURDIR)/scripts/goversioncheck.sh' '$(GO_VERSION_MIN)'" go generate $(go list ./... | grep -v /vendor/) cp .hooks/* .git/hooks/ diff --git a/scripts/goversioncheck.sh b/scripts/goversioncheck.sh new file mode 100755 index 0000000000..083998e1d5 --- /dev/null +++ b/scripts/goversioncheck.sh @@ -0,0 +1,19 @@ +#!/usr/bin/env bash + +GO_VERSION_MIN=$1 +echo "==> Checking that build is using go version >= $1..." + +GO_VERSION=$(go version | grep -o 'go[0-9]\+\.[0-9]\+\(\.[0-9]\+\)\?' | tr -d 'go') + + +IFS="." read -r -a GO_VERSION_ARR <<< "$GO_VERSION" +IFS="." read -r -a GO_VERSION_REQ <<< "$GO_VERSION_MIN" + +if [[ ${GO_VERSION_ARR[0]} -lt ${GO_VERSION_REQ[0]} || + ( ${GO_VERSION_ARR[0]} -eq ${GO_VERSION_REQ[0]} && + ( ${GO_VERSION_ARR[1]} -lt ${GO_VERSION_REQ[1]} || + ( ${GO_VERSION_ARR[1]} -eq ${GO_VERSION_REQ[1]} && ${GO_VERSION_ARR[2]} -lt ${GO_VERSION_REQ[2]} ))) + ]]; then + echo "Vault requires go $GO_VERSION_MIN to build; found $GO_VERSION." + exit 1 +fi