| #!/bin/bash |
| # |
| # ============LICENSE_START======================================================= |
| # ONAP CLAMP |
| # ================================================================================ |
| # Copyright (C) 2017 AT&T Intellectual Property. All 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. |
| # ============LICENSE_END============================================ |
| # =================================================================== |
| # ECOMP is a trademark and service mark of AT&T Intellectual Property. |
| # |
| |
| echo "This is ${WORKSPACE}/scripts/vvp/start_vvp_containers.sh" |
| |
| export IP=$HOST_IP |
| export PREFIX='nexus3.onap.org:10001/openecomp/vvp' |
| export RELEASE='latest' |
| |
| #start Engagement Manager pod: |
| docker run \ |
| --detach \ |
| --entrypoint="" \ |
| --name vvp-engagementmgr \ |
| --env-file ${WORKSPACE}/data/environments/vvp_env.list \ |
| --log-driver=json-file \ |
| --log-opt max-size=100m \ |
| --log-opt max-file=10 \ |
| --ulimit memlock=-1:-1 \ |
| --memory 4g \ |
| --memory-swap=4g \ |
| --ulimit nofile=4096:100000 \ |
| --volume /etc/localtime:/etc/localtime:ro \ |
| --volume /opt/configmaps/settings:/opt/configmaps/settings/ \ |
| --publish 9090:80 ${PREFIX}/engagementmgr:${RELEASE} |
| |
| docker cp /opt/configmaps/settings/uwsgi.ini vvp-engagementmgr:/srv/vvp/settings/ |
| |
| echo "please wait while Engagement Manager is starting..." |
| echo "" |
| c=60 # seconds to wait |
| REWRITE="\e[25D\e[1A\e[K" |
| while [ $c -gt 0 ]; do |
| c=$((c-1)) |
| sleep 1 |
| echo -e "${REWRITE}$c" |
| done |
| echo -e "" |
| |
| #run migration again: |
| docker exec -d vvp-engagementmgr sh -c "python3 /srv/manage.py migrate" |
| |
| #run initial populate db again: |
| docker exec -d vvp-engagementmgr sh -c "python3 /srv/manage.py initial_populate_db" |
| |
| |
| echo "Will copy the generated DB sqlite3 file into the application directory in 30 seconds..." |
| sleep 30 |
| #copy the generated DB sqlite3 file into the application directory: |
| docker exec -d vvp-engagementmgr sh -c "cp emdb.db /srv/emdb.db -f" |
| |
| TIME_OUT=600 |
| INTERVAL=5 |
| TIME=0 |
| while [ "$TIME" -lt "$TIME_OUT" ]; do |
| response=$(curl --write-out '%{http_code}' --silent --output /dev/null http://localhost:9090/vvp/v1/engmgr/vendors); echo $response |
| |
| if [ "$response" == "200" ]; then |
| echo VVP-Engagement-Manager well started in $TIME seconds |
| break; |
| fi |
| |
| echo Sleep: $INTERVAL seconds before testing if VVP-Engagement-Manager is up. Total wait time up now is: $TIME seconds. Timeout is: $TIME_OUT seconds |
| sleep $INTERVAL |
| TIME=$(($TIME+$INTERVAL)) |
| done |
| |
| if [ "$TIME" -ge "$TIME_OUT" ]; then |
| echo TIME OUT: Docker containers not started in $TIME_OUT seconds... Could cause problems for tests... |
| else |
| echo "Done starting vvp containers!" |
| fi |