-
Notifications
You must be signed in to change notification settings - Fork 255
/
Makefile
executable file
·300 lines (230 loc) · 9.77 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
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
# Makefile to build fortio's docker images as well as short cut
# for local test/install
#
# See also release/README.md
#
IMAGES=echosrv fcurl # plus the combo image / Dockerfile without ext.
DOCKER_PREFIX := docker.io/fortio/fortio
BUILD_IMAGE_TAG := v77@sha256:03af2e7202d5364fb3424c9ef28f372702081ee809b7f8dfbb2a1b649b0b4c2c
BUILDX_PLATFORMS := linux/amd64,linux/arm64,linux/ppc64le,linux/s390x
BUILDX_POSTFIX :=
ifeq '$(shell echo $(BUILDX_PLATFORMS) | awk -F "," "{print NF-1}")' '0'
BUILDX_POSTFIX = --load
endif
BUILD_IMAGE := $(DOCKER_PREFIX).build:$(BUILD_IMAGE_TAG)
TAG:=$(USER)$(shell date +%y%m%d_%H%M%S)
DOCKER_TAG = $(DOCKER_PREFIX)$(IMAGE):$(TAG)
CERT_TEMP_DIR := ./cert-tmp/
# go test ./... and others run in vendor/ and cause problems (!)
# so to avoid `can't load package: package fortio.org/fortio/...: no Go files in ...`
# note that only go1.8 needs the grep -v vendor but we are compatible with 1.8
# ps: can't use go list (and get packages as canonical fortio.org/fortio/x)
# as somehow that makes gometaliner silently not find/report errors...
PACKAGES ?= $(shell go list ./...)
# from fortio 1.4 we use go 1.14 (from go 1.8 up to fortio 1.3) and switched to go modules (from vendor)
# Local targets:
go-install:
go install $(PACKAGES)
# Run/test dependencies
dependencies: certs
# Only generate certs if needed
certs: $(CERT_TEMP_DIR)/server.cert
# Generate certs for unit and release tests.
$(CERT_TEMP_DIR)/server.cert: cert-gen
@echo "OS='$(OS)'"
./cert-gen
# Remove certificates
certs-clean:
rm -rf $(CERT_TEMP_DIR)
TEST_TIMEOUT:=90s
OS:=$(shell go env GOOS)
# Local test
ifeq ($(OS),windows)
test:
@echo "Skipping most tests on Windows until we can get cert-gen to work there."
go test ./stats
else
test: dependencies
go test -tags netgo -timeout $(TEST_TIMEOUT) -race $(PACKAGES)
endif
# To debug strange linter errors, uncomment
# DEBUG_LINTERS="--debug"
.golangci.yml: Makefile
curl -fsS -o .golangci.yml https://raw.githubusercontent.com/fortio/workflows/main/golangci.yml
local-lint: .golangci.yml
govulncheck $(LINT_PACKAGES)
golangci-lint version
golangci-lint --timeout 120s $(DEBUG_LINTERS) run $(LINT_PACKAGES)
# Lint everything by default but ok to "make lint LINT_PACKAGES=./fhttp"
LINT_PACKAGES:=./...
lint: .golangci.yml
docker run -v $(CURDIR):/build/fortio $(BUILD_IMAGE) bash -c \
"cd /build/fortio; chown build:build . \
&& time make local-lint DEBUG_LINTERS=\"$(DEBUG_LINTERS)\" LINT_PACKAGES=\"$(LINT_PACKAGES)\""
docker-test:
docker run -v $(CURDIR):/build/fortio $(BUILD_IMAGE) bash -c \
"cd /build/fortio \
&& time make test"
shell:
docker run -ti -v $(CURDIR):/build/fortio $(BUILD_IMAGE)
# This really also tests the release process and build on windows,mac,linux
# and the Docker images, not just "web" (UI) stuff that it also exercises.
release-test: docker-version
./Webtest.sh
# old name for release-test
webtest: release-test
coverage: dependencies
go test -race -coverprofile=coverage.out -covermode=atomic ./...
# Short cut for pulling/updating to latest of the current branch
pull:
git pull
# Docker: Pushes the combo image and the smaller image(s)
all: test go-install lint docker-version docker-push-internal
@for img in $(IMAGES); do \
$(MAKE) docker-push-internal IMAGE=.$$img TAG=$(TAG); \
done
# When changing the build image, this Makefile should be edited first
# (bump BUILD_IMAGE_TAG), also change this list if the image is used in
# more places.
FILES_WITH_IMAGE:= .circleci/config.yml Dockerfile Dockerfile.echosrv \
Dockerfile.fcurl release/Dockerfile.in Webtest.sh
# then run make update-build-image and check the diff, etc... see release/README.md
update-build-image:
docker buildx create --use
$(MAKE) docker-push-internal IMAGE=.build TAG=$(BUILD_IMAGE_TAG)
# Get the sha (use after newly building a new build image) to put it back in BUILD_IMAGE_TAG
build-image-sha:
docker pull $(BUILD_IMAGE)
docker inspect $(BUILD_IMAGE) | jq -r '.[0].RepoDigests[0]' | sed -e "s/^.*@/$(BUILD_IMAGE_TAG)@/"
SED:=sed
update-build-image-tag:
@echo 'Need to use gnu sed (brew install gnu-sed; make update-build-image-tag SED=gsed)'
$(SED) --in-place=.bak -E -e 's!$(DOCKER_PREFIX).build:v[^ ]+!$(BUILD_IMAGE)!g' $(FILES_WITH_IMAGE)
docker-default-platform:
@docker buildx --builder default inspect | awk '/Platforms:/ {print $$2}' | sed -e 's/,//g'
docker-version:
@echo "### Docker is `which docker`"
@docker version
docker-internal: dependencies
@echo "### Now building $(DOCKER_TAG)"
docker buildx build --platform $(BUILDX_PLATFORMS) --build-arg MODE=$(MODE) -f Dockerfile$(IMAGE) -t $(DOCKER_TAG) $(BUILDX_POSTFIX) .
docker-push-internal: docker-internal docker-buildx-push
docker-buildx-push:
@echo "### Now pushing $(DOCKER_TAG)"
docker buildx build --push --platform $(BUILDX_PLATFORMS) -f Dockerfile$(IMAGE) -t $(DOCKER_TAG) .
release: dist
release/release.sh
.PHONY: all docker-internal docker-push-internal docker-version test dependencies
.PHONY: go-install lint install-linters coverage webtest release-test update-build-image build-image-sha
.PHONY: local-lint update-build-image-tag release pull certs certs-clean
# Targets used for official builds (initially from Dockerfile)
BUILD_DIR := /tmp/fortio_build
BUILD_DIR_ABS := $(abspath $(BUILD_DIR))
BUILD_DIR_BIN := $(BUILD_DIR_ABS)/bin
OFFICIAL_EXE ?= $(notdir $(OFFICIAL_TARGET))
OFFICIAL_BIN ?= $(BUILD_DIR)/result/$(OFFICIAL_EXE)
OFFICIAL_DIR ?= $(dir $(OFFICIAL_BIN))
GOOS :=
GO_BIN := go
GIT_TAG ?= $(shell git describe --tags --match 'v*' --dirty)
DIST_VERSION ?= $(shell echo $(GIT_TAG) | sed -e "s/^v//")
GIT_SHA ?= $(shell git rev-parse HEAD)
# Main/default binary to build: (can be changed to build fcurl or echosrv instead)
OFFICIAL_TARGET := fortio.org/fortio
MODE ?= install
debug-tags:
@echo "GIT_TAG=$(GIT_TAG)"
@echo "DIST_VERSION=$(DIST_VERSION)"
echo-version:
@echo "$(DIST_VERSION)"
# FPM (for rpm...) converts - to _
echo-package-version:
@echo "$(DIST_VERSION)" | sed -e "s/-/_/g"
$(BUILD_DIR):
mkdir -p $(BUILD_DIR)
$(OFFICIAL_DIR):
mkdir -p $(OFFICIAL_DIR)
.PHONY: official-build official-build-internal official-build-version official-build-clean
official-build: official-build-internal
official-build-internal: $(BUILD_DIR) $(OFFICIAL_DIR)
@echo "Building OFFICIAL_EXE=$(OFFICIAL_EXE) BUILD_DIR=$(BUILD_DIR) BUILD_DIR_BIN=$(BUILD_DIR_BIN) MODE=$(MODE)"
@echo "OFFICIAL_BIN=$(OFFICIAL_BIN) OFFICIAL_DIR=$(OFFICIAL_DIR) OFFICIAL_TARGET=$(OFFICIAL_TARGET)"
$(GO_BIN) version
ifeq ($(MODE),install)
GOPATH=$(BUILD_DIR_ABS) CGO_ENABLED=0 GOOS=$(GOOS) $(GO_BIN) install -a -ldflags -s $(OFFICIAL_TARGET)@v$(DIST_VERSION)
# rename when building cross architecture (on windows it has .exe suffix thus the *)
ls -lR $(BUILD_DIR_BIN)
-mv -f $(BUILD_DIR_BIN)/*_*/$(OFFICIAL_EXE)* $(BUILD_DIR_BIN)
-rmdir $(BUILD_DIR_BIN)/*_*
mv -f $(BUILD_DIR_BIN)/$(OFFICIAL_EXE)* $(OFFICIAL_DIR)
else
CGO_ENABLED=0 GOOS=$(GOOS) $(GO_BIN) build -a -ldflags -s -o $(OFFICIAL_BIN) $(OFFICIAL_TARGET)
endif
official-build-version: official-build
$(OFFICIAL_BIN) version
official-build-clean:
-$(RM) $(OFFICIAL_BIN) release/Makefile
# Create a complete source tree with naming matching Debian package conventions
TAR ?= tar # on macOS need gtar to get --owner
DIST_PATH:=release/fortio_$(DIST_VERSION).orig.tar
.PHONY: dist dist-sign distclean
release/Makefile: release/Makefile.dist
echo "GIT_TAG := $(GIT_TAG)" > $@
echo "GIT_SHA := $(GIT_SHA)" >> $@
cat $< >> $@
dist: release/Makefile
# put the source files where they can be used as gopath by go,
# except leave the debian dir where it needs to be (below the version dir)
git ls-files \
| awk '{printf("fortio/%s\n", $$0)}' \
| (cd ../ ; $(TAR) \
--xform="s|^fortio/|fortio-$(DIST_VERSION)/src/fortio.org/fortio/|;s|^.*debian/|fortio-$(DIST_VERSION)/debian/|" \
--owner=0 --group=0 -c -f - -T -) > $(DIST_PATH)
# move the release/Makefile at the top (after the version dir)
$(TAR) --xform="s|^release/|fortio-$(DIST_VERSION)/|" \
--owner=0 --group=0 -r -f $(DIST_PATH) release/Makefile
gzip -f $(DIST_PATH)
@echo "Created $(CURDIR)/$(DIST_PATH).gz"
dist-sign:
gpg --armor --detach-sign $(DIST_PATH)
distclean: official-build-clean
-rm -f *.profile.* */*.profile.*
-rm -rf $(CERT_TEMP_DIR)
# Install target more compatible with standard gnu/debian practices. Uses DESTDIR as staging prefix
install: official-install
.PHONY: install official-install
BIN_INSTALL_DIR = $(DESTDIR)/usr/bin
MAN_INSTALL_DIR = $(DESTDIR)/usr/share/man/man1
BIN_INSTALL_EXEC = fortio
official-install: official-build-clean official-build-version
-mkdir -p $(BIN_INSTALL_DIR) $(MAN_INSTALL_DIR)
cp $(OFFICIAL_BIN) $(BIN_INSTALL_DIR)/$(BIN_INSTALL_EXEC)
cp docs/fortio.1 $(MAN_INSTALL_DIR)
# Test distribution (only used by maintainer)
.PHONY: debian-dist-common debian-dist-test debian-dist debian-sbuild
# warning, will be cleaned
TMP_DIST_DIR:=~/tmp/fortio-dist
# debian getting version from debian/changelog while we get it from git tags
# doesn't help making this simple: (TODO: unify or autoupdate the 3 versions)
debian-dist-common:
$(MAKE) dist TAR=tar
-mkdir -p $(TMP_DIST_DIR)
rm -rf $(TMP_DIST_DIR)/fortio*
cp $(CURDIR)/$(DIST_PATH).gz $(TMP_DIST_DIR)
cd $(TMP_DIST_DIR); tar xfz *.tar.gz
-cd $(TMP_DIST_DIR);\
ln -s *.tar.gz fortio_`cd fortio-$(DIST_VERSION); dpkg-parsechangelog -S Version | sed -e "s/-.*//"`.orig.tar.gz
debian-dist-test: debian-dist-common
cd $(TMP_DIST_DIR)/fortio-$(DIST_VERSION); FORTIO_SKIP_TESTS=Y dpkg-buildpackage -us -uc
cd $(TMP_DIST_DIR)/fortio-$(DIST_VERSION); lintian
debian-dist: distclean debian-dist-common
cd $(TMP_DIST_DIR)/fortio-$(DIST_VERSION); FORTIO_SKIP_TESTS=N dpkg-buildpackage -ap
cd $(TMP_DIST_DIR)/fortio-$(DIST_VERSION); lintian
# assumes you ran one of the previous 2 target first
debian-sbuild:
cd $(TMP_DIST_DIR)/fortio-$(DIST_VERSION); sbuild
info:
@echo "GIT_SHA=$(GIT_SHA)"
@echo "GIT_TAG=$(GIT_TAG)"
pwd
ls -la