forked from stolostron/deploy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstart.sh
executable file
·504 lines (454 loc) · 21.9 KB
/
start.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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
#!/bin/bash
# Copyright 2020, 2021 Red Hat Inc.
#Command Line param's
# ./start.sh -t, this exits after modifying the files but not apply any of the yaml
# ./start.sh --silent, this skips any questions, using the local files to apply the snapshot and secret
# ./start.sh --watch, this monitors for status during the main deploy of Red Hat ACM
# ./start.sh --search, this enables search, but turning on redis
# CONSTANTS
TOTAL_POD_COUNT_1X=35
TOTAL_POD_COUNT_2X=55
POLL_DURATION_21X=1500
# Global Variables with Defaults
TARGET_NAMESPACE=${TARGET_NAMESPACE:-"open-cluster-management"}
COMPOSITE_BUNDLE=${COMPOSITE_BUNDLE:-"true"}
DOWNSTREAM=${DOWNSTREAM:-"false"}
CUSTOM_REGISTRY_REPO=${CUSTOM_REGISTRY_REPO:-"quay.io/stolostron"}
QUAY_TOKEN=${QUAY_TOKEN:-"UNSET"}
MODE=${MODE:-"Automatic"}
STARTING_VERSION=${STARTING_VERSION:-"2.1.0"}
MCE_SNAPSHOT_CHOICE=${MCE_SNAPSHOT_CHOICE:-"UNSET"}
# build starting csv variable from $STARTING_VERSION
STARTING_CSV="advanced-cluster-management.v${STARTING_VERSION}"
function waitForInstallPlan() {
version=$1
for i in `seq 1 10`; do
oc get installplan -n ${TARGET_NAMESPACE} | grep "$version"
if [ $? -eq 0 ]; then
break
fi
echo 'waiting for installplan to show'
sleep 10
done
}
function waitForPod() {
FOUND=1
MINUTE=0
podName=$1
ignore=$2
namespace=$3
running="\([0-9]\+\)\/\1"
printf "\n#####\nWait for ${podName} to reach running state (4min).\n"
while [ ${FOUND} -eq 1 ]; do
# Wait up to 4min, should only take about 20-30s
if [ $MINUTE -gt 240 ]; then
echo "Timeout waiting for the ${podName}. Try cleaning up using the uninstall scripts before running again."
echo "List of current pods:"
oc -n ${namespace} get pods
echo
echo "You should see ${podName}, multiclusterhub-repo, and multicloud-operators-subscription pods"
exit 1
fi
if [ "$ignore" == "" ]; then
operatorPod=`oc -n ${namespace} get pods | grep ${podName}`
else
operatorPod=`oc -n ${namespace} get pods | grep ${podName} | grep -v ${ignore}`
fi
if [[ $(echo $operatorPod | grep "${running}") ]]; then
echo "* ${podName} is running"
break
elif [ "$operatorPod" == "" ]; then
operatorPod="Waiting"
fi
echo "* STATUS: $operatorPod"
sleep 3
(( MINUTE = MINUTE + 3 ))
done
}
function enable_search() {
if [[ ! " $@ " =~ " --skip-search " ]]; then
oc set env deploy search-operator DEPLOY_REDISGRAPH="true" -n ${TARGET_NAMESPACE}
echo "Search enabled"
echo ""
else
echo "Search was not enabled"
echo "Run 'oc set env deploy search-operator DEPLOY_REDISGRAPH="true" -n ${TARGET_NAMESPACE}' to enable search."
echo ""
fi
}
# fix sed issue on mac
OS=$(uname -s | tr '[:upper:]' '[:lower:]')
SED="sed"
if [ "${OS}" == "darwin" ]; then
SED="gsed"
if [ ! -x "$(command -v ${SED})" ]; then
echo "ERROR: $SED required, but not found."
echo "Perform \"brew install gnu-sed\" and try again."
exit 1
fi
fi
# if using --watch option on mac make sure watch is installed
if [[ " $@ " =~ " --watch " ]]; then
if [ ! -x "$(command -v watch)" ]; then
echo "ERROR: watch required, but not found."
if [ "${OS}" == "darwin" ]; then
echo "Perform \"brew install watch\" and try again."
fi
exit 1
fi
fi
# Ensure yq exists
if [ ! -x "$(command -v yq)" ]; then
YQ_ERROR="ERROR: yq is required, but was not found."
if [ "${OS}" == "darwin" ]; then
echo "${YQ_ERROR}"
echo "Perform \"brew install yq\" and try again."
exit 1
elif [ "${OS}" == "linux" ]; then # if linux, assume it is canary, and install yq
YQ_PATH="$HOME/bin"
if [[ ":$PATH:" == *":${YQ_PATH}:"* ]]; then
echo "Attempting to install yq to ${YQ_PATH}"
wget https://github.com/mikefarah/yq/releases/download/v4.12.2/yq_linux_amd64 -O ${YQ_PATH}/yq && chmod +x ${YQ_PATH}/yq
if [ ! -x "$(command -v yq)" ]; then
echo "ERROR: yq is required, but attempts to install it failed."
exit 1
fi
else
echo "${YQ_ERROR}"
exit 1
fi
fi
fi
#This is needed for the deploy
echo "* Testing connection"
HOST_URL=`oc -n openshift-console get routes console -o jsonpath='{.status.ingress[0].routerCanonicalHostname}'`
if [ $? -ne 0 ]; then
echo "ERROR: Make sure you are logged into an OpenShift Container Platform before running this script"
exit 2
fi
#Shorten to the basedomain
HOST_URL=${HOST_URL/#router-default./}
HOST_URL=${HOST_URL/#apps./}
echo "* Using baseDomain: ${HOST_URL}"
VER=`oc version | grep "Client Version:"`
echo "* oc CLI ${VER}"
if ! [[ $VER =~ .*[4-9]\.([3-9]|10)\..* ]]; then
echo "oc cli version 4.3 or greater required. Please visit https://access.redhat.com/downloads/content/290/ver=4.3/rhel---8/4.3.9/x86_64/product-software."
exit 1
fi
QUAY_TOKEN_OVERRIDE="false"
if [ ! -f ./prereqs/pull-secret.yaml ]; then
echo "SECURITY NOTICE: The encrypted dockerconfigjson is stored in ./prereqs/pull-secret.yaml. If you want to change the value, delete the file and run start.sh"
if [[ "$QUAY_TOKEN" == "UNSET" ]]; then
echo "Enter the encrypted .dockerconfigjson"
read -r QUAY_TOKEN
fi
echo "Writing .prereqs/pull-secret.yaml"
cat <<EOF > ./prereqs/pull-secret.yaml
apiVersion: v1
data:
.dockerconfigjson: ${QUAY_TOKEN}
kind: Secret
metadata:
name: multiclusterhub-operator-pull-secret
type: kubernetes.io/dockerconfigjson
EOF
elif [[ "${QUAY_TOKEN}" != "UNSET" ]]; then
QUAY_TOKEN_OVERRIDE="true"
fi
DEFAULT_SNAPSHOT="MUST_PROVIDE_SNAPSHOT"
if [ -f ./snapshot.ver ]; then
DEFAULT_SNAPSHOT=`cat ./snapshot.ver`
elif [[ " $@ " =~ " --silent " ]]; then
echo "ERROR: Silent mode will not work when ./snapshot.ver is missing"
exit 1
fi
if [[ " $@ " =~ " --silent " ]]; then
echo "* Silent mode"
else
printf "Find snapshot tags @ https://quay.io/repository/stolostron/acm-custom-registry?tab=tags\nEnter SNAPSHOT TAG: (Press ENTER for default: ${DEFAULT_SNAPSHOT})\n"
read -r SNAPSHOT_CHOICE
if [ "${SNAPSHOT_CHOICE}" != "" ]; then
DEFAULT_SNAPSHOT=${SNAPSHOT_CHOICE}
printf "${DEFAULT_SNAPSHOT}" > ./snapshot.ver
fi
fi
if [ "${DEFAULT_SNAPSHOT}" == "MUST_PROVIDE_SNAPSHOT" ]; then
echo "ERROR: Please specify a valid snapshot tag to continue."
exit 2
fi
SNAPSHOT_PREFIX=${DEFAULT_SNAPSHOT%%\-*}
# Change our expected pod count based on what version snapshot we detect, defaulting to 1.0 (smallest number of pods as of writing)
if [[ $DEFAULT_SNAPSHOT == 1.0* ]]; then
TOTAL_POD_COUNT=${TOTAL_POD_COUNT_1X}
elif [[ $DEFAULT_SNAPSHOT =~ v{0,1}2\.[0-9]+\.[0-9]+.* ]]; then
TOTAL_POD_COUNT=${TOTAL_POD_COUNT_2X}
else
TOTAL_POD_COUNT=${TOTAL_POD_COUNT_1X}
echo "Snapshot doesn't contain a version number we recognize, looking for the 1.X release pod count of ${TOTAL_POD_COUNT} if wait is selected."
fi
echo "* Applying multicluster-hub-cr values"
${SED} -i "s/example-multiclusterhub/multiclusterhub/" ./multiclusterhub/example-multiclusterhub-cr.yaml
if [[ -d applied-mch ]]; then rm -rf applied-mch; fi;
cp -r multiclusterhub applied-mch
if [[ "$DOWNSTREAM" != "true" ]]; then
yq eval -i 'del(.metadata.annotations.mch-imageRepository)' ./applied-mch/example-multiclusterhub-cr.yaml
else
CUSTOM_REGISTRY_REPO=${CUSTOM_REGISTRY_REPO} yq eval -i '.metadata.annotations.mch-imageRepository = env(CUSTOM_REGISTRY_REPO)' ./applied-mch/example-multiclusterhub-cr.yaml
fi
if [[ -z $SKIP_OPERATOR_INSTALL ]]; then
# If the user sets the COMPOSITE_BUNDLE flag to "true", then set to the `acm` variants of variables, otherwise the multicluster-hub version.
if [[ "$COMPOSITE_BUNDLE" == "true" ]]; then
OPERATOR_DIRECTORY="acm-operator"
CUSTOM_REGISTRY_IMAGE="acm-custom-registry"
IMG="${CUSTOM_REGISTRY_REPO}/acm-custom-registry:${DEFAULT_SNAPSHOT}" yq eval -i '.spec.image = env(IMG)' catalogsources/acm-operator.yaml
oc apply -f catalogsources/acm-operator.yaml
waitForPod "acm-custom-registry" "" "openshift-marketplace"
else
OPERATOR_DIRECTORY="multicluster-hub-operator"
CUSTOM_REGISTRY_IMAGE="multicluster-hub-custom-registry"
IMG="${CUSTOM_REGISTRY_REPO}/multicluster-hub-custom-registry:${DEFAULT_SNAPSHOT}" yq eval -i '.spec.image = env(IMG)' catalogsources/multiclusterhub-operator.yaml
oc apply -f catalogsources/multiclusterhub-operator.yaml
fi
# If 2.5.0 or higher, install MCE
if [[ $DEFAULT_SNAPSHOT =~ v{0,1}[2-9]\.[5-9]+\.[0-9]+.* ]]; then
_MCE_IMAGE_NAME="mce-custom-registry"
if [[ ${CUSTOM_REGISTRY_REPO} == "quay.io/stolostron" ]]; then
_MCE_IMAGE_NAME="cmb-custom-registry"
fi
if [[ "$MCE_SNAPSHOT_CHOICE" == "UNSET" ]]; then
MCE_SNAPSHOT_CHOICE=${DEFAULT_SNAPSHOT}
fi
IMG="${CUSTOM_REGISTRY_REPO}/${_MCE_IMAGE_NAME}:${MCE_SNAPSHOT_CHOICE}" yq eval -i '.spec.image = env(IMG)' catalogsources/multicluster-engine.yaml
oc apply -f catalogsources/multicluster-engine.yaml
waitForPod "multiclusterengine-catalog" "" "openshift-marketplace"
fi
# Set the subscription channel if the variable wasn't defined as input, defaulted to snapshot-<release-version>
if [ -z "$SUBSCRIPTION_CHANNEL" ]; then
SUBSCRIPTION_CHANNEL_VERSION=$(echo ${SNAPSHOT_PREFIX} | ${SED} -nr "s/v{0,1}([0-9]+\.[0-9]+)\.{0,1}[0-9]*.*/\1/p")
if [[ "$COMPOSITE_BUNDLE" == "true" ]]; then
SUBSCRIPTION_CHANNEL_PREFIX="release";
else
SUBSCRIPTION_CHANNEL_PREFIX="snapshot";
fi;
SUBSCRIPTION_CHANNEL="${SUBSCRIPTION_CHANNEL_PREFIX}-${SUBSCRIPTION_CHANNEL_VERSION}"
if [[ ! ( $SUBSCRIPTION_CHANNEL_VERSION =~ [0-9]+\.[0-9]+ ) ]]; then
echo "Failed to detect SUBSCRIPTION_CHANNEL, we detected ${SUBSCRIPTION_CHANNEL} which doesn't seem correct. Try exporting SUBSCRIPTION_CHANNEL and rerunning."
exit 1
fi
fi
echo "* Downstream: ${DOWNSTREAM} Release Version: $SNAPSHOT_PREFIX"
echo "* Composite Bundle: $COMPOSITE_BUNDLE Image Registry (CUSTOM_REGISTRY_REPO): $CUSTOM_REGISTRY_REPO"
if [[ (! $SNAPSHOT_PREFIX == *.*.*) && ("$DOWNSTREAM" != "true") ]]; then
echo "ERROR: invalid SNAPSHOT format... snapshot must begin with 'X.0.0-' not '$SNAPSHOT_PREFIX', if DOWNSTREAM isn't set"
exit 1
fi
printf "* Using: ${DEFAULT_SNAPSHOT}\n\n"
echo "* Applying SNAPSHOT to multiclusterhub-operator subscription"
${SED} -i "s/newTag: .*$/newTag: ${DEFAULT_SNAPSHOT}/g" ./$OPERATOR_DIRECTORY/kustomization.yaml
echo "* Applying CUSTOM_REGISTRY_REPO to multiclusterhub-operator subscription"
${SED} -i "s|newName: .*$|newName: ${CUSTOM_REGISTRY_REPO}/${CUSTOM_REGISTRY_IMAGE}|g" ./$OPERATOR_DIRECTORY/kustomization.yaml
echo "* Applying SUBSCRIPTION_CHANNEL to multiclusterhub-operator subscription"
${SED} -i "s|channel: .*$|channel: ${SUBSCRIPTION_CHANNEL}|g" ./$OPERATOR_DIRECTORY/subscription.yaml
echo "* Applying MODE to multiclusterhub-operator subscription"
${SED} -i "s|installPlanApproval: .*$|installPlanApproval: ${MODE}|g" ./$OPERATOR_DIRECTORY/subscription.yaml
if [[ "$MODE" == "Automatic" ]]; then
# Issue 7436 - If Downstream RC snapshot, remove leading 'v' from prefix name
CLEAN_RC_PREFIX=$(echo ${SNAPSHOT_PREFIX} | ${SED} 's/v//')
STARTING_CSV="advanced-cluster-management.v${CLEAN_RC_PREFIX}"
echo "* Applying STARTING_CSV to multiclusterhub-operator-subscription ($STARTING_CSV)"
${SED} -i "s|startingCSV: .*$|startingCSV: ${STARTING_CSV}|g" ./$OPERATOR_DIRECTORY/subscription.yaml
elif [[ "$MODE" == "Manual" ]]; then
echo "* Applying STARTING_CSV to multiclusterhub-operator subscription ($STARTING_CSV)"
${SED} -i "s|startingCSV: .*$|startingCSV: ${STARTING_CSV}|g" ./$OPERATOR_DIRECTORY/subscription.yaml
CHANNEL_VERSION=$(echo ${STARTING_VERSION} | ${SED} -nr "s/v{0,1}([0-9]+\.[0-9]+)\.{0,1}[0-9]*.*/\1/p")
echo "* Applying channel 'release-${CHANNEL_VERSION}' to multiclusterhub-operator subscription"
${SED} -i "s|channel: .*$|channel: release-${CHANNEL_VERSION}|g" ./$OPERATOR_DIRECTORY/subscription.yaml
else
echo "* Invalid MODE... Must be one of Automatic|Manual but found ${MODE}."
exit -1
fi
if [[ " $@ " =~ " -t " ]]; then
echo "* Test mode, see yaml files for updates"
exit 0
fi
printf "\n##### Creating the $TARGET_NAMESPACE namespace\n"
kubectl create ns $TARGET_NAMESPACE
seconds=0
while [ -z $(kubectl get sa -n $TARGET_NAMESPACE -o name default) ]; do
echo "--- waiting for namespace: $TARGET_NAMESPACE to create with default service account ---"
sleep 10
(( seconds=seconds+10 ))
if [ "$seconds" -gt 60 ]; then
echo "--- waited 60 seconds for namespace: $TARGET_NAMESPACE but it never came up with default service account, exiting ---"
exit 1;
fi
done;
if [[ "$COMPOSITE_BUNDLE" != "true" ]]; then
printf "\n##### Applying community operator subscriptions\n"
oc apply -k community-subscriptions/ -n ${TARGET_NAMESPACE}
fi
printf "\n##### Applying prerequisites\n"
kubectl apply --openapi-patch=true -k prereqs/ -n openshift-marketplace
kubectl apply --openapi-patch=true -k prereqs/ -n ${TARGET_NAMESPACE}
if [[ "${QUAY_TOKEN_OVERRIDE}" == "true" ]]; then
printf "\n##### Patching secret with QUAY_TOKEN\n"
kubectl patch secret multiclusterhub-operator-pull-secret -n ${TARGET_NAMESPACE} -p '{"data":{".dockerconfigjson":"'${QUAY_TOKEN}'"}}'
fi
printf "\n##### Allow secrets time to propagate #####\n"
sleep 60
printf "\n##### Applying $OPERATOR_DIRECTORY subscription #####\n"
if [[ "${TARGET_NAMESPACE}" != "open-cluster-management" ]]; then
TMP_OP_DIR="operator_tmp"
printf "* Creating temporary directory ${TMP_OP_DIR}/ to customize namespace\n"
mkdir ${TMP_OP_DIR}/
cp ${OPERATOR_DIRECTORY}/*.yaml ${TMP_OP_DIR}/
${SED} -i "s/^ - open-cluster-management$/ - ${TARGET_NAMESPACE}/" ${TMP_OP_DIR}/operator-group.yaml
kubectl apply -k $TMP_OP_DIR/ -n ${TARGET_NAMESPACE}
printf "* Removing temporary directory ${TMP_OP_DIR}/\n"
rm -rf ${TMP_OP_DIR}/
else
kubectl apply -k $OPERATOR_DIRECTORY/ -n ${TARGET_NAMESPACE}
fi
if [[ "$MODE" == "Manual" ]]; then
# wait for install plan to be available
waitForInstallPlan ${STARTING_CSV}
# identify plan and approve it
INSTALL_PLAN=$(oc get InstallPlan -n ${TARGET_NAMESPACE} | grep ${STARTING_CSV} | awk '{print $1;}')
oc patch InstallPlan $INSTALL_PLAN -n ${TARGET_NAMESPACE} --type "json" -p '[{"op":"replace","path":"/spec/approved","value":true}]'
fi
waitForPod "multiclusterhub-operator" "${CUSTOM_REGISTRY_IMAGE}" "${TARGET_NAMESPACE}"
fi
if [[ -z $SKIP_MCH_INSTALL ]]; then
printf "\n* Beginning deploy...\n"
echo "* Applying the multiclusterhub-operator to install Red Hat Advanced Cluster Management for Kubernetes"
kubectl apply -k applied-mch -n ${TARGET_NAMESPACE}
waitForPod "multicluster-operators-application" "" "${TARGET_NAMESPACE}"
COMPLETE=1
if [[ " $@ " =~ " --watch " ]]; then
if [[ $DEFAULT_SNAPSHOT =~ v{0,1}2\.[1-9][0-9]*\.[0-9]+.* ]]; then
echo ""
echo "#####"
mch_status=$(oc get multiclusterhub --all-namespaces -o json | jq -r '.items[].status.phase') 2> /dev/null
acc=0
while [[ "$mch_status" != "Running" && $acc -le $POLL_DURATION_21X ]]; do
echo "Waited $acc/$POLL_DURATION_21X seconds for MCH to reach Ready Status. Current Status: $mch_status"
CONSOLE_URL=`oc -n ${TARGET_NAMESPACE} get routes multicloud-console -o jsonpath='{.status.ingress[0].host}' 2> /dev/null`
if [[ "$CONSOLE_URL" != "" ]]; then
echo "Detected ACM Console URL: https://${CONSOLE_URL}"
fi;
if [[ "$DEBUG" == "true" ]]; then
echo "#####"
component_list=$(oc get multiclusterhub --all-namespaces -o json | jq -r '.items[].status.components')
printf "%-30s\t%-10s\t%-30s\t%-30s\n" "COMPONENT" "STATUS" "TYPE" "REASON"
for status_item in $(echo $component_list | jq -r 'keys | .[]'); do
component=$(echo $component_list | jq -r --arg ITEM_NAME "$status_item" '.[$ITEM_NAME]')
component_status="$(echo $component | jq -r '.status')";
type="$(echo $component | jq -r '.type')";
reason="$(echo $component | jq -r '.reason')";
message="$(echo $component | jq -r '.message')";
printf "%-30s\t%-10s\t%-30s\t%-30s\n" "$status_item" "$component_status" "$type" "$reason"
done
if [[ $DEFAULT_SNAPSHOT =~ v{0,1}[2-9]\.[5-9]+\.[0-9]+.* ]]; then
mce_find=$(oc get mce --all-namespaces 2>&1)
if [[ $mce_find == *"No resources found"* ]]; then
echo "Still waiting on MCE to be created"
else
component_list=$(oc get mce --all-namespaces -o json | jq -r '.items[].status.components') 2>/dev/null
printf "\n"
printf "MCE COMPONENTS"
printf "\n"
printf "%-30s\t%-10s\t%-30s\t%-30s\n" "COMPONENT" "STATUS" "TYPE" "REASON"
size=$(echo $component_list | jq -r '. | length')
for (( c=0; c<$size; c++ )) do
component=$(echo $component_list | jq --argjson c $c '.[$c]')
status_item="$(echo $component | jq -r '.name')";
component_status="$(echo $component | jq -r '.status')";
type="$(echo $component | jq -r '.type')";
reason="$(echo $component | jq -r '.reason')";
message="$(echo $component | jq -r '.message')";
printf "%-30s\t%-10s\t%-30s\t%-30s\n" "$status_item" "$component_status" "$type" "$reason"
done
fi
fi
fi
echo ""
acc=$((acc+30))
sleep 30
mch_status=$(oc get multiclusterhub --all-namespaces -o json | jq -r '.items[].status.phase') 2> /dev/null
done;
if [[ "$mch_status" != "Running" ]]; then
COMPLETE=1
else
COMPLETE=0
echo "MCH reached Running status after $acc seconds."
CONSOLE_URL=`oc -n ${TARGET_NAMESPACE} get routes multicloud-console -o jsonpath='{.status.ingress[0].host}' 2> /dev/null`
if [[ "$CONSOLE_URL" != "" ]]; then
echo "Detected ACM Console URL: https://${CONSOLE_URL}"
fi;
echo ""
fi
else
for i in {1..90}; do
clear
oc -n ${TARGET_NAMESPACE} get pods
CONSOLE_URL=`oc -n ${TARGET_NAMESPACE} get routes multicloud-console -o jsonpath='{.status.ingress[0].host}' 2> /dev/null`
whatsLeft=`oc -n ${TARGET_NAMESPACE} get pods | grep -v -e "Completed" -e "1/1 Running" -e "2/2 Running" -e "3/3 Running" -e "4/4 Running" -e "READY STATUS" | wc -l`
RUNNING_PODS=$(oc -n ${TARGET_NAMESPACE} get pods | grep -v -e "Completed" | tail -n +2 | wc -l | tr -d '[:space:]')
if [ "https://$CONSOLE_URL" == "https://multicloud-console.apps.${HOST_URL}" ] && [ ${whatsLeft} -eq 0 ]; then
if [ $RUNNING_PODS -ge ${TOTAL_POD_COUNT} ]; then
COMPLETE=0
break
fi
fi
echo
echo "Number of expected Pods : $RUNNING_PODS/$TOTAL_POD_COUNT"
echo "Pods still NOT running : ${whatsLeft}"
echo "Detected ACM Console URL: https://${CONSOLE_URL}"
sleep 10
done
fi
if [ $COMPLETE -eq 1 ]; then
if [[ $DEFAULT_SNAPSHOT =~ v{0,1}2\.[1-9][0-9]*\.[0-9]+.* ]]; then
mch_status=$(oc get multiclusterhub --all-namespaces -o json | jq -r '.items[].status.phase')
echo "MCH is in the following state: $mch_status"
echo "The full MCH status is as follows:"
component_list=$(oc get multiclusterhub --all-namespaces -o json | jq -r '.items[].status.components')
printf "%-30s\t%-10s\t%-30s\t%-30s\n" "COMPONENT" "STATUS" "TYPE" "REASON"
for status_item in $(echo $component_list | jq -r 'keys | .[]'); do
component=$(echo $component_list | jq -r --arg ITEM_NAME "$status_item" '.[$ITEM_NAME]')
component_status="$(echo $component | jq -r '.status')";
type="$(echo $component | jq -r '.type')";
reason="$(echo $component | jq -r '.reason')";
message="$(echo $component | jq -r '.message')";
printf "%-30s\t%-10s\t%-30s\t%-30s\n" "$status_item" "$component_status" "$type" "$reason"
done
echo ""
else
echo "At least one pod failed to start..."
oc -n ${TARGET_NAMESPACE} get pods | grep -v -e "Completed" -e "1/1 Running" -e "2/2 Running" -e "3/3 Running" -e "4/4 Running"
fi
exit 1
else
enable_search
echo "#####"
echo "* Red Hat ACM URL: https://$CONSOLE_URL"
echo "#####"
fi
echo "Done!"
exit $COMPLETE
fi
echo "Search will only be automaticaly enabled with '--watch' is set."
echo "Run 'oc set env deploy search-operator DEPLOY_REDISGRAPH="true" -n ${TARGET_NAMESPACE}' to enable search."
echo ""
echo "#####"
echo "* Red Hat ACM URL: https://multicloud-console.apps.${HOST_URL}"
echo "#####"
if [ "${OS}" == "darwin" ]; then
if [ ! -x "$(command -v watch)" ]; then
echo "NOTE: watch executable not found. Perform \"brew install watch\" to use the command above or use \"./start.sh --watch\" "
fi
else
echo "Deploying, for 2.1+ releases monitor the status of the multiclusterhub created in the ${TARGET_NAMESPACE} namespace, for 2.0 releases use \"watch oc -n ${TARGET_NAMESPACE} get pods\" to monitor progress. Expect around ${TOTAL_POD_COUNT} pods."
fi
fi