ba37d9015cd346e993243cde3d411243894b1ba6
[integration/csit.git] / scripts / optf-has / has / music_script.sh
1 #!/bin/bash
2 #
3 # Copyright 2016-2017 Huawei Technologies Co., Ltd.
4 #
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
8 #
9 #     http://www.apache.org/licenses/LICENSE-2.0
10 #
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.
16 #
17 echo "### This is ${WORKSPACE}/scripts/optf-has/has/music_script.sh"
18 #
19 # add here whatever commands is needed to prepare the music setup for optf-has CSIT testing
20 #
21
22 #
23 # add here all the configuration steps eventually needed to be carried out for music CSIT testing
24 #
25 echo "########## music configuration step ##########";
26 CASS_IMG=nexus3.onap.org:10001/onap/music/cassandra_3_11:3.0.23
27 CASS_IMG_JOB=nexus3.onap.org:10001/onap/music/cassandra_job:3.0.23
28 TOMCAT_IMG=nexus3.onap.org:10001/library/tomcat:8.5
29 ZK_IMG=nexus3.onap.org:10001/library/zookeeper:3.4
30 BUSYBOX_IMG=nexus3.onap.org:10001/library/busybox:latest
31 MUSIC_IMG=nexus3.onap.org:10001/onap/music/music:3.0.23
32 TT=10
33 WORK_DIR=/tmp/music
34 CASS_USERNAME=nelson24
35 CASS_PASSWORD=winman123
36 MUSIC_SOURCE_PROPERTIES=${WORKSPACE}/scripts/optf-has/has/music-properties
37 MUSIC_PROPERTIES=/tmp/music/properties
38 MUSIC_LOGS=/tmp/music/logs
39 CQL_FILES=${WORKSPACE}/scripts/music/cql
40 MUSIC_TRIGGER_DIR=/tmp/triggers
41 TRIGGER_JAR=musictrigger-0.1.0.jar
42 TRIGGER_JAR_URL=https://nexus.onap.org/service/local/repositories/autorelease-72298/content/org/onap/music/musictrigger/0.1.0/musictrigger-0.1.0.jar
43
44 mkdir -p ${MUSIC_PROPERTIES}
45 mkdir -p ${MUSIC_LOGS}
46 mkdir -p ${MUSIC_LOGS}/MUSIC
47 mkdir -p /tmp/triggers
48
49 # Get Trigger
50 echo "########## Get Trigger Jar ##########"
51 curl -o $MUSIC_TRIGGER_DIR/$TRIGGER_JAR $TRIGGER_JAR_URL
52
53 cp ${MUSIC_SOURCE_PROPERTIES}/* ${WORK_DIR}/properties
54
55 # Create Volume for mapping war file and tomcat
56 echo "########## create music-vol ##########"
57 docker volume create --name music-vol;
58
59 # Create a network for all the containers to run in.
60 echo "########## create music-net ##########"
61 docker network create music-net;
62
63 # Start Cassandra
64 echo "########## Start Cassandra (music-db) ##########"
65 docker run -d --name music-db --network music-net -p "7000:7000" -p "7001:7001" -p "7199:7199" -p "9042:9042" -p "9160:9160" \
66 -v $MUSIC_TRIGGER_DIR/$TRIGGER_JAR:/etc/cassandra/triggers/$TRIGGER_JAR \
67 ${CASS_IMG};
68
69 CASSA_IP=`docker inspect -f '{{ $network := index .NetworkSettings.Networks "music-net" }}{{ $network.IPAddress}}' music-db`
70 echo "CASSANDRA_IP=${CASSA_IP}"
71 ${WORKSPACE}/scripts/optf-has/has/wait_for_port.sh ${CASSA_IP} 9042
72
73 # See if cassandra is up.
74 echo "########## Running Test to see if Cassandra is up ##########"
75 docker run --name music-casstest --network music-net \
76 $BUSYBOX_IMG sh -c "until nc -z music-db 9042 && echo "success"; do echo 'No connection .. Sleeping for $TT seconds';sleep $TT; done;"
77
78 # Sleep 60 seconds to ensure Cassandra is up and running.
79 sleep 60;
80 # Check to see if Keyspaces are there.
81 docker exec music-db cqlsh -u cassandra -p cassandra -e "DESCRIBE keyspaces;"
82
83 # Load data into Cassandra via Cassandra Job
84 echo "########## Running Cassandra Job (music-job) to load cql files ##########"
85 docker run -d --name music-job --network music-net \
86 -v $CQL_FILES/admin.cql:/cql/admin.cql \
87 -v $CQL_FILES/admin_pw.cql:/cql/admin_pw.cql \
88 -v $CQL_FILES/extra:/cql/extra \
89 -e PORT=9042 \
90 -e CASS_HOSTNAME=music-db \
91 -e USERNAME=$CASS_USERNAME \
92 -e PASSWORD=$CASS_PASSWORD \
93 $CASS_IMG_JOB
94
95 sleep 70;
96
97 # Logs
98 echo "########## Cassandra Job logs ##########"
99 docker logs music-job
100 # Check to see if Keyspaces are there.
101 # "############## Check if new username and password work ##########"
102 docker exec music-db cqlsh -u $CASS_USERNAME -p $CASS_PASSWORD -e "DESCRIBE keyspaces;"
103 # Check to see if Keyspaces are there.
104 # "############## Check if original username and password work ##########"
105 docker exec music-db cqlsh -u cassandra -p cassandra -e "DESCRIBE keyspaces;"
106 # Check to see if Keyspaces are there.
107 # "############## Check if new cassandra username and password work ##########"
108 docker exec music-db cqlsh -u cassandra -p SomeLongRandomStringNoonewillthinkof -e "DESCRIBE keyspaces;"
109
110
111 # Start Music war
112 echo "########## Start music-war ##########"
113 docker run -d --name music-war -v music-vol:/app ${MUSIC_IMG};
114
115 # Start Zookeeper
116 echo "########## Start zookeeper (music-zk) ##########"
117 docker run -d --name music-zk --network music-net -p "2181:2181" -p "2888:2888" -p "3888:3888" ${ZK_IMG};
118
119 ZOO_IP=`docker inspect -f '{{ $network := index .NetworkSettings.Networks "music-net" }}{{ $network.IPAddress}}' music-zk`
120 echo "ZOOKEEPER_IP=${ZOO_IP}"
121
122 # Delay  between Cassandra/Zookeeper and Tomcat
123 sleep 120;
124
125 # Start Up tomcat - Needs to have properties,logs dir and war file volume mapped.
126 echo "########## Start Tomcat (music-tomcat) ##########"
127 docker run -d --name music-tomcat --network music-net -p "8080:8080" -v music-vol:/usr/local/tomcat/webapps -v ${WORK_DIR}/properties:/opt/app/music/etc:ro -v ${WORK_DIR}/logs:/opt/app/music/logs ${TOMCAT_IMG};
128
129 # Connect tomcat to host bridge network so that its port can be seen.
130 echo "########## Create Bridge for Tomcat ##########"
131 docker network connect bridge music-tomcat;
132
133 TOMCAT_IP=`docker inspect --format '{{ .NetworkSettings.Networks.bridge.IPAddress}}' music-tomcat`
134 echo "TOMCAT_IP=${TOMCAT_IP}"
135
136 ${WORKSPACE}/scripts/optf-has/has/wait_for_port.sh ${TOMCAT_IP} 8080
137
138 sleep 20;
139 echo "########## TOMCAT Logs ##########"
140 docker logs music-tomcat
141 # Needed only if we need to look at localhost logs.
142 echo "########## MUSIC localhost Log ##########"
143 docker exec music-tomcat /bin/bash -c "cat /usr/local/tomcat/logs/localhost*"
144
145 echo "########## MUSIC Log ##########"
146 ls -al $MUSIC_LOGS/MUSIC
147 docker exec music-tomcat /bin/bash -c "cat /opt/app/music/logs/MUSIC/music.log"
148 #echo "########## MUSIC error log ##########"
149 #docker exec music-tomcat /bin/bash -c "cat /opt/app/music/logs/MUSIC/error.log"
150
151 echo "########## inspect docker things for tracing purpose ##########"
152 docker inspect music-db
153 docker inspect music-zk
154 docker inspect music-tomcat
155 docker inspect music-war
156 docker volume inspect music-vol
157 docker network inspect music-net
158
159 echo "########## dump music content just after music is started ##########"
160 docker exec music-db /usr/bin/nodetool status
161 docker exec music-db /usr/bin/cqlsh -unelson24 -pwinman123 -e 'SELECT * FROM system_schema.keyspaces'
162 docker exec music-db /usr/bin/cqlsh -unelson24 -pwinman123 -e 'DESCRIBE keyspace admin'
163 docker exec music-db /usr/bin/cqlsh -unelson24 -pwinman123 -e 'SELECT * FROM admin.keyspace_master'
164
165
166 #
167 # add here all ROBOT_VARIABLES settings
168 #
169 echo "########## music robot variables settings ##########";
170 ROBOT_VARIABLES="-v MUSIC_HOSTNAME:http://${TOMCAT_IP} -v MUSIC_PORT:8080 -v COND_HOSTNAME:http://localhost -v COND_PORT:8091"
171
172 echo ${ROBOT_VARIABLES}
173
174
175