Gary Wu | 9abb61c | 2018-09-27 10:38:50 -0700 | [diff] [blame] | 1 | #!/bin/bash |
| 2 | # Place the scripts in run order: |
| 3 | source ${SCRIPTS}/common_functions.sh |
| 4 | |
| 5 | # Clone DMaaP Message Router repo |
| 6 | mkdir -p $WORKSPACE/archives/dmaapmr |
| 7 | cd $WORKSPACE/archives/dmaapmr |
| 8 | git clone --depth 1 http://gerrit.onap.org/r/dmaap/messagerouter/messageservice -b master |
| 9 | git pull |
| 10 | cd $WORKSPACE/archives/dmaapmr/messageservice/src/main/resources/docker-compose |
| 11 | cp $WORKSPACE/archives/dmaapmr/messageservice/bundleconfig-local/etc/appprops/MsgRtrApi.properties /var/tmp/ |
| 12 | |
| 13 | # start DMaaP MR containers with docker compose and configuration from docker-compose.yml |
| 14 | docker login -u docker -p docker nexus3.onap.org:10001 |
| 15 | docker-compose up -d |
| 16 | |
| 17 | ZOOKEEPER=$(docker ps -a -q --filter="name=zookeeper_1") |
| 18 | KAFKA=$(docker ps -a -q --filter="name=kafka_1") |
| 19 | DMAAP=$(docker ps -a -q --filter="name=dmaap_1") |
| 20 | |
| 21 | # Wait for initialization of Docker contaienr for DMaaP MR, Kafka and Zookeeper |
| 22 | for i in {1..50}; do |
| 23 | if [ $(docker inspect --format '{{ .State.Running }}' $KAFKA) ] && \ |
| 24 | [ $(docker inspect --format '{{ .State.Running }}' $ZOOKEEPER) ] && \ |
| 25 | [ $(docker inspect --format '{{ .State.Running }}' $DMAAP) ] |
| 26 | then |
| 27 | echo "DMaaP Service Running" |
| 28 | break |
| 29 | else |
| 30 | echo sleep $i |
| 31 | sleep $i |
| 32 | fi |
| 33 | done |
| 34 | |
| 35 | # Get IP address of DMAAP, KAFKA, Zookeeper |
| 36 | KAFKA_IP=$(docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' $KAFKA) |
| 37 | ZOOKEEPER_IP=$(docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' $ZOOKEEPER) |
| 38 | DMAAP_MR_IP=$(docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' $DMAAP) |
| 39 | |
| 40 | sleep 2 |
| 41 | # Shutdown DMAAP Container |
| 42 | docker kill $DMAAP |
| 43 | |
| 44 | # Initial docker-compose up and down is for populating kafka and zookeeper IPs in /var/tmp/MsgRtrApi.properites |
| 45 | sed -i -e '/config.zk.servers=/ s/=.*/='$ZOOKEEPER_IP'/' /var/tmp/MsgRtrApi.properties |
| 46 | sed -i -e '/kafka.metadata.broker.list=/ s/=.*/='$KAFKA_IP':9092/' /var/tmp/MsgRtrApi.properties |
| 47 | |
| 48 | # Start DMaaP MR containers with docker compose and configuration from docker-compose.yml |
| 49 | docker login -u docker -p docker nexus3.onap.org:10001 |
| 50 | docker-compose up -d |
| 51 | sleep 5 |
| 52 | |
| 53 | # Clone DMaaP Data Router repo |
| 54 | mkdir -p $WORKSPACE/archives/dmaapdr |
| 55 | cd $WORKSPACE/archives/dmaapdr |
| 56 | git clone --depth 1 https://gerrit.onap.org/r/dmaap/datarouter -b master |
| 57 | cd datarouter |
| 58 | cd $WORKSPACE/archives/dmaapdr/datarouter/docker-compose/ |
| 59 | rm -rf docker-compose.yml |
Gary Wu | 13111e9 | 2018-09-27 11:31:33 -0700 | [diff] [blame] | 60 | cp $WORKSPACE/plans/usecases/5G-bulkpm/composefile/docker-compose-e2e.yml $WORKSPACE/archives/dmaapdr/datarouter/docker-compose/docker-compose.yml |
Gary Wu | 9abb61c | 2018-09-27 10:38:50 -0700 | [diff] [blame] | 61 | docker login -u docker -p docker nexus3.onap.org:10001 |
| 62 | docker-compose up -d |
| 63 | docker kill datarouter-prov |
| 64 | docker kill datarouter-node |
| 65 | docker kill vescollector |
| 66 | HOST_IP=$(ip route get 8.8.8.8 | awk '/8.8.8.8/ {print $NF}') |
| 67 | sed -i -e '/DMAAPHOST:/ s/:.*/: '$HOST_IP'/' docker-compose.yml |
| 68 | MARIADB=$(docker inspect '--format={{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' mariadb ) |
| 69 | sed -i 's/172.100.0.2/'$MARIADB'/g' $WORKSPACE/archives/dmaapdr/datarouter/docker-compose/prov_data/provserver.properties |
| 70 | docker-compose up -d |
| 71 | |
| 72 | # Wait for initialization of Docker container for datarouter-node, datarouter-prov and mariadb |
| 73 | for i in {1..50}; do |
| 74 | if [ $(docker inspect --format '{{ .State.Running }}' datarouter-node) ] && \ |
| 75 | [ $(docker inspect --format '{{ .State.Running }}' datarouter-prov) ] && \ |
| 76 | [ $(docker inspect --format '{{ .State.Running }}' mariadb) ] |
| 77 | then |
| 78 | echo "DR Service Running" |
| 79 | break |
| 80 | else |
| 81 | echo sleep $i |
| 82 | sleep $i |
| 83 | fi |
| 84 | done |
| 85 | |
| 86 | sleep 5 |
| 87 | |
| 88 | # Get IP address of datarrouger-prov, datarouter-node, fileconsumer-node. |
| 89 | DR_PROV_IP=$(docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' datarouter-prov) |
| 90 | DR_NODE_IP=$(docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' datarouter-node) |
| 91 | DR_SUBSCIBER_IP=$(docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' fileconsumer-node) |
| 92 | DR_GATEWAY_IP=$(docker inspect -f '{{range .NetworkSettings.Networks}}{{.Gateway}}{{end}}' datarouter-prov) |
| 93 | |
| 94 | echo DR_PROV_IP=${DR_PROV_IP} |
| 95 | echo DR_NODE_IP=${DR_NODE_IP} |
| 96 | echo DR_GATEWAY_IP=${DR_GATEWAY_IP} |
| 97 | echo DR_SUBSCIBER_IP=${DR_SUBSCIBER_IP} |
| 98 | |
| 99 | docker exec -i datarouter-prov sh -c "curl -k -X PUT https://$DR_PROV_IP:8443/internal/api/NODES?val=dmaap-dr-node\|$DR_GATEWAY_IP" |
| 100 | docker exec -i datarouter-prov sh -c "curl -k -X PUT https://$DR_PROV_IP:8443/internal/api/PROV_AUTH_ADDRESSES?val=dmaap-dr-prov\|$DR_GATEWAY_IP" |
| 101 | docker exec datarouter-prov /bin/sh -c "echo '${DR_NODE_IP}' dmaap-dr-node >> /etc/hosts" |
| 102 | docker exec datarouter-node /bin/sh -c "echo '${DR_PROV_IP}' dmaap-dr-prov >> /etc/hosts" |
| 103 | docker exec datarouter-node /bin/sh -c "echo '${DR_SUBSCIBER_IP}' dmaap-dr-subscriber >> /etc/hosts" |
| 104 | |
| 105 | # Get IP address of DMAAP, KAFKA, Zookeeper |
| 106 | DMAAP_MR_IP=$(docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' $DMAAP) |
| 107 | KAFKA_IP=$(docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' $KAFKA) |
| 108 | ZOOKEEPER_IP=$(docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' $ZOOKEEPER) |
| 109 | VESC_IP=$(docker inspect '--format={{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' vescollector) |
| 110 | SFTP_IP=$(docker inspect '--format={{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' sftp) |
| 111 | |
| 112 | export VESC_IP=${VESC_IP} |
| 113 | export HOST_IP=${HOST_IP} |
| 114 | export DMAAP_MR_IP=${DMAAP_MR_IP} |
| 115 | |
| 116 | #Pass any variables required by Robot test suites in ROBOT_VARIABLES |
| 117 | ROBOT_VARIABLES="-v DR_PROV_IP:${DR_PROV_IP} -v DR_NODE_IP:${DR_NODE_IP} -v DMAAP_MR_IP:${DMAAP_MR_IP} -v VESC_IP:${VESC_IP} -v DR_SUBSCIBER_IP:${DR_SUBSCIBER_IP}" |
| 118 | |
| 119 | pip install jsonschema uuid |
| 120 | # Wait container ready |
| 121 | sleep 2 |
| 122 | |
| 123 | # Data File Collector configuration : |
Gary Wu | 13111e9 | 2018-09-27 11:31:33 -0700 | [diff] [blame] | 124 | cp $WORKSPACE/plans/usecases/5G-bulkpm/assets/datafile_endpoints.json /tmp/ |
Gary Wu | 9abb61c | 2018-09-27 10:38:50 -0700 | [diff] [blame] | 125 | sed -i 's/dmaapmrhost/'${DMAAP_MR_IP}'/g' /tmp/datafile_endpoints.json |
| 126 | sed -i 's/dmaapdrhost/'${DR_PROV_IP}'/g' /tmp/datafile_endpoints.json |
| 127 | docker cp /tmp/datafile_endpoints.json dfc:/config/ |
| 128 | docker restart dfc |
| 129 | |
| 130 | # SFTP Configuration: |
| 131 | # Update the File Ready Notification with actual sftp ip address and copy pm files to sftp server. |
rajendrajaiswal | 0d357f3 | 2018-09-28 10:18:19 +0100 | [diff] [blame^] | 132 | cp $WORKSPACE/tests/usecases/5G-bulkpm/assets/json_events/FileExistNotification.json $WORKSPACE/tests/usecases/5G-bulkpm/assets/json_events/FileExistNotificationUpdated.json |
Gary Wu | 13111e9 | 2018-09-27 11:31:33 -0700 | [diff] [blame] | 133 | sed -i 's/sftpserver/'${SFTP_IP}'/g' $WORKSPACE/tests/usecases/5G-bulkpm/assets/json_events/FileExistNotificationUpdated.json |
| 134 | docker cp $WORKSPACE/plans/usecases/5G-bulkpm/assets/xNF.pm.xml.gz sftp:/home/admin/ |
Gary Wu | 9abb61c | 2018-09-27 10:38:50 -0700 | [diff] [blame] | 135 | |
| 136 | # Data Router Configuration: |
| 137 | # Create default feed and create file consumer subscriber on data router |
Gary Wu | 13111e9 | 2018-09-27 11:31:33 -0700 | [diff] [blame] | 138 | curl -v -X POST -H "Content-Type:application/vnd.att-dr.feed" -H "X-ATT-DR-ON-BEHALF-OF:dradmin" --data-ascii @$WORKSPACE/plans/usecases/5G-bulkpm/assets/createFeed.json --post301 --location-trusted -k https://${DR_PROV_IP}:8443 |
| 139 | cp $WORKSPACE/plans/usecases/5G-bulkpm/assets/addSubscriber.json /tmp/addSubscriber.json |
Gary Wu | 9abb61c | 2018-09-27 10:38:50 -0700 | [diff] [blame] | 140 | sed -i 's/fileconsumer/'${DR_SUBSCIBER_IP}'/g' /tmp/addSubscriber.json |
| 141 | curl -v -X POST -H "Content-Type:application/vnd.att-dr.subscription" -H "X-ATT-DR-ON-BEHALF-OF:dradmin" --data-ascii @/tmp/addSubscriber.json --post301 --location-trusted -k https://${DR_PROV_IP}:8443/subscribe/1ii @/tmp/addSubscriber.json --post301 --location-trusted -k https://${DR_PROV_IP}:8443/subscribe/1 |