Use Makefile.common from Prometheus
authorSimon Pasquier <spasquie@redhat.com>
Tue, 22 May 2018 09:44:41 +0000 (11:44 +0200)
committerBrian Brazil <brian.brazil@robustperception.io>
Tue, 22 May 2018 20:09:55 +0000 (21:09 +0100)
Signed-off-by: Simon Pasquier <spasquie@redhat.com>
Makefile
Makefile.common [new file with mode: 0644]

index dedf8069a3bd8e16801fe26233b9bb57bf363629..6012f30162f21519ed6142d9401f3a18cab5cf17 100644 (file)
--- a/Makefile
+++ b/Makefile
 # See the License for the specific language governing permissions and
 # limitations under the License.
 
-GO           := GO15VENDOREXPERIMENT=1 go
-FIRST_GOPATH := $(firstword $(subst :, ,$(shell $(GO) env GOPATH)))
-PROMU        := $(FIRST_GOPATH)/bin/promu
-STATICCHECK  := $(FIRST_GOPATH)/bin/staticcheck
-pkgs         = $(shell $(GO) list ./... | grep -v /vendor/)
+include Makefile.common
 
-PREFIX                  ?= $(shell pwd)
-BIN_DIR                 ?= $(shell pwd)
 DOCKER_IMAGE_NAME       ?= blackbox-exporter
-DOCKER_IMAGE_TAG        ?= $(subst /,-,$(shell git rev-parse --abbrev-ref HEAD))
-
-
-all: format vet staticcheck build test
-
-style:
-       @echo ">> checking code style"
-       @! gofmt -d $(shell find . -path ./vendor -prune -o -name '*.go' -print) | grep '^'
-
-test:
-       @echo ">> running tests"
-       @$(GO) test -short $(pkgs)
-
-format:
-       @echo ">> formatting code"
-       @$(GO) fmt $(pkgs)
-
-vet:
-       @echo ">> vetting code"
-       @$(GO) vet $(pkgs)
-
-staticcheck: $(STATICCHECK)
-       @echo ">> running staticcheck"
-       @$(STATICCHECK) $(pkgs)
-
-build: $(PROMU)
-       @echo ">> building binaries"
-       @$(PROMU) build --prefix $(PREFIX)
-
-tarball: $(PROMU)
-       @echo ">> building release tarball"
-       @$(PROMU) tarball --prefix $(PREFIX) $(BIN_DIR)
-
-docker:
-       @echo ">> building docker image"
-       @docker build -t "$(DOCKER_IMAGE_NAME):$(DOCKER_IMAGE_TAG)" .
-
-$(FIRST_GOPATH)/bin/promu promu:
-       @GOOS= GOARCH= $(GO) get -u github.com/prometheus/promu
-
-$(FIRST_GOPATH)/bin/staticcheck:
-       @GOOS= GOARCH= $(GO) get -u honnef.co/go/tools/cmd/staticcheck
-
-.PHONY: all style format build test vet tarball docker promu staticcheck $(FIRST_GOPATH)/bin/promu $(FIRST_GOPATH)/bin/staticcheck
diff --git a/Makefile.common b/Makefile.common
new file mode 100644 (file)
index 0000000..353494c
--- /dev/null
@@ -0,0 +1,100 @@
+# Copyright 2018 The Prometheus Authors
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+
+# A common Makefile that includes rules to be reused in different prometheus projects.
+# !!! Open PRs only against the prometheus/prometheus/Makefile.common repository!
+
+# Example usage :
+# Create the main Makefile in the root project directory. 
+# include Makefile.common
+# customTarget:
+#      @echo ">> Running customTarget"
+#
+
+# Ensure GOBIN is not set during build so that promu is installed to the correct path
+unexport GOBIN
+
+GO           ?= go
+GOFMT        ?= $(GO)fmt
+FIRST_GOPATH := $(firstword $(subst :, ,$(shell $(GO) env GOPATH)))
+PROMU        := $(FIRST_GOPATH)/bin/promu
+STATICCHECK  := $(FIRST_GOPATH)/bin/staticcheck
+GOVENDOR     := $(FIRST_GOPATH)/bin/govendor
+pkgs          = ./...
+
+PREFIX                  ?= $(shell pwd)
+BIN_DIR                 ?= $(shell pwd)
+DOCKER_IMAGE_TAG        ?= $(subst /,-,$(shell git rev-parse --abbrev-ref HEAD))
+
+all: style staticcheck unused build test
+
+style:
+       @echo ">> checking code style"
+       ! $(GOFMT) -d $$(find . -path ./vendor -prune -o -name '*.go' -print) | grep '^'
+
+check_license:
+       @echo ">> checking license header"
+       @licRes=$$(for file in $$(find . -type f -iname '*.go' ! -path './vendor/*') ; do \
+               awk 'NR<=3' $$file | grep -Eq "(Copyright|generated|GENERATED)" || echo $$file; \
+       done); \
+       if [ -n "$${licRes}" ]; then \
+               echo "license header checking failed:"; echo "$${licRes}"; \
+               exit 1; \
+       fi
+
+test-short:
+       @echo ">> running short tests"
+       $(GO) test -short $(pkgs)
+
+test:
+       @echo ">> running all tests"
+       $(GO) test -race $(pkgs)
+
+format:
+       @echo ">> formatting code"
+       $(GO) fmt $(pkgs)
+
+vet:
+       @echo ">> vetting code"
+       $(GO) vet $(pkgs)
+
+staticcheck: $(STATICCHECK)
+       @echo ">> running staticcheck"
+       $(STATICCHECK) -ignore "$(STATICCHECK_IGNORE)" $(pkgs)
+
+unused: $(GOVENDOR)
+       @echo ">> running check for unused packages"
+       @$(GOVENDOR) list +unused | grep . && exit 1 || echo 'No unused packages'
+
+build: promu
+       @echo ">> building binaries"
+       $(PROMU) build --prefix $(PREFIX)
+
+tarball: promu
+       @echo ">> building release tarball"
+       $(PROMU) tarball --prefix $(PREFIX) $(BIN_DIR)
+
+docker:
+       docker build -t "$(DOCKER_IMAGE_NAME):$(DOCKER_IMAGE_TAG)" .
+
+promu:
+       GOOS= GOARCH= $(GO) get -u github.com/prometheus/promu
+
+$(FIRST_GOPATH)/bin/staticcheck:
+       GOOS= GOARCH= $(GO) get -u honnef.co/go/tools/cmd/staticcheck
+
+$(FIRST_GOPATH)/bin/govendor:
+       GOOS= GOARCH= $(GO) get -u github.com/kardianos/govendor
+
+.PHONY: all style check_license format build test vet assets tarball docker promu staticcheck $(FIRST_GOPATH)/bin/staticcheck govendor $(FIRST_GOPATH)/bin/govendor
\ No newline at end of file