aboutsummaryrefslogtreecommitdiffstats
path: root/build/f_isoroot/f_kvm-pluginbuild/Makefile
blob: 81309ef87da7dbe417f8a135783546d351449604 (plain)
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
##############################################################################
# Copyright (c) 2015 Ericsson AB and others.
# jonas.bjurel@eicsson.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
##############################################################################

TOP := $(shell pwd)

############################################################################
# BEGIN of Include definitions
#
include config.mk
#
# END Include definitions
#############################################################################

.PHONY: all
all: .kvmbuild

.PHONY: clean
clean:
	@rm -f .kvmbuild ../release/opnfv/fuel-plugin-kvm*.rpm fuel-plugin-kvm*.rpm
	@rm -f $(BUILD_BASE)/gitinfo_kvm-plugin.txt gitinfo_kvm-plugin.txt

.PHONY: release
release:.kvmbuild
	@rm -f ../release/opnfv/fuel-plugin-kvm*.rpm
	@mkdir -p ../release/opnfv
	@cp fuel-plugin-kvm*.rpm ../release/opnfv/
	cp gitinfo_kvm-plugin.txt $(BUILD_BASE)

.kvmbuild:
	@rm -rf kvmfornfv
	../../docker/ubuntu-builder/install_docker.sh
	git clone $(KVMFORNFV_REPO)
	cd kvmfornfv; \
	git checkout $(KVMFORNFV_BRANCH); \
	if [ ! -z $(KVMFORNFV_CHANGE) ]; then \
	   git fetch $(KVMFORNFV_REPO) $(KVMFORNFV_CHANGE); \
	   git checkout FETCH_HEAD; \
	fi
	cd kvmfornfv/fuel-plugin; \
	INCLUDE_DEPENDENCIES=true fpb --debug --build ./
	@mv kvmfornfv/fuel-plugin/fuel-plugin-kvm*.rpm .
	$(REPOINFO) -r . > gitinfo_kvm-plugin.txt
	@rm -rf kvmfornfv
	@touch .kvmbuild
	# Store artifact in cache straight away if caching is enabled
	# (no .cacheid will be present unless this is a cached build)
	test -f .cacheid && $(MAKE) -f Makefile put-cache || exit 0

#############################################################################
# Cache operations - only used when building through ci/build.sh
#############################################################################


# Create a unique hash to be used for getting and putting cache, based on:
#   - The SHA1 hash of the HEAD on the plugin repo's $(KVMFORNFV_BRANCH)
#   - The contents of this Makefile
.cacheid:
	@if [ ! -z $(KVMFORNFV_CHANGE) ]; then \
	  $(CACHETOOL) getcommitid $(KVMFORNFV_REPO) $(KVMFORNFV_CHANGE) > .cachedata; \
	else \
	  $(CACHETOOL) getcommitid $(KVMFORNFV_REPO) $(KVMFORNFV_BRANCH) > .cachedata; \
	fi
	@sha1sum Makefile | awk {'print $$1'} >> .cachedata
	@sha1sum config.mk | awk {'print $$1'} >> .cachedata
	@echo -n $(UBUNTU_ARCH) | sha1sum | awk {'print $$1'} >> .cachedata
	@cat .cachedata | $(CACHETOOL) getid > .cacheid

# Clean local data related to caching - called prior to ordinary build
.PHONY: clean-cache
clean-cache: clean
	@rm -f .cachedata .cacheid

# Try to download cache - called prior to ordinary build
.PHONY: get-cache
get-cache: .cacheid
	@if $(CACHETOOL) check $(shell cat .cacheid); then \
		 $(CACHETOOL) get $(shell cat .cacheid) | tar xf -;\
	else \
		echo "No cache item found for $(shell cat .cacheid)" ;\
		exit 0;\
	fi

# Store cache if not already stored - called after ordinary build
.PHONY: put-cache
put-cache: .cacheid
	@tar cf - .kvmbuild fuel-plugin-kvm*.rpm gitinfo_kvm-plugin.txt | $(CACHETOOL) put $(shell cat .cacheid)
re OPNFV with its dependencies. **Release Notes**: :code:`<repo>/docs/release/release-notes` - Changes brought about in the release cycle. - Include version details. Testing documentation ^^^^^^^^^^^^^^^^^^^^^ Documentation created by test projects can be stored under two different sub directories /user or /developemnt. Release notes will be stored under <repo>/docs/release/release-notes **User documentation**: :code:`<repo>/testing/user/` Will collect the documentation of the test projects allowing the end user to perform testing towards a OPNFV SUT e.g. Functest/Yardstick/Vsperf/Storperf/Bottlenecks/Qtip installation/config & user guides. **Development documentation**: :code:`<repo>/testing/developent/` Will collect documentation to explain how to create your own test case and leverage existing testing frameworks e.g. developer guides. Development Documentation ^^^^^^^^^^^^^^^^^^^^^^^^^ Project specific documents such as design documentation, project overview or requirement documentation can be stored under /docs/development. Links to generated documents will be dislayed under Development Documentaiton section on docs.opnfv.org. You are encouraged to establish the following basic structure for your project as needed: **Requirement Documentation**: :code:`<repo>/docs/development/requirements/` - Folder for your requirement documentation - For details on requirements projects' structures see the `Requirements Projects <https://wiki.opnfv.org/display/PROJ/Requirements+Projects>`_ page. **Design Documentation**: :code:`<repo>/docs/development/design` - Folder for your upstream design documents (blueprints, development proposals, etc..) **Project overview**: :code:`<repo>/docs/development/overview` - Folder for any project specific documentation.