From 63230b9f6b9fd10530bf1993f5d45ed7568a9450 Mon Sep 17 00:00:00 2001 From: Dimitrios Markou Date: Mon, 26 Nov 2018 14:56:04 -0600 Subject: [PATCH] Create Makefile target to install Helm binary In Makefile there is no target which actually installs Helm binary. Change-Id: Idca3ed4d0c6d8734b7b6bcfc9d8a1ba9e50693ee Signed-off-by: Dimitrios Markou --- Makefile | 19 +++++++++++++------ tools/helm_install.sh | 44 +++++++++++++++++++++++++++++++++++++++++++ tools/helm_tk.sh | 13 ++++++++++--- 3 files changed, 67 insertions(+), 9 deletions(-) create mode 100755 tools/helm_install.sh diff --git a/Makefile b/Makefile index 98932eb..6366364 100644 --- a/Makefile +++ b/Makefile @@ -12,12 +12,15 @@ # See the License for the specific language governing permissions and # limitations under the License. -HELM := helm -TASK := build +BUILD_DIR := $(shell mkdir -p build && mktemp -d -p build) +HELM := $(shell realpath $(BUILD_DIR))/helm +TASK := build -EXCLUDES := helm-toolkit docs tests tools logs -CHARTS := $(filter-out $(EXCLUDES), $(patsubst %/.,%,$(wildcard */.))) -CHART := divingbell +EXCLUDES := helm-toolkit docs tests tools logs +CHARTS := $(filter-out $(EXCLUDES), $(patsubst %/.,%,$(wildcard */.))) +CHART := divingbell + +export all: $(CHART) @@ -26,7 +29,7 @@ $(CHART): @echo "===== Processing [$@] chart =====" @make $(TASK)-$@ -init-%: clean +init-%: clean helm-install DEP_UP_LIST=$* tools/helm_tk.sh $(HELM) lint-%: init-% @@ -62,3 +65,7 @@ docs: clean build_docs .PHONY: build_docs build_docs: tox -e docs + +.PHONY: helm-install +helm-install: + tools/helm_install.sh $(HELM) diff --git a/tools/helm_install.sh b/tools/helm_install.sh new file mode 100755 index 0000000..e561655 --- /dev/null +++ b/tools/helm_install.sh @@ -0,0 +1,44 @@ +#!/bin/bash +# Copyright 2018 AT&T Intellectual Property. All other rights reserved. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# + +set -x + +HELM=$1 +HELM_ARTIFACT_URL=${HELM_ARTIFACT_URL:-"https://storage.googleapis.com/kubernetes-helm/helm-v2.10.0-linux-amd64.tar.gz"} + + +function install_helm_binary { + if [[ -z "${HELM}" ]] + then + echo "No Helm binary target location." + exit -1 + fi + + if [[ -w "$(dirname ${HELM})" ]] + then + TMP_DIR=${BUILD_DIR:-$(mktemp -d)} + curl -o "${TMP_DIR}/helm.tar.gz" "${HELM_ARTIFACT_URL}" + pushd ${TMP_DIR} + tar -xvzf helm.tar.gz + cp "linux-amd64/helm" "helm" + popd + else + echo "Cannot write to ${HELM}" + exit -1 + fi +} + +install_helm_binary diff --git a/tools/helm_tk.sh b/tools/helm_tk.sh index 99ac4c0..585c21f 100755 --- a/tools/helm_tk.sh +++ b/tools/helm_tk.sh @@ -18,6 +18,8 @@ HELM=$1 HTK_REPO=${HTK_REPO:-"https://github.com/openstack/openstack-helm-infra"} HTK_PATH=${HTK_PATH:-""} +HTK_STABLE_COMMIT=${HTK_COMMIT:-"2fce7e821201a5f578331370703e164d5a932fcc"} +BUILD_DIR=${BUILD_DIR:-$(mktemp -d)} DEP_UP_LIST=${DEP_UP_LIST:-"divingbell"} if [[ ! -z $(echo $http_proxy) ]] @@ -31,7 +33,7 @@ function helm_serve { if [[ -d "$HOME/.helm" ]]; then echo ".helm directory found" else - ${HELM} init --client-only + ${HELM} init --client-only --skip-refresh fi if [[ -z $(curl -s 127.0.0.1:8879 | grep 'Helm Repository') ]]; then ${HELM} serve & > /dev/null @@ -54,10 +56,15 @@ mkdir -p build pushd build git clone --depth 1 $HTK_REPO || true pushd ${HTK_REPO##*/}/$HTK_PATH +git reset --hard "${HTK_STABLE_COMMIT}" -git pull -make helm-toolkit helm_serve +if [[ ${HELM} != "helm" ]] +then + export PATH=${PATH}:$(dirname ${HELM}) +fi + +make helm-toolkit popd && popd for c in $DEP_UP_LIST