blob: 9374284103c7d3e77e20d2a09266a4762969f144 [file] [log] [blame]
khenaidoo9a468962018-09-19 15:33:13 -04001#
2# Copyright 2018 the original author or authors.
3#
4# Licensed under the Apache License, Version 2.0 (the "License");
5# you may not use this file except in compliance with the License.
6# You may obtain a copy of the License at
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS,
12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15#
16
17ifneq ($(VOLTHA_BUILD),docker)
18ifeq ($(VOLTHA_BASE)_set,_set)
19$(error To get started, please source the env.sh file)
20endif
21endif
22
23ifeq ($(TAG),)
24TAG := latest
25endif
26
27ifeq ($(TARGET_TAG),)
28TARGET_TAG := latest
29endif
30
31# If no DOCKER_HOST_IP is specified grab a v4 IP address associated with
32# the default gateway
33ifeq ($(DOCKER_HOST_IP),)
34DOCKER_HOST_IP := $(shell ifconfig $$(netstat -rn | grep -E '^(default|0.0.0.0)' | head -1 | awk '{print $$NF}') | grep inet | awk '{print $$2}' | sed -e 's/addr://g')
35endif
36
37ifneq ($(http_proxy)$(https_proxy),)
38# Include proxies from the environment
39DOCKER_PROXY_ARGS = \
40 --build-arg http_proxy=$(http_proxy) \
41 --build-arg https_proxy=$(https_proxy) \
42 --build-arg ftp_proxy=$(ftp_proxy) \
43 --build-arg no_proxy=$(no_proxy) \
44 --build-arg HTTP_PROXY=$(HTTP_PROXY) \
45 --build-arg HTTPS_PROXY=$(HTTPS_PROXY) \
46 --build-arg FTP_PROXY=$(FTP_PROXY) \
47 --build-arg NO_PROXY=$(NO_PROXY)
48endif
49
50DOCKER_BUILD_ARGS = \
51 --build-arg TAG=$(TAG) \
52 --build-arg REGISTRY=$(REGISTRY) \
53 --build-arg REPOSITORY=$(REPOSITORY) \
54 $(DOCKER_PROXY_ARGS) $(DOCKER_CACHE_ARG) \
55 --rm --force-rm \
56 $(DOCKER_BUILD_EXTRA_ARGS)
57
58VENVDIR := venv-$(shell uname -s | tr '[:upper:]' '[:lower:]')
59
60DOCKER_IMAGE_LIST = \
61 base \
62 protoc \
63 protos \
64 adapter-ponsim-olt \
65 adapter-ponsim-onu \
66
67# The following list was scavanged from the compose / stack files as well as
68# from the Dockerfiles. If nothing else it highlights that VOLTHA is not
69# using consistent versions for some of the containers.
70
71FETCH_BUILD_IMAGE_LIST = \
72 alpine:3.6 \
73 centos:7 \
74 centurylink/ca-certs:latest \
75 grpc/python:latest \
76 ubuntu:xenial
77
78FETCH_COMPOSE_IMAGE_LIST = \
79 wurstmeister/kafka:latest \
80 wurstmeister/zookeeper:latest
81
82# find k8s -type f | xargs grep image: | awk '{print $NF}' | sed -e 's/\"//g' | sed '/:.*$/!s/$/:latest/g' | sort -u | sed -e 's/^/ /g' -e 's/$/ \\/g'
83# Manually remove some image from this list as they don't reflect the new
84# naming conventions for the VOLTHA build
85FETCH_K8S_IMAGE_LIST = \
86 wurstmeister/kafka:1.0.0 \
87 zookeeper:3.4.11
88
89FETCH_IMAGE_LIST = $(shell echo $(FETCH_BUILD_IMAGE_LIST) $(FETCH_COMPOSE_IMAGE_LIST) $(FETCH_K8S_IMAGE_LIST) | tr ' ' '\n' | sort -u)
90
91.PHONY: $(DIRS) $(DIRS_CLEAN) $(DIRS_FLAKE8) flake8 base ponsim_olt ponsim_onu protos kafka common start stop tag push pull
92
93# This should to be the first and default target in this Makefile
94help:
95 @echo "Usage: make [<target>]"
96 @echo "where available targets are:"
97 @echo
98 @echo "build : Build the Adapters protos and docker images.\n\
99 If this is the first time you are building, choose \"make build\" option."
100 @echo "clean : Remove files created by the build and tests"
101 @echo "distclean : Remove venv directory"
102 @echo "fetch : Pre-fetch artifacts for subsequent local builds"
103 @echo "help : Print this help"
104 @echo "protoc : Build a container with protoc installed"
105 @echo "protos : Compile all grpc/protobuf files"
106 @echo "rebuild-venv : Rebuild local Python virtualenv from scratch"
107 @echo "venv : Build local Python virtualenv if did not exist yet"
108 @echo "containers : Build all the docker containers"
109 @echo "base : Build the base docker container used by all other dockers"
110 @echo "adapter_ponsim_olt : Build the ponsim olt adapter docker container"
111 @echo "adapter_ponsim_onu : Build the ponsim olt adapter docker container"
112 @echo "tag : Tag a set of images"
113 @echo "push : Push the docker images to an external repository"
114 @echo "pull : Pull the docker images from a repository"
115 @echo
116
117## New directories can be added here
118#DIRS:=
119
120## If one directory depends on another directory that
121## dependency can be expressed here
122##
123## For example, if the Tibit directory depended on the eoam
124## directory being built first, then that can be expressed here.
125## driver/tibit: eoam
126
127# Parallel Build
128$(DIRS):
129 @echo " MK $@"
130 $(Q)$(MAKE) -C $@
131
132# Parallel Clean
133DIRS_CLEAN = $(addsuffix .clean,$(DIRS))
134$(DIRS_CLEAN):
135 @echo " CLEAN $(basename $@)"
136 $(Q)$(MAKE) -C $(basename $@) clean
137
138# Parallel Flake8
139DIRS_FLAKE8 = $(addsuffix .flake8,$(DIRS))
140$(DIRS_FLAKE8):
141 @echo " FLAKE8 $(basename $@)"
142 -$(Q)$(MAKE) -C $(basename $@) flake8
143
144build: protoc protos containers
145
146containers: base adapter_ponsim_olt adapter_ponsim_onu
147
148base:
149 docker build $(DOCKER_BUILD_ARGS) -t ${REGISTRY}${REPOSITORY}voltha-base:${TAG} -f docker/Dockerfile.base .
150
151adapter_ponsim_olt:
152 docker build $(DOCKER_BUILD_ARGS) -t ${REGISTRY}${REPOSITORY}voltha-adapter-ponsim-olt:${TAG} -f docker/Dockerfile.adapter_ponsim_olt .
153
154adapter_ponsim_onu:
155 docker build $(DOCKER_BUILD_ARGS) -t ${REGISTRY}${REPOSITORY}voltha-adapter-ponsim-onu:${TAG} -f docker/Dockerfile.adapter_ponsim_onu .
156
157tag: $(patsubst %,%.tag,$(DOCKER_IMAGE_LIST))
158
159push: tag $(patsubst %,%.push,$(DOCKER_IMAGE_LIST))
160
161pull: $(patsubst %,%.pull,$(DOCKER_IMAGE_LIST))
162
163%.tag:
164 docker tag ${REGISTRY}${REPOSITORY}voltha-$(subst .tag,,$@):${TAG} ${TARGET_REGISTRY}${TARGET_REPOSITORY}voltha-$(subst .tag,,$@):${TARGET_TAG}
165
166%.push:
167 docker push ${TARGET_REGISTRY}${TARGET_REPOSITORY}voltha-$(subst .push,,$@):${TARGET_TAG}
168
169%.pull:
170 docker pull ${REGISTRY}${REPOSITORY}voltha-$(subst .pull,,$@):${TAG}
171
172protoc:
173ifeq ($(VOLTHA_BUILD),docker)
174 docker build $(DOCKER_BUILD_ARGS) -t ${REGISTRY}${REPOSITORY}voltha-protoc:${TAG} -f docker/Dockerfile.protoc .
175endif
176
177protos:
178ifneq ($(VOLTHA_BUILD),docker)
179 make -C protos
180else
181 docker build $(DOCKER_BUILD_ARGS) -t ${REGISTRY}${REPOSITORY}voltha-protos:${TAG} -f docker/Dockerfile.protos .
182endif
183
184install-protoc:
185 make -C voltha/protos install-protoc
186
187clean:
188 find voltha -name '*.pyc' | xargs rm -f
189
190distclean: clean
191 rm -rf ${VENVDIR}
192
193fetch:
194 @bash -c ' \
195 for i in $(FETCH_IMAGE_LIST); do \
196 docker pull $$i; \
197 done'
198
199purge-venv:
200 rm -fr ${VENVDIR}
201
202rebuild-venv: purge-venv venv
203
204ifneq ($(VOLTHA_BUILD),docker)
205venv: ${VENVDIR}/.built
206else
207venv:
208endif
209
210${VENVDIR}/.built:
211 @ virtualenv ${VENVDIR}
212 @ . ${VENVDIR}/bin/activate && \
213 pip install --upgrade pip; \
214 if ! pip install -r requirements.txt; \
215 then \
216 echo "On MAC OS X, if the installation failed with an error \n'<openssl/opensslv.h>': file not found,"; \
217 echo "see the BUILD.md file for a workaround"; \
218 else \
219 uname -s > ${VENVDIR}/.built; \
220 fi
221
222
223flake8: $(DIRS_FLAKE8)
224
225# end file