forked from projectcalico/kube-controllers
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
102 lines (85 loc) · 3.56 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
.PHONY: all policy-controller docker-image clean
SRCDIR=.
CONTAINER_NAME=calico/kube-policy-controller
default: all
all: policy-controller
# Build the calico/kube-policy-controller Docker container.
docker-image: image.created
# Run the unit tests.
ut: update-version
docker run --rm -v `pwd`:/code \
calico/test \
nosetests tests/unit -c nose.cfg
# Run system tests.
st: docker-image run-etcd run-k8s-apiserver
./tests/system/apiserver-reconnection.sh
$(MAKE) stop-k8s-apiserver stop-etcd
GET_CONTAINER_IP := docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}'
K8S_VERSION=1.5.3
.PHONY: run-k8s-apiserver stop-k8s-apiserver run-etcd stop-etcd
run-k8s-apiserver: stop-k8s-apiserver
ETCD_IP=`$(GET_CONTAINER_IP) st-etcd` && \
docker run --detach \
--name st-apiserver \
gcr.io/google_containers/hyperkube-amd64:v$(K8S_VERSION) \
/hyperkube apiserver --etcd-servers=http://$${ETCD_IP}:2379 \
--service-cluster-ip-range=10.101.0.0/16 -v=10
stop-k8s-apiserver:
@-docker rm -f st-apiserver
run-etcd: stop-etcd
docker run --detach \
--name st-etcd quay.io/coreos/etcd:v3.1.5 \
etcd \
--advertise-client-urls "http://127.0.0.1:2379,http://127.0.0.1:4001" \
--listen-client-urls "http://0.0.0.0:2379,http://0.0.0.0:4001"
stop-etcd:
@-docker rm -f st-etcd
# Makes tests on Circle CI.
test-circle: update-version
# Can't use --rm on circle
# Circle also requires extra options for reporting.
docker run \
-v `pwd`:/code \
-v $(CIRCLE_TEST_REPORTS):/circle_output \
-e COVERALLS_REPO_TOKEN=$(COVERALLS_REPO_TOKEN) \
calico/test sh -c \
'nosetests tests/unit -c nose.cfg \
--with-xunit --xunit-file=/circle_output/output.xml; RC=$$?;\
[[ ! -z "$$COVERALLS_REPO_TOKEN" ]] && coveralls || true; exit $$RC'
image.created: update-version
# Build the docker image for the policy controller.
docker build -t $(CONTAINER_NAME) .
touch image.created
# Update the version file.
update-version:
echo "VERSION='`git describe --tags --dirty`'" > version.py
release: clean
ifndef VERSION
$(error VERSION is undefined - run using make release VERSION=vX.Y.Z)
endif
git tag $(VERSION)
$(MAKE) image.created
docker tag $(CONTAINER_NAME) $(CONTAINER_NAME):$(VERSION)
docker tag $(CONTAINER_NAME) quay.io/$(CONTAINER_NAME):$(VERSION)
# Ensure reported version is correct.
if ! docker run calico/kube-policy-controller:$(VERSION) version | grep '^$(VERSION)$$'; then echo "Reported version:" `docker run calico/kube-policy-controller:$(VERSION) version` "\nExpected version: $(VERSION)"; false; else echo "Version check passed\n"; fi
@echo "Now push the tag and images."
@echo "git push $(VERSION)"
@echo "docker push calico/kube-policy-controller:$(VERSION)"
@echo "docker push quay.io/calico/kube-policy-controller:$(VERSION)"
clean:
find . -name '*.pyc' -exec rm -f {} +
rm -rf dist image.created
-docker rmi $(CONTAINER_NAME)
ci: clean docker-image ut st
# Assumes that a few environment variables exist - BRANCH_NAME PULL_REQUEST_NUMBER
set -e; \
if [ -z $$PULL_REQUEST_NUMBER ]; then \
docker tag $(CONTAINER_NAME) $(CONTAINER_NAME):$$BRANCH_NAME && docker push $(CONTAINER_NAME):$$BRANCH_NAME; \
docker tag $(CONTAINER_NAME) quay.io/$(CONTAINER_NAME):$$BRANCH_NAME && docker push quay.io/$(CONTAINER_NAME):$$BRANCH_NAME; \
if [ "$$BRANCH_NAME" = "master" ]; then \
export VERSION=`git describe --tags --dirty`; \
docker tag $(CONTAINER_NAME) $(CONTAINER_NAME):$$VERSION && docker push $(CONTAINER_NAME):$$VERSION; \
docker tag $(CONTAINER_NAME) quay.io/$(CONTAINER_NAME):$$VERSION && docker push quay.io/$(CONTAINER_NAME):$$VERSION; \
fi; \
fi