components/openstack/horizon/Makefile
branchs11-update
changeset 4072 db0cec748ec0
parent 3996 20c0f21bbe1e
child 4625 18adb92d4193
--- a/components/openstack/horizon/Makefile	Tue Apr 07 15:49:29 2015 -0700
+++ b/components/openstack/horizon/Makefile	Tue Apr 07 13:31:20 2015 -0700
@@ -22,22 +22,184 @@
 #
 # Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved.
 #
+
 include ../../../make-rules/shared-macros.mk
+include ../../../make-rules/shared-targets.mk
+
+PATCH_EACH_ARCHIVE = 1
 
 COMPONENT_NAME=		horizon
-COMPONENT_CODENAME=	havana
-COMPONENT_VERSION=	2013.2.3
+COMPONENT_CODENAME=	juno
+COMPONENT_VERSION=	2014.2.2
+COMPONENT_BE_VERSION=	2014.2
 COMPONENT_SRC=		$(COMPONENT_NAME)-$(COMPONENT_VERSION)
 COMPONENT_ARCHIVE=	$(COMPONENT_SRC).tar.gz
 COMPONENT_ARCHIVE_HASH=	\
-    sha256:de9b87ee62d8b28792399be0fc867ba99618eaaad289cf9842b5c7084e12620f
+    sha256:f639cdb8fc7fd26725d689d42c426f09bbd5a77554910800b1315f182879558e
 COMPONENT_ARCHIVE_URL=	http://launchpad.net/$(COMPONENT_NAME)/$(COMPONENT_CODENAME)/$(COMPONENT_VERSION)/+download/$(COMPONENT_ARCHIVE)
 COMPONENT_PROJECT_URL=	http://www.openstack.org/
-COMPONENT_BUGDB=	service/horizon 
-IPS_COMPONENT_VERSION=  0.$(COMPONENT_VERSION)
+COMPONENT_BUGDB=	service/horizon
+IPS_COMPONENT_VERSION=	0.$(COMPONENT_VERSION)
+COMPONENT_PATCHES=	\
+	01-osprofiler.patch \
+	02-change-angular-imports.patch \
+	03-remove-qunit.patch \
+	04-remove-jasmine.patch \
+	05-disable-unsupported-bootsource.patch \
+	06-remove-security-groups.patch \
+	07-remove-image-source.patch \
+	08-_get_reachable_subnets.patch \
+	11-requirements.patch
+
+TPNO_HORIZON=		21822
+TPNO_ANGULAR=		21640
+TPNO_BOOTSTRAP_DP=	20670
+TPNO_BOOTSTRAP_SCSS=	20671
+TPNO_D3=		20822
+TPNO_FONT_AWESOME=	21641
+TPNO_HOGAN=		21827
+TPNO_JQUERY=		21642
+TPNO_JQUERY_MIGRATE=	13315
+TPNO_JQUERY_UI=		18416
+TPNO_JQUERY_QUICKSEARCH=20396
+TPNO_JQUERY_TABLESORTER=20824
+TPNO_JSENCRYPT=		20397
+TPNO_RICKSHAW=		20673
+TPNO_SPIN=		20674
+
+NUM_EXTRA_ARCHIVES=	1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
+
+#
+# Starting with Juno, Horizon depends on a number of XStatic modules
+# to deliver the required JavaScript modules.  This delivery method
+# may be changing in future releases, so the XStatic modules for now
+# are built as part of Horizon rather than being stand alone
+# components/packages.  The NUM_EXTRA_ARCHIVES parameter should
+# enumerate the numbers of all the extra XStatic archives to be
+# included in the Horizon build.
+#
+# XStatic itself is only used during the build process and so while it
+# is downloaded and installed in the proto area, none of its
+# components are delivered in the Horizon package itself.
+#
+COMPONENT_NAME_1 =	XStatic
+VERSION_XSTATIC =	1.0.1
+COMPONENT_ARCHIVE_1 =	XStatic-$(VERSION_XSTATIC).tar.gz
+COMPONENT_ARCHIVE_HASH_1 = \
+	sha256:0ec93d7c66ebb9e0d31b664753437dc8634cb66e13310cb47c9eb1e0bc66d726
+COMPONENT_ARCHIVE_URL_1 = $(call pypi_url,1)
+
+COMPONENT_NAME_2 =	XStatic-Angular
+VERSION_ANGULAR =	1.3.7.0
+COMPONENT_ARCHIVE_2 =	XStatic-Angular-$(VERSION_ANGULAR).tar.gz
+COMPONENT_ARCHIVE_HASH_2 = \
+	sha256:7cad216b226399cbe8d2909ed5b9f28d724907b9c9e1e078e6e25d320a3d5dd7
+COMPONENT_ARCHIVE_URL_2 = $(call pypi_url,2)
+PKG_MACROS +=		VERSION_ANGULAR=$(VERSION_ANGULAR)
+
+COMPONENT_NAME_3 =	XStatic-Bootstrap-Datepicker
+VERSION_BOOTSTRAP_DP=	1.3.1.0
+COMPONENT_ARCHIVE_3 =	XStatic-Bootstrap-Datepicker-$(VERSION_BOOTSTRAP_DP).tar.gz
+COMPONENT_ARCHIVE_HASH_3 = \
+	sha256:9edc9b77501001fcee9fbf4bf0a722c263efd928ef928b40081a8269fdd9a944
+COMPONENT_ARCHIVE_URL_3 = $(call pypi_url,3)
+PKG_MACROS +=		VERSION_BOOTSTRAP_DP=$(VERSION_BOOTSTRAP_DP)
+
+COMPONENT_NAME_4 =	XStatic-Bootstrap-SCSS
+VERSION_BOOTSTRAP_SCSS=	3.2.0.0
+COMPONENT_ARCHIVE_4 =	XStatic-Bootstrap-SCSS-$(VERSION_BOOTSTRAP_SCSS).tar.gz
+COMPONENT_ARCHIVE_HASH_4 = \
+	sha256:7e9858737e2e6aac921ec7a3fca627e522901c3061611e154ebc0b8a892c7018
+COMPONENT_ARCHIVE_URL_4 = $(call pypi_url,4)
+PKG_MACROS +=		VERSION_BOOTSTRAP_SCSS=$(VERSION_BOOTSTRAP_SCSS)
 
