-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
99 lines (82 loc) · 2.78 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
.DEFAULT_GOAL := help
VERSION := v0.0.0
TARGET_MAX_CHAR_NUM := 20
GREEN := $(shell tput -Txterm setaf 2)
YELLOW := $(shell tput -Txterm setaf 3)
WHITE := $(shell tput -Txterm setaf 7)
RESET := $(shell tput -Txterm sgr0)
PROJECT_DIR=$(shell pwd)
.PHONY: help build fmt lint test release-tag release-push
## Show help
help:
@echo 'Package eris provides a better way to handle errors in Go.'
@echo ''
@echo 'Usage:'
@echo ' ${YELLOW}make${RESET} ${GREEN}<target>${RESET}'
@echo ''
@echo 'Targets:'
@awk '/^[a-zA-Z\-\_0-9]+:/ { \
helpMessage = match(lastLine, /^## (.*)/); \
if (helpMessage) { \
helpCommand = substr($$1, 0, index($$1, ":")-1); \
helpMessage = substr(lastLine, RSTART + 3, RLENGTH); \
printf " ${YELLOW}%-$(TARGET_MAX_CHAR_NUM)s${RESET} ${GREEN}%s${RESET}\n", helpCommand, helpMessage; \
} \
} \
{ lastLine = $$0 }' $(MAKEFILE_LIST)
## Build the code
build:
@echo Building
@go build -v .
## Format with go-fmt
fmt:
@echo Formatting
@go fmt .
## Lint with golangci-lint
lint: golangci-lint
@echo Linting
@$(PROJECT_DIR)/bin/golangci-lint run --config $(PROJECT_DIR)/.golangci.yaml
golangci-lint:
GOBIN=$(PROJECT_DIR)/bin go install github.com/golangci/golangci-lint/cmd/[email protected]
## Format docs
docs:
@echo Formatting docs
@npm list -g markdown-toc > /dev/null 2>&1 || npm install -g markdown-toc > /dev/null 2>&1
@markdown-toc -i README.md
## Run the tests
test:
@echo Running tests
@go test -race -covermode=atomic -coverprofile=cover.out -v .
@go tool cover -html cover.out -o cover.html
tests: test
## Run benchmark tests
bench:
@echo Running benchmark tests
@cd benchmark && go test -benchmem -bench=. && cd ..
## Run the tests with coverage
test-coverage:
@echo Running tests with coverage
@go test -short -coverprofile cover.out -covermode=atomic ${PKG_LIST}
## Display test coverage
display-coverage: test-coverage
@echo Displaying test coverage
@go tool cover -html=cover.out
## Stage a release (usage: make release-tag VERSION={VERSION_TAG})
release-tag: build fmt lint test
@echo Tagging release with version "${VERSION}"
@git tag -a ${VERSION} -m "chore: release version '${VERSION}'"
@echo Generating changelog
@git-chglog -o CHANGELOG.md
@git add CHANGELOG.md
@git commit -m "chore: update changelog for version '${VERSION}'"
## Push a release (warning: make sure the release was staged properly before doing this)
release-push:
@echo Publishing release
@git push --follow-tags
spellcheck:
@if command -v cspell > /dev/null 2>&1 ; then \
cspell lint -c hack/cspell/cspell.json --relative --no-progress --no-summary --show-suggestions -e 'vendor/*' --gitignore **/*.go **/*.md; \
else \
echo "ERROR: cspell not found, install it manually! Link: https://cspell.org/docs/getting-started"; \
exit 1; \
fi