summaryrefslogtreecommitdiffstats
path: root/fuel-build/Makefile
diff options
context:
space:
mode:
authorJonas Bjurel <jonas.bjurel@ericsson.com>2015-01-30 22:22:43 +0100
committerJonas Bjurel <jonas.bjurel@ericsson.com>2015-02-05 19:39:31 +0100
commitd29df40fd66d6a90fde858e8a0bc0d0e98a01794 (patch)
tree17e48a2b5978b21c5a44ac0234626e8bb39c0af3 /fuel-build/Makefile
parent09247c2eca21891be5b04eda08a23d4a866a3b84 (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/Makefile126
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"