-TPNO_HORIZON=		17862
-TPNO_CSS=		16775
+COMPONENT_NAME_5 =	XStatic-D3
+VERSION_D3 =		3.1.6.2
+COMPONENT_ARCHIVE_5 =	XStatic-D3-$(VERSION_D3).tar.gz
+COMPONENT_ARCHIVE_HASH_5 = \
+	sha256:46fe521f8dad99f5e20f6702180510c37b81d11f1d78119d308fcec31381f90e
+COMPONENT_ARCHIVE_URL_5 = $(call pypi_url,5)
+PKG_MACROS +=		VERSION_D3=$(VERSION_D3)
+
+COMPONENT_NAME_6 =	XStatic-Font-Awesome
+VERSION_FONT_AWESOME =	4.2.0.0
+COMPONENT_ARCHIVE_6 =	XStatic-Font-Awesome-$(VERSION_FONT_AWESOME).tar.gz
+COMPONENT_ARCHIVE_HASH_6 = \
+	sha256:b7fdbf1ed316f3a207eeb9ee1c052820e55b4e31d247d81c8ea059e21f555a73
+COMPONENT_ARCHIVE_URL_6 = $(call pypi_url,6)
+PKG_MACROS +=		VERSION_FONT_AWESOME=$(VERSION_FONT_AWESOME)
+
+COMPONENT_NAME_7 =	XStatic-Hogan
+VERSION_HOGAN =		2.0.0.2
+COMPONENT_ARCHIVE_7 =	XStatic-Hogan-$(VERSION_HOGAN).tar.gz
+COMPONENT_ARCHIVE_HASH_7 = \
+	sha256:5941bc7fb2a09916b8837848e6fc2a13b2dfc271811e9b522c61e1337d5fc2bd
+COMPONENT_ARCHIVE_URL_7 = $(call pypi_url,7)
+PKG_MACROS +=		VERSION_HOGAN=$(VERSION_HOGAN)
+
+COMPONENT_NAME_8 =	XStatic-jQuery
+VERSION_JQUERY =	1.10.2.1
+COMPONENT_ARCHIVE_8 =	XStatic-jQuery-$(VERSION_JQUERY).tar.gz
+COMPONENT_ARCHIVE_HASH_8 = \
+	sha256:83416a6bb86e8534858c4d1ddca45e881c87639da6f78000c28c3a193fe91305
+COMPONENT_ARCHIVE_URL_8 = $(call pypi_url,8)
+PKG_MACROS +=		VERSION_JQUERY=$(VERSION_JQUERY)
+
+COMPONENT_NAME_9 =	XStatic-JQuery-Migrate
+VERSION_JQUERY_MIGRATE=	1.2.1.1
+COMPONENT_ARCHIVE_9 =	XStatic-JQuery-Migrate-$(VERSION_JQUERY_MIGRATE).tar.gz
+COMPONENT_ARCHIVE_HASH_9 = \
+	sha256:e2959b3df49afdddb00d36b74cca727a91b994b9f4edb993d7264731a750900e
+COMPONENT_ARCHIVE_URL_9 = $(call pypi_url,9)
+PKG_MACROS +=		VERSION_JQUERY_MIGRATE=$(VERSION_JQUERY_MIGRATE)
+
+COMPONENT_NAME_10 =	XStatic-jquery-ui
+VERSION_JQUERY_UI =	1.11.0.1
+COMPONENT_ARCHIVE_10 =	XStatic-jquery-ui-$(VERSION_JQUERY_UI).tar.gz
+COMPONENT_ARCHIVE_HASH_10 = \
+	sha256:099b1836eb0d91b8dc98f5b8a6b856a2631d43af0d47f33ef90ee72ed37bda58
+COMPONENT_ARCHIVE_URL_10 = $(call pypi_url,10)
+PKG_MACROS +=		VERSION_JQUERY_UI=$(VERSION_JQUERY_UI)
+
+COMPONENT_NAME_11 =	XStatic-JQuery.quicksearch
+VERSION_JQUERY_QS =	2.0.3.1
+COMPONENT_ARCHIVE_11 =	XStatic-JQuery.quicksearch-$(VERSION_JQUERY_QS).tar.gz
+COMPONENT_ARCHIVE_HASH_11 = \
+	sha256:1271571b420417add56c274fd935e81bfc79e0d54a03559d6ba5ef369f358477
+COMPONENT_ARCHIVE_URL_11 = $(call pypi_url,11)
+PKG_MACROS +=		VERSION_JQUERY_QS=$(VERSION_JQUERY_QS)
+
+COMPONENT_NAME_12 =	XStatic-JQuery.TableSorter
+VERSION_JQUERY_TS =	2.14.5.1
+COMPONENT_ARCHIVE_12 =	XStatic-JQuery.TableSorter-$(VERSION_JQUERY_TS).tar.gz
+COMPONENT_ARCHIVE_HASH_12 = \
+	sha256:3ba24aecd9a3dc71a79dd4096fa5a8a041c3a7b892c61d05e6e46de0605070f0
+COMPONENT_ARCHIVE_URL_12 = $(call pypi_url,12)
+PKG_MACROS +=		VERSION_JQUERY_TS=$(VERSION_JQUERY_TS)
+
+COMPONENT_NAME_13 =	XStatic-JSEncrypt
+VERSION_JSENCRYPT =	2.0.0.2
+COMPONENT_ARCHIVE_13 =	XStatic-JSEncrypt-$(VERSION_JSENCRYPT).tar.gz
+COMPONENT_ARCHIVE_HASH_13 = \
+	sha256:5852892afc6f80c7848f4110b6dad190a54aeb908271d67aaeae9d966f4a26b5
+COMPONENT_ARCHIVE_URL_13 = $(call pypi_url,13)
+PKG_MACROS +=		VERSION_JSENCRYPT=$(VERSION_JSENCRYPT)
+
+COMPONENT_NAME_14 =	XStatic-Rickshaw
+VERSION_RICKSHAW =	1.5.0.0
+COMPONENT_ARCHIVE_14 =	XStatic-Rickshaw-$(VERSION_RICKSHAW).tar.gz
+COMPONENT_ARCHIVE_HASH_14 = \
+	sha256:147574228757254442700a9eea5150f14acb1224ef0612f896b663ab58406de8
+COMPONENT_ARCHIVE_URL_14 = $(call pypi_url,14)
+PKG_MACROS +=		VERSION_RICKSHAW=$(VERSION_RICKSHAW)
+
+COMPONENT_NAME_15 =	XStatic-Spin
+VERSION_SPIN =		1.2.5.2
+COMPONENT_ARCHIVE_15 =	XStatic-Spin-$(VERSION_SPIN).tar.gz
+COMPONENT_ARCHIVE_HASH_15 = \
+	sha256:7f46ef0e45e047019ba6eda22c432fb96f681b97bbe7f1749aa9209e07727192
+COMPONENT_ARCHIVE_URL_15 = $(call pypi_url,15)
+PKG_MACROS +=		VERSION_SPIN=$(VERSION_SPIN)
 
 include $(WS_MAKE_RULES)/prep.mk
 include $(WS_MAKE_RULES)/setup.py.mk
