-
Notifications
You must be signed in to change notification settings - Fork 426
/
Makefile
264 lines (199 loc) · 8.67 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
SHELL = /bin/bash -o pipefail
GO = go
# Flags to pass to go build
BUILD_FLAGS = -gcflags '-N -l'
BUILD_QUIET ?= -q
GOLANG_IMAGE ?= golang:1.14
GOPROXY ?= $(shell go env GOPROXY)
# Where to find your project
PROJECT_ROOT = github.com/uber/kraken
PACKAGE_VERSION ?= $(shell git describe --always --tags)
ALL_SRC = $(shell find . -name "*.go" | grep -v \
-e ".*/\..*" \
-e ".*/_.*" \
-e ".*/mocks.*" \
-e ".*/*.pb.go")
ALL_PKGS = $(shell go list $(sort $(dir $(ALL_SRC))))
# ==== BASIC ====
BUILD_LINUX = GOOS=linux GOARCH=amd64 $(GO) build -i -o $@ $(BUILD_FLAGS) $(BUILD_GC_FLAGS) $(BUILD_VERSION_FLAGS) ./$(dir $@)
# Cross compiling cgo for sqlite3 is not well supported in Mac OSX.
# This workaround builds the binary inside a linux container.
CROSS_COMPILER = docker run --rm -it -v $(shell pwd):/go/src/github.com/uber/kraken -w /go/src/github.com/uber/kraken -e GOPROXY=$(GOPROXY) $(GOLANG_IMAGE) go build -o ./$@ ./$(dir $@)
LINUX_BINS = \
agent/agent \
build-index/build-index \
origin/origin \
proxy/proxy \
tools/bin/testfs/testfs \
tracker/tracker
REGISTRY ?= gcr.io/uber-container-tools
$(LINUX_BINS):: $(ALL_SRC)
$(CROSS_COMPILER)
define tag_image
docker tag $(1):$(PACKAGE_VERSION) $(1):dev
docker tag $(1):$(PACKAGE_VERSION) $(REGISTRY)/$(1):$(PACKAGE_VERSION)
endef
.PHONY: images
images: $(LINUX_BINS)
docker build $(BUILD_QUIET) -t kraken-agent:$(PACKAGE_VERSION) -f docker/agent/Dockerfile ./
docker build $(BUILD_QUIET) -t kraken-build-index:$(PACKAGE_VERSION) -f docker/build-index/Dockerfile ./
docker build $(BUILD_QUIET) -t kraken-origin:$(PACKAGE_VERSION) -f docker/origin/Dockerfile ./
docker build $(BUILD_QUIET) -t kraken-proxy:$(PACKAGE_VERSION) -f docker/proxy/Dockerfile ./
docker build $(BUILD_QUIET) -t kraken-testfs:$(PACKAGE_VERSION) -f docker/testfs/Dockerfile ./
docker build $(BUILD_QUIET) -t kraken-tracker:$(PACKAGE_VERSION) -f docker/tracker/Dockerfile ./
docker build $(BUILD_QUIET) -t kraken-herd:$(PACKAGE_VERSION) -f docker/herd/Dockerfile ./
$(call tag_image,kraken-agent)
$(call tag_image,kraken-build-index)
$(call tag_image,kraken-origin)
$(call tag_image,kraken-proxy)
$(call tag_image,kraken-testfs)
$(call tag_image,kraken-tracker)
$(call tag_image,kraken-herd)
.PHONY: publish
publish: images
docker push $(REGISTRY)/kraken-agent:$(PACKAGE_VERSION)
docker push $(REGISTRY)/kraken-build-index:$(PACKAGE_VERSION)
docker push $(REGISTRY)/kraken-origin:$(PACKAGE_VERSION)
docker push $(REGISTRY)/kraken-proxy:$(PACKAGE_VERSION)
docker push $(REGISTRY)/kraken-testfs:$(PACKAGE_VERSION)
docker push $(REGISTRY)/kraken-tracker:$(PACKAGE_VERSION)
docker push $(REGISTRY)/kraken-herd:$(PACKAGE_VERSION)
clean::
@rm -f $(LINUX_BINS)
.PHONY: bins
bins: $(LINUX_BINS)
# ==== TEST ====
.PHONY: unit-test
unit-test:
-rm coverage.txt
$(GO) test -timeout=30s -race -coverprofile=coverage.txt $(ALL_PKGS) --tags "unit"
.PHONY: docker_stop
docker_stop:
-docker ps -a --format '{{.Names}}' | grep kraken | while read n; do docker rm -f $$n; done
venv: requirements-tests.txt
virtualenv --python=$(shell which python2) --setuptools venv
source venv/bin/activate
venv/bin/pip install -r requirements-tests.txt
.PHONY: integration
FILE?=
NAME?=test_
USERNAME:=$(shell id -u -n)
USERID:=$(shell id -u)
integration: venv $(LINUX_BINS) docker_stop tools/bin/puller/puller
docker build $(BUILD_QUIET) -t kraken-agent:$(PACKAGE_VERSION) -f docker/agent/Dockerfile --build-arg USERID=$(USERID) --build-arg USERNAME=$(USERNAME) ./
docker build $(BUILD_QUIET) -t kraken-build-index:$(PACKAGE_VERSION) -f docker/build-index/Dockerfile --build-arg USERID=$(USERID) --build-arg USERNAME=$(USERNAME) ./
docker build $(BUILD_QUIET) -t kraken-origin:$(PACKAGE_VERSION) -f docker/origin/Dockerfile --build-arg USERID=$(USERID) --build-arg USERNAME=$(USERNAME) ./
docker build $(BUILD_QUIET) -t kraken-proxy:$(PACKAGE_VERSION) -f docker/proxy/Dockerfile --build-arg USERID=$(USERID) --build-arg USERNAME=$(USERNAME) ./
docker build $(BUILD_QUIET) -t kraken-testfs:$(PACKAGE_VERSION) -f docker/testfs/Dockerfile --build-arg USERID=$(USERID) --build-arg USERNAME=$(USERNAME) ./
docker build $(BUILD_QUIET) -t kraken-tracker:$(PACKAGE_VERSION) -f docker/tracker/Dockerfile --build-arg USERID=$(USERID) --build-arg USERNAME=$(USERNAME) ./
PACKAGE_VERSION=$(PACKAGE_VERSION) venv/bin/py.test --timeout=120 -v -k $(NAME) test/python/$(FILE)
.PHONY: runtest
NAME?=test_
runtest: venv docker_stop
source venv/bin/activate
venv/bin/py.test --timeout=120 -v -k $(NAME) test/python
.PHONY: devcluster
devcluster: $(LINUX_BINS) docker_stop images
./examples/devcluster/herd_start_container.sh
./examples/devcluster/agent_one_start_container.sh
./examples/devcluster/agent_two_start_container.sh
# ==== TOOLS ====
TOOLS = \
tools/bin/puller/puller \
tools/bin/reload/reload \
tools/bin/visualization/visualization
tools/bin/puller/puller:: $(wildcard tools/bin/puller/puller/*.go)
$(CROSS_COMPILER)
tools/bin/reload/reload:: $(wildcard tools/bin/reload/reload/*.go)
$(CROSS_COMPILER)
tools/bin/visualization/visualization:: $(wildcard tools/bin/visualization/visualization/*.go)
$(CROSS_COMPILER)
.PHONY: tools
tools: $(TOOLS)
# Creates a release summary containing the build revisions of each component
# for the specified version.
releases/%:
./scripts/release.sh $(subst releases/,,$@)
# ==== CODE GENERATION ====
# In order for kraken to be imported by other projects, we need to check in all
# the generated code, otherwise dependency management tools would report errors
# caused by missing dependencies of kraken itself.
# protoc must be installed on the system to make this work.
# Install it by by following instructions on:
# https://github.com/protocolbuffers/protobuf.
PROTOC_BIN = protoc
PROTO = $(GEN_DIR)/proto/p2p/p2p.pb.go
GEN_DIR = gen/go
.PHONY: protoc
protoc:
mkdir -p $(GEN_DIR)
go get -u github.com/golang/protobuf/protoc-gen-go
$(PROTOC_BIN) --plugin=$(shell go env GOPATH)/bin/protoc-gen-go --go_out=$(GEN_DIR) $(subst .pb.go,.proto,$(subst $(GEN_DIR)/,,$(PROTO)))
# mockgen must be installed on the system to make this work.
# Install it by running:
# `go get github.com/golang/mock/mockgen`.
mockgen = $(shell go env GOPATH)/bin/mockgen
define lowercase
$(shell tr '[:upper:]' '[:lower:]' <<< $(1))
endef
define add_mock
mkdir -p mocks/$(1)
$(mockgen) \
-destination=mocks/$(1)/$(call lowercase,$(2)).go \
-package mock$(notdir $(1)) \
$(PROJECT_ROOT)/$(1) $(2)
endef
.PHONY: mocks
mocks:
rm -rf mocks
mkdir -p $(shell go env GOPATH)/bin
$(call add_mock,agent/agentclient,Client)
$(call add_mock,lib/backend/s3backend,S3)
# mockgen doesn't play nice when importing vendor code. Must strip the vendor prefix
# from the imports.
sed -i '' s,github.com/uber/kraken/vendor/,, mocks/lib/backend/s3backend/s3.go
$(call add_mock,lib/backend/gcsbackend,GCS)
sed -i '' s,github.com/uber/kraken/vendor/,, mocks/lib/backend/gcsbackend/gcs.go
$(call add_mock,lib/hashring,Ring)
$(call add_mock,lib/hashring,Watcher)
$(call add_mock,lib/backend/hdfsbackend/webhdfs,Client)
$(call add_mock,lib/hostlist,List)
$(call add_mock,lib/healthcheck,Checker)
$(call add_mock,lib/healthcheck,Filter)
$(call add_mock,lib/healthcheck,PassiveFilter)
$(call add_mock,tracker/originstore,Store)
$(call add_mock,build-index/tagstore,Store)
$(call add_mock,build-index/tagstore,FileStore)
$(call add_mock,build-index/tagtype,DependencyResolver)
$(call add_mock,build-index/tagclient,Provider)
$(call add_mock,build-index/tagclient,Client)
$(call add_mock,tracker/announceclient,Client)
$(call add_mock,utils/dedup,TaskRunner)
$(call add_mock,utils/dedup,IntervalTask)
$(call add_mock,lib/backend,Client)
$(call add_mock,tracker/peerstore,Store)
$(call add_mock,lib/store,FileReadWriter)
$(call add_mock,lib/torrent/scheduler,ReloadableScheduler)
$(call add_mock,lib/torrent/scheduler,Scheduler)
$(call add_mock,origin/blobclient,Client)
$(call add_mock,origin/blobclient,Provider)
$(call add_mock,origin/blobclient,ClusterClient)
$(call add_mock,origin/blobclient,ClusterProvider)
$(call add_mock,origin/blobclient,ClientResolver)
$(call add_mock,lib/containerruntime,Factory)
$(call add_mock,lib/containerruntime/containerd,Client)
$(call add_mock,lib/containerruntime/dockerdaemon,DockerClient)
$(call add_mock,lib/dockerregistry/transfer,ImageTransferer)
$(call add_mock,tracker/metainfoclient,Client)
$(call add_mock,lib/persistedretry,Store)
$(call add_mock,lib/persistedretry,Task)
$(call add_mock,lib/persistedretry,Executor)
$(call add_mock,lib/persistedretry,Manager)
$(call add_mock,lib/persistedretry/tagreplication,RemoteValidator)
$(call add_mock,utils/httputil,RoundTripper)
# ==== MISC ====
kubecluster:
cd ./examples/k8s && bash deploy.sh
.PHONY: docs
docs:
@./scripts/mkdocs.sh -q serve