blob: 2091d14e0fea84f51c60604a1b409446e1464055 [file] [log] [blame]
kishore328996f2017-09-08 17:15:42 -05001#!/bin/bash
kishore6eebdba2017-10-03 11:12:57 -05002# Starts docker containers for ONAP Portal
3# This version for Amsterdam/R1 of Portal, uses docker-compose.
4# Temporarily maintained in portal/deliveries area;
5# replicated from the ONAP demo/boot area due to release concerns.
6
7# Start Xvfb
8echo -e "Starting Xvfb on display ${DISPLAY} with res ${RES}"
9Xvfb ${DISPLAY} -ac -screen 0 ${RES} +extension RANDR &
10XVFBPID=$!
11# Get pid of this spawned process to make sure we kill the correct process later
12
13#Get current IP of VM
14HOST_IP=$(ip route get 8.8.8.8 | awk '/8.8.8.8/ {print $NF}')
15export HOST_IP=${HOST_IP}
16
kishore92d70d62017-10-11 14:51:31 -050017
18
kishore6eebdba2017-10-03 11:12:57 -050019if ! ifconfig docker0; then
20if ! ifconfig ens3; then
21echo "Could not determine IP address"
22exit 1
23fi
24export DOCKER_IP_IP=`ifconfig ens3 | awk -F: '/inet addr/ {gsub(/ .*/,"",$2); print $2}'`
25else
26export DOCKER_IP=`ifconfig docker0 | awk -F: '/inet addr/ {gsub(/ .*/,"",$2); print $2}'`
27fi
28echo $DOCKER_IP
29
30
31# Pass any variables required by Robot test suites in ROBOT_VARIABLES
32#ROBOT_VARIABLES="-v MOCK_IP:${MOCK_IP} -v IP:${IP} -v POLICY_IP:${POLICY_IP} -v DOCKER_IP:${DOCKER_IP}"
33#export PORTAL_IP=${PORTAL_IP}
34ROBOT_VARIABLES="-v MOCK_IP:${MOCK_IP} -v IP:${IP} -v DOCKER_IP:${DOCKER_IP}"
35export DOCKER_IP=${DOCKER_IP}
36
37
kishore92d70d62017-10-11 14:51:31 -050038
39
kishore328996f2017-09-08 17:15:42 -050040# be verbose
41set -x
42
43# Establish environment variables
kishore6eebdba2017-10-03 11:12:57 -050044NEXUS_USERNAME=docker
45NEXUS_PASSWD=docker
46NEXUS_DOCKER_REPO=nexus3.onap.org:10003
47
48
49
50CURR="$(pwd)"
51git clone http://gerrit.onap.org/r/portal
kishore328996f2017-09-08 17:15:42 -050052
53# Refresh configuration and scripts
kishore6eebdba2017-10-03 11:12:57 -050054cd portal
kishore328996f2017-09-08 17:15:42 -050055git pull
56cd deliveries
kishore6eebdba2017-10-03 11:12:57 -050057rm .env
58rm docker-compose.yml
59cp $CURR/.env .
60cp $CURR/docker-compose.yml .
kishore92d70d62017-10-11 14:51:31 -050061#cd properties_simpledemo/ECOMPPORTALAPP
kishore6eebdba2017-10-03 11:12:57 -050062#rm system.properties
63#cp $CURR/system.properties .
64#cd ../..
kishore328996f2017-09-08 17:15:42 -050065# Get image names used below from docker-compose environment file
kishore6eebdba2017-10-03 11:12:57 -050066source $CURR/.env
kishore92d70d62017-10-11 14:51:31 -050067#source .env
68
69# Make inter-app communication work in CSIT
70export EXTRA_HOST_IP="-i ${HOST_IP}"
71export EXTRA_HOST_NAME="-n portal.api.simpledemo.openecomp.org"
72
kishore328996f2017-09-08 17:15:42 -050073
kishore6eebdba2017-10-03 11:12:57 -050074# Copy property files to new directory
75mkdir -p $PROPS_DIR
kishore92d70d62017-10-11 14:51:31 -050076cp -r properties_simpledemo/* $PROPS_DIR
kishore6eebdba2017-10-03 11:12:57 -050077# Also create logs directory
78mkdir -p $LOGS_DIR
79
kishore328996f2017-09-08 17:15:42 -050080
81# Refresh images
82docker login -u $NEXUS_USERNAME -p $NEXUS_PASSWD $NEXUS_DOCKER_REPO
kishorebbca0cf2017-10-09 16:59:38 -050083docker pull $NEXUS_DOCKER_REPO/${DB_IMG_NAME}:$DOCKER_IMAGE_VERSION
84docker pull $NEXUS_DOCKER_REPO/${EP_IMG_NAME}:$DOCKER_IMAGE_VERSION
85docker pull $NEXUS_DOCKER_REPO/${WMS_IMG_NAME}:$DOCKER_IMAGE_VERSION
kishore6eebdba2017-10-03 11:12:57 -050086docker pull $NEXUS_DOCKER_REPO/$CLI_IMG_NAME:$CLI_DOCKER_VERSION
kishore328996f2017-09-08 17:15:42 -050087
88# Tag them as expected by docker-compose file
kishorebbca0cf2017-10-09 16:59:38 -050089docker tag $NEXUS_DOCKER_REPO/${DB_IMG_NAME}:$DOCKER_IMAGE_VERSION $DB_IMG_NAME:$PORTAL_TAG
90docker tag $NEXUS_DOCKER_REPO/${EP_IMG_NAME}:$DOCKER_IMAGE_VERSION $EP_IMG_NAME:$PORTAL_TAG
91docker tag $NEXUS_DOCKER_REPO/${WMS_IMG_NAME}:$DOCKER_IMAGE_VERSION $WMS_IMG_NAME:$PORTAL_TAG
kishore6eebdba2017-10-03 11:12:57 -050092docker tag $NEXUS_DOCKER_REPO/$CLI_IMG_NAME:$CLI_DOCKER_VERSION $CLI_IMG_NAME:$PORTAL_TAG
kishore328996f2017-09-08 17:15:42 -050093
kishorebbca0cf2017-10-09 16:59:38 -050094
kishore6eebdba2017-10-03 11:12:57 -050095# compose is not in /usr/bin
96docker-compose down
97docker-compose up -d
98
kishore6eebdba2017-10-03 11:12:57 -050099#${HOSTNAME}="portal.api.simpledemo.openecomp.org"
100#echo "$HOST_IP ${HOSTNAME}" >> /etc/hosts
101
102#echo "$HOST_IP portal.api.simpledemo.openecomp.org" >> /etc/hosts
103#sudo sed -i "2i$HOST_IP portal.api.simpledemo.openecomp.org" /etc/hosts
104
105#HOST="portal.api.simpledemo.openecomp.org"
106#sudo sed -i "/$HOST/ s/.*/$HOST_IP\t$HOST/g" /etc/hosts
107
108# insert/update hosts entry
109ip_address=$HOST_IP
110host_name="portal.api.simpledemo.openecomp.org"
111# find existing instances in the host file and save the line numbers
112matches_in_hosts="$(grep -n $host_name /etc/hosts | cut -f1 -d:)"
113host_entry="${ip_address} ${host_name}"
114
115echo "$host_entry"
116
117if [ ! -z "$matches_in_hosts" ]
118then
119echo "Updating existing hosts entry."
120# iterate over the line numbers on which matches were found
121while read -r line_number; do
122# replace the text of each line with the desired host entry
123sudo sed -i '' "${line_number}s/.*/${host_entry} /" /etc/hosts
124echo "${line_number} ${host_entry}"
125done <<< "$matches_in_hosts"
126else
127echo "Adding new hosts entry."
128echo "$host_entry" | sudo tee -a /etc/hosts > /dev/null
129fi
130
kishore92d70d62017-10-11 14:51:31 -0500131
132
kishorebbca0cf2017-10-09 16:59:38 -0500133sleep 3m
kishore6eebdba2017-10-03 11:12:57 -0500134
135# WAIT 5 minutes maximum and test every 5 seconds if Portal up using HealthCheck API
kishorebbca0cf2017-10-09 16:59:38 -0500136TIME_OUT=500
kishore6eebdba2017-10-03 11:12:57 -0500137INTERVAL=20
138TIME=0
139while [ "$TIME" -lt "$TIME_OUT" ]; do
140 response=$(curl --write-out '%{http_code}' --silent --output /dev/null http://portal.api.simpledemo.openecomp.org:8989/ECOMPPORTAL/portalApi/healthCheck); echo $response
141
142 if [ "$response" == "200" ]; then
143 echo Portal and its database well started in $TIME seconds
144 break;
145 fi
146
147 echo Sleep: $INTERVAL seconds before testing if Portal is up. Total wait time up now is: $TIME seconds. Timeout is: $TIME_OUT seconds
148 sleep $INTERVAL
149 TIME=$(($TIME+$INTERVAL))
150done
151
152if [ "$TIME" -ge "$TIME_OUT" ]; then
153 echo TIME OUT: Docker containers not started in $TIME_OUT seconds... Could cause problems for tests...
154fi
155
156#sleep 3m
157
158
159
160#if [ "$TIME" -ge "$TIME_OUT" ]; then
161# echo TIME OUT: Docker containers not started in $TIME_OUT seconds... Could cause problems for tests...
162#fi
163
164
165
166
167
168#Get current IP of VM
169HOST_IP=$(ip route get 8.8.8.8 | awk '/8.8.8.8/ {print $NF}')
170export HOST_IP=${HOST_IP}
171
kishore92d70d62017-10-11 14:51:31 -0500172#docker logs deliveries_portal-db_1
kishore6eebdba2017-10-03 11:12:57 -0500173docker logs deliveries_portal-apps_1
174docker logs deliveries_portal-wms_1
175
176
177
178