@@ -49,25 +211,117 @@
 # only need to deliver one version.  The manifest is parameterized, though.
 PYTHON_VERSIONS=	2.6
 
+# Django's manage.py needs to be run with Python 2.6, since that's what this
+# ecosystem runs under right now.
+PYTHON_VERSION=		2.6
+
+PKG_MACROS +=		COMPONENT_BE_VERSION=$(COMPONENT_BE_VERSION)
 PKG_MACROS +=		PYVER=$(PYTHON_VERSIONS)
+PKG_MACROS +=		PYV=$(shell echo $(PYTHON_VERSIONS) | tr -d .)
 
+PROTO_PYTHON_LIB =	$(PROTO_DIR)$(PYTHON_LIB)
+
+# Copy the Oracle branding files and Django app customizations into place
+COMPONENT_POST_INSTALL_ACTION += \
+	($(MKDIR) $(PROTO_PYTHON_LIB)/openstack_dashboard/templates/solaris; \
+	 $(CP) files/branding/css/solaris.css \
+	     $(PROTO_PYTHON_LIB)/openstack_dashboard/static/dashboard/css; \
+	 $(CP) files/branding/img/* \
+	     $(PROTO_PYTHON_LIB)/openstack_dashboard/static/dashboard/img; \
+	 $(CP) files/branding/theme/_stylesheets.html \
+	     $(PROTO_PYTHON_LIB)/openstack_dashboard/templates/solaris; \
+	 $(CP) files/overrides.py $(PROTO_PYTHON_LIB)/openstack_dashboard);
+
+# Generate .pyc files for the files in the proto directory
+COMPONENT_POST_INSTALL_ACTION += \
+	$(PYTHON) -m compileall $(PROTO_PYTHON_LIB);
+
+# Collect the JavaScript files and compress the static assets
 COMPONENT_POST_INSTALL_ACTION += \
-	($(MKDIR) $(PROTO_DIR)/usr/lib/python2.6/vendor-packages/openstack_dashboard/static/solaris/css; \
-	 $(CP) files/branding/css/solaris.css $(PROTO_DIR)/usr/lib/python2.6/vendor-packages/openstack_dashboard/static/solaris/css; \
-	 $(MKDIR) $(PROTO_DIR)/usr/lib/python2.6/vendor-packages/openstack_dashboard/static/solaris/img; \
-	 $(CP) files/branding/img/* $(PROTO_DIR)/usr/lib/python2.6/vendor-packages/openstack_dashboard/static/solaris/img; \
-	 $(MKDIR) $(PROTO_DIR)/usr/lib/python2.6/vendor-packages/openstack_dashboard/static/solaris/theme; \
-	 $(CP) files/branding/theme/_stylesheets.html $(PROTO_DIR)/usr/lib/python2.6/vendor-packages/openstack_dashboard/static/solaris/theme; \
-	 $(CP) files/overrides.py $(PROTO_DIR)/usr/lib/python2.6/vendor-packages/openstack_dashboard); \
-	 $(PYTHON) -m compileall $(PROTO_DIR)/$(PYTHON_VENDOR_PACKAGES)
-	
+	(set -e; $(CP) $(SOURCE_DIR)/manage.py \
+	     $(PROTO_PYTHON_LIB)/openstack_dashboard; \
+	 $(TOUCH) $(PROTO_PYTHON_LIB)/xstatic/__init__.py; \
+	 $(TOUCH) $(PROTO_PYTHON_LIB)/xstatic/pkg/__init__.py; \
+	 cd $(PROTO_PYTHON_LIB)/openstack_dashboard; \
+	 $(ENV) PYTHONPATH=$(PROTO_PYTHON_LIB) ./manage.py \
+	     collectstatic --noinput; \
+	 $(ENV) PYTHONPATH=$(PROTO_PYTHON_LIB) ./manage.py compress --force; \
+	 $(CP) -R $(PROTO_PYTHON_LIB)/static \
+	     $(PROTO_PYTHON_LIB)/openstack_dashboard; \
+	 $(RM) -r \
+	     $(PROTO_PYTHON_LIB)/XStatic* \
+	     $(PROTO_PYTHON_LIB)/openstack_dashboard/local/.secret_key_store \
+	     $(PROTO_PYTHON_LIB)/openstack_dashboard/manage.py \
+	     $(PROTO_PYTHON_LIB)/static \
+	     $(PROTO_PYTHON_LIB)/xstatic); (( $$? )) && exit 1;
+
+# Patch openstack_dashboard/settings.py to remove the xstatic imports
+# and use.  This is done after 'gmake prep' because we need the
+# xstatic imports for static asset collection.
+COMPONENT_POST_INSTALL_ACTION += \
+	 $(GPATCH) -d $(PROTO_DIR) $(GPATCH_FLAGS) \
+	     < patches/99-remove.xstatic.patch
+
+#
+# The xstatic target builds each XStatic component alongside Horizon.
+# This is done because the Django script which collects
+# the JavaScript libraries and compresses the static assets
+# (manage.py) requires the packages be "installed".  Rather than
+# forcing a CBE update for any revision of any XStatic module, we use
+# what's specified above.
+#
+# This extra work is done at package build time rather than when the
+# application runs because a) compressing the assets ahead of time
+# makes things faster and b) this allows the package to be entirely
+# contained in /usr rather than having a separate spot in /var for the
+# webservd user to write compressed assets to as they get used.
+#
+.PHONY:	xstatic
+xstatic:	$(PROTO_DIR) build
+	for xs_archive in $$(ls -d XStatic-* | grep -v .tar.gz); do \
+		cd $$xs_archive; \
+		$(ENV) $(PYTHON.$(BITS)) ./setup.py build; \
+		$(ENV) $(PYTHON.$(BITS)) ./setup.py install \
+		    --force \
+		    --install-data=$(PYTHON_DATA) \
+		    --install-lib=$(PYTHON_LIB) \
+		    --install-platlib=$(PYTHON_LIB) \
+		    --install-purelib=$(PYTHON_LIB) \
+		    --root $(PROTO_DIR); \
+		cd ../; \
+	done
+
 # common targets
 build:		$(BUILD_NO_ARCH)
 
-install:	$(INSTALL_NO_ARCH)
+# make sure all of the xstatic modules are built
+install:	$(INSTALL_NO_ARCH) xstatic
 
 test:		$(NO_TESTS)
 
+clean::
+	gfind $(COMPONENT_DIR) -maxdepth 1 -type d -name "XStatic*" \
+	    -exec rm -r {} \;
 
-REQUIRED_PACKAGES += library/python/eventlet-26
+
+# Packages required by Django's manage.py during the Horizon build
+REQUIRED_PACKAGES += library/python/babel-26
+REQUIRED_PACKAGES += library/python/ceilometerclient-26
+REQUIRED_PACKAGES += library/python/cinderclient-26
+REQUIRED_PACKAGES += library/python/django-26
+REQUIRED_PACKAGES += library/python/django-pyscss-26
+REQUIRED_PACKAGES += library/python/django_compressor-26
+REQUIRED_PACKAGES += library/python/django_openstack_auth-26
+REQUIRED_PACKAGES += library/python/glanceclient-26
+REQUIRED_PACKAGES += library/python/heatclient-26
+REQUIRED_PACKAGES += library/python/iso8601-26
+REQUIRED_PACKAGES += library/python/keystoneclient-26
+REQUIRED_PACKAGES += library/python/lockfile-26
+REQUIRED_PACKAGES += library/python/neutronclient-26
+REQUIRED_PACKAGES += library/python/novaclient-26
 REQUIRED_PACKAGES += library/python/oslo.config-26
+REQUIRED_PACKAGES += library/python/requests-26
+REQUIRED_PACKAGES += library/python/saharaclient-26
+REQUIRED_PACKAGES += library/python/six-26
+REQUIRED_PACKAGES += library/python/swiftclient-26
+REQUIRED_PACKAGES += library/python/troveclient-26