31082eed27
It's not clear that the best way to manage clients is through a gRPC based command line tool. For example we may explore an admin dashboard and enable bootstrapping through static clients. For now use static clients while we hold off on a more concrete proposal.
56 lines
1.1 KiB
Makefile
56 lines
1.1 KiB
Makefile
PROJ="poke"
|
|
ORG_PATH="github.com/coreos"
|
|
REPO_PATH="$(ORG_PATH)/$(PROJ)"
|
|
export PATH := $(PWD)/bin:$(PATH)
|
|
|
|
export GOBIN=$(PWD)/bin
|
|
export GO15VENDOREXPERIMENT=1
|
|
|
|
GOOS=$(shell go env GOOS)
|
|
GOARCH=$(shell go env GOARCH)
|
|
|
|
COMMIT=$(shell git rev-parse HEAD)
|
|
|
|
# check if the current commit has a matching tag
|
|
TAG=$(shell git describe --exact-match --abbrev=0 --tags $(COMMIT) 2> /dev/null || true)
|
|
|
|
ifeq ($(TAG),)
|
|
VERSION=$(TAG)
|
|
else
|
|
VERSION=$(COMMIT)
|
|
endif
|
|
|
|
|
|
build: bin/poke bin/pokectl
|
|
|
|
bin/poke: FORCE
|
|
@go install $(REPO_PATH)/cmd/poke
|
|
|
|
bin/pokectl: FORCE
|
|
@go install $(REPO_PATH)/cmd/pokectl
|
|
|
|
test:
|
|
@go test $(shell go list ./... | grep -v '/vendor/')
|
|
|
|
testrace:
|
|
@go test --race $(shell go list ./... | grep -v '/vendor/')
|
|
|
|
vet:
|
|
@go vet $(shell go list ./... | grep -v '/vendor/')
|
|
|
|
fmt:
|
|
@go fmt $(shell go list ./... | grep -v '/vendor/')
|
|
|
|
lint:
|
|
@for package in $(shell go list ./... | grep -v '/vendor/' | grep -v 'api/apipb'); do \
|
|
golint $$package; \
|
|
done
|
|
|
|
clean:
|
|
@rm bin/*
|
|
|
|
testall: testrace vet fmt lint
|
|
|
|
FORCE:
|
|
|
|
.PHONY: test testrace vet fmt lint testall
|