diff options
author | Jonas Bjurel <jonas.bjurel@ericsson.com> | 2015-01-30 22:22:43 +0100 |
---|---|---|
committer | Jonas Bjurel <jonas.bjurel@ericsson.com> | 2015-02-05 19:39:31 +0100 |
commit | d29df40fd66d6a90fde858e8a0bc0d0e98a01794 (patch) | |
tree | 17e48a2b5978b21c5a44ac0234626e8bb39c0af3 /fuel-build/Makefile | |
parent | 09247c2eca21891be5b04eda08a23d4a866a3b84 (diff) |
Version 0.0.1 of /fuel-bild
This is a build system that rebases the result from fuel.org such that you can add or change
packages/puppet manifests any way you like, and reliably produce a installable which can
be reproduced any time. See README for more information.
Signed-off-by: Jonas Bjurel <jonas.bjurel@ericsson.com>
Diffstat (limited to 'fuel-build/Makefile')
-rw-r--r-- | fuel-build/Makefile | 126 |
1 files changed, 126 insertions, 0 deletions
diff --git a/fuel-build/Makefile b/fuel-build/Makefile new file mode 100644 index 0000000..ea403c8 --- /dev/null +++ b/fuel-build/Makefile @@ -0,0 +1,126 @@ +############################################################################## +# Copyright (c) 2015 Ericsson AB and others. +# stefan.k.berg@ericsson.com +# jonas.bjurel@ericsson.com +# All rights reserved. This program and the accompanying materials +# are made available under the terms of the Apache License, Version 2.0 +# which accompanies this distribution, and is available at +# http://www.apache.org/licenses/LICENSE-2.0 +############################################################################## + +############################################################################ +# BEGIN of variables to customize +# +SHELL = /bin/bash + + +ISOSRC = file:$(shell pwd)/fuel-5.1.1.iso +ISOCACHE = $(shell pwd)/$(shell basename $(ISOSRC)) +PRODUCT_NAME = "OPNFV_BGS" +VERSION = "P0000" +NEWISO = $(shell pwd)/release/opnfv-${VERSION}.iso +DOCKERIMG = opnfv.org/ubuntu-builder:12.04 +# Note! Invoke with "make VERSION=RXXXX iso" to make release build! +# Invoke with ICOCACHE=/full/path/to/iso if cached ISO is in non-standard location. +# +# END of variables to customize +############################################################################# +ORIGDIR = $(shell pwd)/origiso + +SUBDIRS := f_isoroot +SUBDIRS += f_opnfv_puppet +SUBDIRS += f_osnaily +SUBDIRS += f_l23network +SUBDIRS += f_resolvconf +SUBDIRS += f_ntp + +# f_example is only an example of how to generate a .deb package and +# should not be enabled in official builds. +#SUBDIRS += f_example + +SUBCLEAN = $(addsuffix .clean,$(SUBDIRS)) + +.PHONY: all +all: + @docker version >/dev/null 2>&1 || (echo 'No Docker installation available'; exit 1) + make -C docker + @docker/runcontext $(DOCKERIMG) $(MAKE) $(MAKEFLAGS) iso + +$(ISOCACHE): + # Clone Fuel + sudo rm -rf fuel-main + git clone https://github.com/stackforge/fuel-main + cd fuel-main && git checkout 5.1.1 + # Setup cgroups for docker-in-docker + sudo /root/enable_dockerx2 + # Need to patch to fix race condition in build + cd fuel-main && patch -p1 < ../fuel-main.patches + # + cd fuel-main && ./prepare-build-env.sh + # Need to patch not supported start-stop-daemon argument + sudo sed -i 's/--no-close//' /etc/init.d/docker + sudo /etc/init.d/docker start + cd fuel-main && make iso + mv fuel-main/build/artifacts/fuel*.iso . + # Remove Fuel + sudo rm -rf fuel-main + +# Used the "docker" target to build within the context of the Docker +# container created by the Makefile in the docker subdirectory. +.PHONY: docker +docker: /.dockerinit + +/.dockerinit: + docker/runcontext $(DOCKERIMG) $(MAKE) $(MAKEFLAGS) + +.PHONY: get-iso mount-origiso umount-origiso +mount-origiso: + @echo "Mounting original ISO in $(ORIGDIR)" + @mkdir -p $(ORIGDIR) + @fuseiso $(ISOCACHE) $(ORIGDIR) + +umount-origiso: + @echo "Unmounting original ISO from $(ORIGDIR)" + @fusermount -u $(ORIGDIR) + @rmdir $(ORIGDIR) + +get-iso: + wget $(ISOSRC) -O $(ISOCACHE) + + + @echo "ISO data of source ISO:" >> release/.isodata + @isoinfo -d -i $(ISOCACHE) >> release/.isodata + +.PHONY: $(SUBDIRS) +$(SUBDIRS): + @mkdir -p release/packages/ubuntu/pool/main release/puppet/modules release/isoroot + $(MAKE) -C $@ -f Makefile release + +.PHONY: patch-packages +patch-packages: + ORIGISO=$(ISOCACHE) VERSION=$(VERSION) $(MAKE) -C $@ -f Makefile release + +.PHONY: clean $(SUBCLEAN) +clean: $(SUBCLEAN) + $(MAKE) -C patch-packages -f Makefile clean + @rm -Rf release + @rm -Rf newiso + @rm -f $(NEWISO) + +$(SUBCLEAN): %.clean: + $(MAKE) -C $* -f Makefile clean + +.PHONY: install +install:$(SUBDIRS) patch-packages + install/install.sh live + +.PHONY: uninstall +uninstall: + install/uninstall.sh + +# Todo: Make things smarter - we shouldn't need to clean everything +# betwen make invocations. +.PHONY: iso +iso: clean $(ISOCACHE) $(SUBDIRS) patch-packages + install/install.sh iso $(ISOCACHE) $(NEWISO) $(PRODUCT_NAME) $(VERSION) + @printf "\n\nProduct ISO is $(NEWISO)\n\n" |