TEST?=./... VETARGS?=-asmdecl -atomic -bool -buildtags -copylocks -methods -nilfunc -printf -rangeloops -shift -structtags -unsafeptr EXTERNAL_TOOLS=\ github.com/tools/godep \ github.com/mitchellh/gox \ golang.org/x/tools/cmd/cover \ golang.org/x/tools/cmd/vet default: test # bin generates the releaseable binaries for Vault bin: generate @sh -c "'$(CURDIR)/scripts/build.sh'" # dev creates binaries for testing Vault locally. These are put # into ./bin/ as well as $GOPATH/bin dev: generate @TF_DEV=1 sh -c "'$(CURDIR)/scripts/build.sh'" # test runs the unit tests and vets the code test: generate VAULT_TOKEN= TF_ACC= godep go test $(TEST) $(TESTARGS) -timeout=60s -parallel=4 # testacc runs acceptance tests testacc: generate @if [ "$(TEST)" = "./..." ]; then \ echo "ERROR: Set TEST to a specific package"; \ exit 1; \ fi TF_ACC=1 godep go test $(TEST) -v $(TESTARGS) -timeout 45m # testrace runs the race checker testrace: generate CGO_ENABLED=1 VAULT_TOKEN= TF_ACC= godep go test -race $(TEST) $(TESTARGS) cover: ./scripts/coverage.sh --html # vet runs the Go source code static analysis tool `vet` to find # any common errors. vet: @go list -f '{{.Dir}}' ./... \ | grep -v '.*github.com/hashicorp/vault$$' \ | xargs go tool vet ; if [ $$? -eq 1 ]; then \ echo ""; \ echo "Vet found suspicious constructs. Please check the reported constructs"; \ echo "and fix them if necessary before submitting the code for reviewal."; \ fi # generate runs `go generate` to build the dynamically generated # source files. generate: go generate ./... # bootstrap the build by downloading additional tools bootstrap: @for tool in $(EXTERNAL_TOOLS) ; do \ echo "Installing $$tool" ; \ go get $$tool; \ done .PHONY: bin default generate test vet bootstrap