3 # Copyright 2017-2019 AT&T Intellectual Property. All rights reserved.
5 # Licensed under the Apache License, Version 2.0 (the "License");
6 # you may not use this file except in compliance with the License.
7 # You may obtain a copy of the License at
9 # http://www.apache.org/licenses/LICENSE-2.0
11 # Unless required by applicable law or agreed to in writing, software
12 # distributed under the License is distributed on an "AS IS" BASIS,
13 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 # See the License for the specific language governing permissions and
15 # limitations under the License.
17 echo "This is ${WORKSPACE}/scripts/policy/drools-pdp-script.sh"
20 # the directory of the script
21 DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
24 # the temp directory used, within $DIR
25 # omit the -p parameter to create a temporal directory in the default location
26 WORK_DIR=`mktemp -d -p "$DIR"`
31 # check if tmp dir was created
32 if [[ ! "$WORK_DIR" || ! -d "$WORK_DIR" ]]; then
33 echo "Could not create temp dir"
40 curl -O http://apache.claz.org/maven/maven-3/3.3.9/binaries/apache-maven-3.3.9-bin.tar.gz
41 tar -xzvf apache-maven-3.3.9-bin.tar.gz
43 export PATH=${PATH}:${WORK_DIR}/maven/apache-maven-3.3.9/bin
44 ${WORK_DIR}/maven/apache-maven-3.3.9/bin/mvn -v
49 export IP=`ip route get 8.8.8.8 | awk '/8.8.8.8/ {print $NF}'`
51 echo "Could not determine IP address"
56 if ! ifconfig docker0; then
57 export DOCKER_IP="$IP"
59 export DOCKER_IP=`ifconfig docker0 | awk -F: '/inet addr/ {gsub(/ .*/,"",$2); print $2}'`
63 git clone http://gerrit.onap.org/r/oparent
65 git clone http://gerrit.onap.org/r/policy/engine
66 cd engine/packages/docker
67 ${WORK_DIR}/maven/apache-maven-3.3.9/bin/mvn prepare-package --settings ${WORK_DIR}/oparent/settings.xml
68 docker build -t onap/policy-pe target/policy-pe
71 git clone http://gerrit.onap.org/r/policy/drools-pdp
72 cd drools-pdp/packages/docker
73 ${WORK_DIR}/maven/apache-maven-3.3.9/bin/mvn prepare-package --settings ${WORK_DIR}/oparent/settings.xml
74 docker build -t onap/policy-drools target/policy-drools
77 git clone http://gerrit.onap.org/r/policy/docker
80 chmod +x config/drools/drools-tweaks.sh
82 echo $IP > config/pe/ip_addr.txt
83 ls -l config/pe/ip_addr.txt
84 cat config/pe/ip_addr.txt
88 export PRELOAD_POLICIES=false
89 docker-compose -f docker-compose-integration.yml up -d
91 if [ ! $? -eq 0 ]; then
92 echo "Docker compose failed"
98 POLICY_IP=`docker inspect --format '{{ .NetworkSettings.Networks.docker_default.IPAddress}}' drools`
101 PDP_IP=`docker inspect --format '{{ .NetworkSettings.Networks.docker_default.IPAddress}}' pdp`
104 PAP_IP=`docker inspect --format '{{ .NetworkSettings.Networks.docker_default.IPAddress}}' pap`
107 BRMS_IP=`docker inspect --format '{{ .NetworkSettings.Networks.docker_default.IPAddress}}' brmsgw`
110 NEXUS_IP=`docker inspect --format '{{ .NetworkSettings.Networks.docker_default.IPAddress}}' nexus`
113 MARIADB_IP=`docker inspect --format '{{ .NetworkSettings.Networks.docker_default.IPAddress}}' mariadb`
118 docker logs mariadb 2>&1 | grep -q "mysqld: ready for connections"
119 if [ $? -eq 0 ]; then
120 # mariadb is ok - sleep a little longer for others
124 echo mariadb is not ready
127 docker kill drools pdp pap brmsgw nexus mariadb
128 docker rm -f drools pdp pap brmsgw nexus mariadb
130 docker-compose -f docker-compose-integration.yml up -d
132 if [ ! $? -eq 0 ]; then
133 echo "Docker compose failed"
139 POLICY_IP=`docker inspect --format '{{ .NetworkSettings.Networks.docker_default.IPAddress}}' drools`
142 PDP_IP=`docker inspect --format '{{ .NetworkSettings.Networks.docker_default.IPAddress}}' pdp`
145 PAP_IP=`docker inspect --format '{{ .NetworkSettings.Networks.docker_default.IPAddress}}' pap`
148 BRMS_IP=`docker inspect --format '{{ .NetworkSettings.Networks.docker_default.IPAddress}}' brmsgw`
151 NEXUS_IP=`docker inspect --format '{{ .NetworkSettings.Networks.docker_default.IPAddress}}' nexus`
154 MARIADB_IP=`docker inspect --format '{{ .NetworkSettings.Networks.docker_default.IPAddress}}' mariadb`
162 ${DIR}/wait_for_port.sh ${MARIADB_IP} 3306
164 if [[ $rc != 0 ]]; then
165 echo "cannot open ${MARIADB_IP} 3306"
166 telnet ${MARIADB_IP} 3306 < /dev/null
167 nc -vz ${MARIADB_IP} 3306
172 ${DIR}/wait_for_port.sh ${NEXUS_IP} 8081
174 if [[ $rc != 0 ]]; then
175 echo "cannot open ${NEXUS_IP} 8081"
176 telnet ${NEXUS_IP} 8081 < /dev/null
177 nc -vz ${NEXUS_IP} 8081
182 ${DIR}/wait_for_port.sh ${POLICY_IP} 9696
184 if [[ $rc != 0 ]]; then
185 echo "cannot open ${POLICY_IP} 9696"
186 telnet ${POLICY_IP} 9696 < /dev/null
187 nc -vz ${POLICY_IP} 9696
192 ${DIR}/wait_for_port.sh ${PAP_IP} 9091
194 if [[ $rc != 0 ]]; then
195 echo "cannot open ${PAP_IP} 9091"
196 telnet ${PAP_IP} 9091 < /dev/null
197 nc -vz ${PAP_IP} 9091
202 ${DIR}/wait_for_port.sh ${PDP_IP} 8081
204 if [[ $rc != 0 ]]; then
205 echo "cannot open ${PDP_IP} 8081"
206 telnet ${PDP_IP} 8081 < /dev/null
207 nc -vz ${PDP_IP} 8081
212 ${DIR}/wait_for_port.sh ${BRMS_IP} 9989
214 if [[ $rc != 0 ]]; then
215 echo "cannot open ${BRMS_IP} 9989"
216 telnet ${BRMS_IP} 9989" < /dev/null
217 nc -vz ${BRMS_IP} 9989"
230 while [ "$TIME" -lt "$TIME_OUT" ]; do
231 curl -k -i --user "demo@people.osaaf.org:demo123456!" -H "ContentType: application/json" -H "Accept: application/json" https://${POLICY_IP}:9696/healthcheck && break
233 echo Sleep: $INTERVAL seconds before testing if Policy is up. Total wait time up now is: $TIME seconds. Timeout is: $TIME_OUT seconds
235 TIME=$(($TIME+$INTERVAL))
240 # Add more sleep for everything to settle