-
Notifications
You must be signed in to change notification settings - Fork 105
/
Copy pathMakefile
167 lines (132 loc) · 5.05 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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
NAME := kubesec
GITHUB_ORG = controlplaneio
DOCKER_HUB_ORG = controlplane
K8S_SCHEMA_VER = 1.31.0
### github.com/controlplaneio/ensure-content.git makefile-header START ###
ifeq ($(NAME),)
$(error NAME required, please add "NAME := project-name" to top of Makefile)
else ifeq ($(GITHUB_ORG),)
$(error GITHUB_ORG required, please add "GITHUB_ORG := controlplaneio" to top of Makefile)
else ifeq ($(DOCKER_HUB_ORG),)
$(error DOCKER_HUB_ORG required, please add "DOCKER_HUB_ORG := controlplane" to top of Makefile)
endif
PKG := github.com/$(GITHUB_ORG)/$(NAME)
DOCKER_REGISTRY_FQDN ?= docker.io
DOCKER_HUB_URL := $(DOCKER_REGISTRY_FQDN)/$(DOCKER_HUB_ORG)/$(NAME)
SHELL := /bin/bash
BUILD_DATE := $(shell date -u +%Y-%m-%dT%H:%M:%SZ)
GIT_MESSAGE := $(shell git -c log.showSignature=false \
log --max-count=1 --pretty=format:"%H")
GIT_SHA := $(shell git -c log.showSignature=false rev-parse HEAD)
GIT_TAG := $(shell bash -c 'TAG=$$(git -c log.showSignature=false \
describe --tags --exact-match --abbrev=0 $(GIT_SHA) 2>/dev/null); echo "$${TAG:-dev}"')
GIT_UNTRACKED_CHANGES := $(shell git -c log.showSignature=false \
status --porcelain)
ifneq ($(GIT_UNTRACKED_CHANGES),)
GIT_COMMIT := $(GIT_COMMIT)-dirty
ifneq ($(GIT_TAG),dev)
GIT_TAG := $(GIT_TAG)-dirty
endif
endif
CONTAINER_TAG ?= $(GIT_TAG)
CONTAINER_TAG_LATEST := $(CONTAINER_TAG)
CONTAINER_NAME := $(DOCKER_REGISTRY_FQDN)/$(NAME):$(CONTAINER_TAG)
# if no untracked changes and tag is not dev, release `latest` tag
ifeq ($(GIT_UNTRACKED_CHANGES),)
ifneq ($(GIT_TAG),dev)
CONTAINER_TAG_LATEST = latest
endif
endif
CONTAINER_NAME_LATEST := $(DOCKER_REGISTRY_FQDN)/$(NAME):$(CONTAINER_TAG_LATEST)
# golang buildtime, more at https://github.com/jessfraz/pepper/blob/master/Makefile
CTIMEVAR=-X $(PKG)/version.GITCOMMIT=$(GITCOMMIT) -X $(PKG)/version.VERSION=$(VERSION)
GO_LDFLAGS=-ldflags "-w $(CTIMEVAR)"
GO_LDFLAGS_STATIC=-ldflags "-w $(CTIMEVAR) -extldflags -static"
export NAME DOCKER_HUB_URL BUILD_DATE GIT_MESSAGE GIT_SHA GIT_TAG \
CONTAINER_TAG CONTAINER_NAME CONTAINER_NAME_LATEST CONTAINER_NAME_TESTING
### github.com/controlplaneio/ensure-content.git makefile-header END ###
PACKAGE = none
BATS_PARALLEL_JOBS := $(shell command -v parallel 2>/dev/null && echo '--jobs 20')
REMOTE_URL ?= "https://v2.kubesec.io/scan"
.PHONY: all
all: help
# ---
.PHONY: all
lint:
@echo "+ $@"
-make lint-markdown
make lint-go-fmt
.PHONY: lint-go-fmt
lint-go-fmt: ## golang fmt check
@echo "+ $@"
gofmt -l -s ./pkg | grep ".*\.go"; if [ "$$?" = "0" ]; then exit 1; fi
MARKDOWN_IMAGE ?= registry.gitlab.com/06kellyjac/docker_markdownlint-cli
MARKDOWN_IMAGE_TAG ?= 0.19.0
.PHONY: lint-markdown
lint-markdown:
@echo "+ $@"
docker run -v ${PWD}:/markdown ${MARKDOWN_IMAGE}:${MARKDOWN_IMAGE_TAG} '**/*.md' --ignore 'test/bin/'
# ---
.PHONY: test
test: ## unit and local acceptance tests
@echo "+ $@"
make test-unit build test-acceptance
# fetch the parent directory of a file we expect to exist
# don't go deeper than the root of the directory
test/bin/%:
git submodule update --init -- $(dirname $@)
.PHONY: bats
bats: test/bin/bats/README.md test/bin/bats-assert/README.md test/bin/bats-support/README.md ## fetch bats dependencies
.PHONY: test-acceptance
test-acceptance: build test-acceptance-built ## acceptance tests
.PHONY: test-acceptance-built
test-acceptance-built: bats ## run acceptance tests with existing kubesec binary
@echo "+ $@"
bash -xc 'cd test && ./bin/bats/bin/bats $(BATS_PARALLEL_JOBS) .'
.PHONY: test-remote
test-remote: build test-remote-built ## acceptance tests against remote URL
.PHONY: test-remote-built
test-remote-built: bats ## acceptance tests against remote URL with existing kubesec binary
@echo "+ $@"
bash -xc 'cd test && REMOTE_URL=$(REMOTE_URL) ./bin/bats/bin/bats $(BATS_PARALLEL_JOBS) .'
.PHONY: test-unit
test-unit: ## golang unit tests
@echo "+ $@"
go test -race $$(go list ./... | grep -v '/vendor/') -run "$${RUN:-.*}"
.PHONY: test-unit-verbose
test-unit-verbose: ## golang unit tests (verbose)
@echo "+ $@"
go test -race -v $$(go list ./... | grep -v '/vendor/') -run "$${RUN:-.*}"
# ---
.PHONY: build
build: ## golang build
@echo "+ $@"
go build -a -o ./dist/kubesec .
.PHONY: prune
prune: ## golang dependency prune
@echo "+ $@"
go mod tidy
# ---
.PHONY: docker-build
docker-build: ## builds a docker image
@echo "+ $@"
docker build --tag "${CONTAINER_NAME}" --build-arg "K8S_SCHEMA_VER=${K8S_SCHEMA_VER}" .
docker tag "${CONTAINER_NAME}" "${CONTAINER_NAME_LATEST}"
@echo "Successfully tagged ${CONTAINER_NAME} as ${CONTAINER_NAME_LATEST}"
.PHONY: docker-run
docker-run: ## runs the last build docker image
@echo "+ $@"
docker run -it "${CONTAINER_NAME}"
.PHONY: docker-push
docker-push: ## pushes the last build docker image
@echo "+ $@"
docker push "${CONTAINER_NAME}"
docker push "${CONTAINER_NAME_LATEST}"
# ---
.PHONY: help
help: ## parse jobs and descriptions from this Makefile
set -x;
@grep -E '^[ a-zA-Z0-9_-]+:([^=]|$$)' $(MAKEFILE_LIST) \
| grep -Ev '^help\b[[:space:]]*:' \
| sort \
| awk 'BEGIN {FS = ":.*?##"}; {printf "\033[36m%-20s\033[0m %s\n", $$1, $$2}'