|
@@ -1,7 +1,9 @@
|
|
|
|
|
+GO ?= go
|
|
|
GOFMT ?= gofmt "-s"
|
|
GOFMT ?= gofmt "-s"
|
|
|
-PACKAGES ?= $(shell go list ./... | grep -v /vendor/)
|
|
|
|
|
-VETPACKAGES ?= $(shell go list ./... | grep -v /vendor/ | grep -v /examples/)
|
|
|
|
|
|
|
+PACKAGES ?= $(shell $(GO) list ./... | grep -v /vendor/)
|
|
|
|
|
+VETPACKAGES ?= $(shell $(GO) list ./... | grep -v /vendor/ | grep -v /examples/)
|
|
|
GOFILES := $(shell find . -name "*.go" -type f -not -path "./vendor/*")
|
|
GOFILES := $(shell find . -name "*.go" -type f -not -path "./vendor/*")
|
|
|
|
|
+TESTFOLDER := $(shell $(GO) list ./... | grep -E 'gin$$|binding$$|render$$' | grep -v examples)
|
|
|
|
|
|
|
|
all: install
|
|
all: install
|
|
|
|
|
|
|
@@ -10,7 +12,14 @@ install: deps
|
|
|
|
|
|
|
|
.PHONY: test
|
|
.PHONY: test
|
|
|
test:
|
|
test:
|
|
|
- sh coverage.sh
|
|
|
|
|
|
|
+ echo "mode: count" > coverage.out
|
|
|
|
|
+ for d in $(TESTFOLDER); do \
|
|
|
|
|
+ $(GO) test -v -covermode=count -coverprofile=profile.out $$d; \
|
|
|
|
|
+ if [ -f profile.out ]; then \
|
|
|
|
|
+ cat profile.out | grep -v "mode:" >> coverage.out; \
|
|
|
|
|
+ rm profile.out; \
|
|
|
|
|
+ fi; \
|
|
|
|
|
+ done
|
|
|
|
|
|
|
|
.PHONY: fmt
|
|
.PHONY: fmt
|
|
|
fmt:
|
|
fmt:
|
|
@@ -18,7 +27,6 @@ fmt:
|
|
|
|
|
|
|
|
.PHONY: fmt-check
|
|
.PHONY: fmt-check
|
|
|
fmt-check:
|
|
fmt-check:
|
|
|
- # get all go files and run go fmt on them
|
|
|
|
|
@diff=$$($(GOFMT) -d $(GOFILES)); \
|
|
@diff=$$($(GOFMT) -d $(GOFILES)); \
|
|
|
if [ -n "$$diff" ]; then \
|
|
if [ -n "$$diff" ]; then \
|
|
|
echo "Please run 'make fmt' and commit the result:"; \
|
|
echo "Please run 'make fmt' and commit the result:"; \
|
|
@@ -27,14 +35,14 @@ fmt-check:
|
|
|
fi;
|
|
fi;
|
|
|
|
|
|
|
|
vet:
|
|
vet:
|
|
|
- go vet $(VETPACKAGES)
|
|
|
|
|
|
|
+ $(GO) vet $(VETPACKAGES)
|
|
|
|
|
|
|
|
deps:
|
|
deps:
|
|
|
@hash govendor > /dev/null 2>&1; if [ $$? -ne 0 ]; then \
|
|
@hash govendor > /dev/null 2>&1; if [ $$? -ne 0 ]; then \
|
|
|
- go get -u github.com/kardianos/govendor; \
|
|
|
|
|
|
|
+ $(GO) get -u github.com/kardianos/govendor; \
|
|
|
fi
|
|
fi
|
|
|
@hash embedmd > /dev/null 2>&1; if [ $$? -ne 0 ]; then \
|
|
@hash embedmd > /dev/null 2>&1; if [ $$? -ne 0 ]; then \
|
|
|
- go get -u github.com/campoy/embedmd; \
|
|
|
|
|
|
|
+ $(GO) get -u github.com/campoy/embedmd; \
|
|
|
fi
|
|
fi
|
|
|
|
|
|
|
|
embedmd:
|
|
embedmd:
|
|
@@ -43,20 +51,20 @@ embedmd:
|
|
|
.PHONY: lint
|
|
.PHONY: lint
|
|
|
lint:
|
|
lint:
|
|
|
@hash golint > /dev/null 2>&1; if [ $$? -ne 0 ]; then \
|
|
@hash golint > /dev/null 2>&1; if [ $$? -ne 0 ]; then \
|
|
|
- go get -u golang.org/x/lint/golint; \
|
|
|
|
|
|
|
+ $(GO) get -u golang.org/x/lint/golint; \
|
|
|
fi
|
|
fi
|
|
|
for PKG in $(PACKAGES); do golint -set_exit_status $$PKG || exit 1; done;
|
|
for PKG in $(PACKAGES); do golint -set_exit_status $$PKG || exit 1; done;
|
|
|
|
|
|
|
|
.PHONY: misspell-check
|
|
.PHONY: misspell-check
|
|
|
misspell-check:
|
|
misspell-check:
|
|
|
@hash misspell > /dev/null 2>&1; if [ $$? -ne 0 ]; then \
|
|
@hash misspell > /dev/null 2>&1; if [ $$? -ne 0 ]; then \
|
|
|
- go get -u github.com/client9/misspell/cmd/misspell; \
|
|
|
|
|
|
|
+ $(GO) get -u github.com/client9/misspell/cmd/misspell; \
|
|
|
fi
|
|
fi
|
|
|
misspell -error $(GOFILES)
|
|
misspell -error $(GOFILES)
|
|
|
|
|
|
|
|
.PHONY: misspell
|
|
.PHONY: misspell
|
|
|
misspell:
|
|
misspell:
|
|
|
@hash misspell > /dev/null 2>&1; if [ $$? -ne 0 ]; then \
|
|
@hash misspell > /dev/null 2>&1; if [ $$? -ne 0 ]; then \
|
|
|
- go get -u github.com/client9/misspell/cmd/misspell; \
|
|
|
|
|
|
|
+ $(GO) get -u github.com/client9/misspell/cmd/misspell; \
|
|
|
fi
|
|
fi
|
|
|
misspell -w $(GOFILES)
|
|
misspell -w $(GOFILES)
|