forked from pixie-io/pixie
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhelm_build_release.sh
executable file
·68 lines (54 loc) · 2.06 KB
/
helm_build_release.sh
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
#!/usr/bin/env bash
# Copyright 2018- The Pixie Authors.
#
# 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.
#
# SPDX-License-Identifier: Apache-2.0
set -ex
usage() {
echo "Usage: $0 <version> <yaml_tar>"
echo "Example: $0 0.1.2 /tmp/yamls.tar"
}
parse_args() {
if [ $# -lt 2 ]; then
usage
fi
VERSION=$1
YAML_TAR=$2
}
parse_args "$@"
helm_gcs_bucket="pixie-helm-charts"
tmp_path="/tmp/helm-${VERSION}"
tmp_dir="$(mktemp -d)"
repo_path=$(pwd)
mkdir -p "${tmp_path}"
# A Helm chart contains two main items:
# 1. Chart.yaml which specifies the version and name of the chart.
# 2. `templates` directory, which contains the template YAMLs that should be filled out.
# Create Chart.yaml for this release.
echo "apiVersion: v2
name: pixie-chart
type: application
version: ${VERSION}" > "${tmp_path}/Chart.yaml"
# Extract templated YAMLs.
tar xvf "${YAML_TAR}" -C "${tmp_dir}"
mv "${tmp_dir}/pixie_yamls" "${tmp_path}/templates"
# Fetch all of the current charts in GCS, because generating the index needs all pre-existing tar versions present.
mkdir -p "${tmp_dir}/${helm_gcs_bucket}"
gsutil rsync "gs://${helm_gcs_bucket}" "${tmp_dir}/${helm_gcs_bucket}"
# Generates tgz for the new release helm chart.
helm package "${tmp_path}" -d "${tmp_dir}/${helm_gcs_bucket}"
# Update the index file.
helm repo index "${tmp_dir}/${helm_gcs_bucket}" --url "https://${helm_gcs_bucket}.storage.googleapis.com"
# Upload the new index and tar to gcs by syncing. This will help keep the timestamps for pre-existing tars the same.
gsutil rsync "${tmp_dir}/${helm_gcs_bucket}" "gs://${helm_gcs_bucket}"