-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathMakefile
105 lines (85 loc) · 3.15 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
# Based on https://git.io/fjkGc
# The name of the file recommended in the standard
# documentation go test -cover and used codecov.io
# to check code coverage.
COVER_FILE ?= coverage.out
# Main targets.
.DEFAULT_GOAL := help
.PHONY: bench
bench: ## Run benchmarks
@go test ./... -bench=. -run="Benchmark*"
.PHONY: build
build: ## Build the project binary
@go build ./...
.PHONY: ci
ci: check checkstate ## Target for integration with ci pipeline
.PHONY: check
check: static test build ## Check project with static checks and unit tests
$(COVER_FILE):
@$(MAKE) test
.PHONY: cover
cover: $(COVER_FILE) ## Output coverage in human readable an HTML
@go tool cover -html=$(COVER_FILE)
@rm -f $(COVER_FILE)
.PHONY: dep
dep: ## Install and sync go modules dependencies, beautify go.mod and go.sum files
@go mod download
@go mod tidy
@go mod download
@go mod verify
.PHONY: help
help: ## Print this help
@grep -E '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | sort | \
awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}'
.PHONY: imports
imports: tools ## Check and fix import section by import rules
@test -z $$(for d in $$(go list -f {{.Dir}} ./...); do goimports -e -l -local $$(go list) -w $$d/*.go; done)
.PHONY: lint
lint: tools ## Check the project with lint
@go list ./... | grep -v /vendor/ | xargs -L1 golint -set_exit_status
.PHONY: static
static: imports vet lint ## Run static checks (lint, imports, vet, ...) all over the project
.PHONY: test
test: ## Run unit tests
@go test ./... -count=1 -race
@go test ./... -count=1 -coverprofile=$(COVER_FILE) -covermode=atomic $d
@go tool cover -func=$(COVER_FILE) | grep ^total
.PHONY: testin
testin: ## Run integration tests
@go test `go list ./... | grep -v /vendor/` -tags=integration -coverprofile=$(COVER_FILE) -covermode=atomic $d
@go tool cover -func=$(COVER_FILE) | grep ^total
.PHONY: testup
testup: ## Run unit tests with golden files update
@find . -type f -name '*.golden' -exec rm -f {} \;
@go test `go list ./... | grep -v /vendor/` -update
CDTOOLS ?= cd internal/tools &&
.PHONY: tools
tools: ## Install all needed tools, e.g. for static checks
@$(CDTOOLS) go install golang.org/x/lint/golint
@$(CDTOOLS) go install golang.org/x/tools/cmd/goimports
.PHONY: toolsup
toolsup: ## Update all needed tools, e.g. for static checks
@$(CDTOOLS) go mod tidy
@$(CDTOOLS) go get golang.org/x/lint/golint@latest
@$(CDTOOLS) go get golang.org/x/tools/cmd/goimports@latest
@$(CDTOOLS) go mod download
@$(CDTOOLS) go mod verify
@$(MAKE) tools
.PHONY: vet
vet: ## Check the project with vet
@go vet ./...
.PHONY: checkstate
checkstate: tools ## Checking the relevance of dependencies, and tools. Also, the absence of arbitrary changes when performing checks.
@echo 'checking the relevance of the dependency list'
@go mod tidy
@git diff --exit-code go.mod go.sum
@echo 'checking the relevance of the committed dependencies'
@go mod vendor
@git diff --exit-code vendor
@echo 'checking the relevance of the committed generated files'
@go generate
@exit $$(git status -s | wc -l)
@echo 'checking the relevance of the committed golden files'
@make testup
@exit $$(git status -s | wc -l)
@go mod verify