-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathdeploy_epoxy_components.sh
executable file
·85 lines (74 loc) · 2.9 KB
/
deploy_epoxy_components.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
#!/bin/bash
#
# deploy.sh copies files and build artifacts from the local directory to a given
# GCS bucket. Copies are authorized using credentials found in the environment
# variable named by the given key name.
#
# deploy.sh is depends on the locations of build artifacts ($PWD/output) and
# action scripts ($PWD/actions).
#
# deploy.sh creates several directories in the given GCS $BUCKET:
#
# - /stage3_coreos
# * coreos initramfs with epoxy_client and custom cloud-config.yaml
# * coreos kernel, stock
# * actions scripts for all stages
#
# - /stage3_update
# * Ubuntu-based initramfs with epoxy_client and update scripts
# * Ubuntu kernel, stock
# * actions scripts for all stages
#
# - /stage3_update_iso
# * stage3 update bootable ISOs for first-time setup. (boot via DRAC)
#
# - /stage1_mlxrom
# * stage1 mellanox ROMs, used by update images
#
# Example:
#
# # After a successful build phase:
# ./deploy.sh SERVICE_ACCOUNT_mlab_sandbox gs://epoxy-mlab-sandbox
set -eux
SOURCE_DIR=$( dirname "${BASH_SOURCE[0]}" )
USAGE="Usage: $0 <keyname> <gs://bucket>"
KEYNAME=${1:?Please provide the service account keyname: $USAGE}
BUCKET=${2:?Please provide the destination GCS bucket name: $USAGE}
# Verify BUCKET is in the correct format.
if [[ ${BUCKET:0:5} != "gs://" ]] ; then
echo "Error: provide the destination GCS bucket in the form: gs://<bucket>"
exit 1
fi
# TODO: use common stage2/ location; do not copy stage2_vmlinuz to stage3 dirs.
# Deploy all stage3_coreos images and actions.
${SOURCE_DIR}/travis/deploy_gcs.sh ${KEYNAME} \
${SOURCE_DIR}/output/stage2_vmlinuz \
${SOURCE_DIR}/output/coreos_custom_pxe_image.cpio.gz \
${SOURCE_DIR}/output/coreos_production_pxe.vmlinuz \
${SOURCE_DIR}/actions/stage2/stage1to2.ipxe \
${SOURCE_DIR}/actions/stage3_coreos/*.json \
${BUCKET}/stage3_coreos/
# Deploy all stage3_update images and actions.
${SOURCE_DIR}/travis/deploy_gcs.sh ${KEYNAME} \
${SOURCE_DIR}/output/stage2_vmlinuz \
${SOURCE_DIR}/output/vmlinuz_stage3_update \
${SOURCE_DIR}/output/initramfs_stage3_update.cpio.gz \
${SOURCE_DIR}/actions/stage2/stage1to2.ipxe \
${SOURCE_DIR}/actions/stage3_update/*.json \
${BUCKET}/stage3_update/
# Deploy stage3_update_iso images.
${SOURCE_DIR}/travis/deploy_gcs.sh ${KEYNAME} \
${SOURCE_DIR}/output/*.iso \
${BUCKET}/stage3_update_iso/
# Deploy stage1_mlxrom images preserving version directory.
${SOURCE_DIR}/travis/deploy_gcs.sh ${KEYNAME} \
${SOURCE_DIR}/output/stage1_mlxrom/* \
${BUCKET}/stage1_mlxrom/
# Deploy stage1_mlxrom images again to the 'latest' directory (without version).
${SOURCE_DIR}/travis/deploy_gcs.sh ${KEYNAME} \
${SOURCE_DIR}/output/stage1_mlxrom/*/* \
${BUCKET}/stage1_mlxrom/latest/
# Deploy the stage1 custom bootstrapfs for the modified PlanetLab bootmanager.
${SOURCE_DIR}/travis/deploy_gcs.sh ${KEYNAME} \
${SOURCE_DIR}/output/bootstrapfs-MeasurementLabUpdate.tar.bz2* \
${BUCKET}/stage1_bootstrapfs/