Add Dockerfile and bootstrap scripts to run rubbos
[bottlenecks.git] / utils / infra_setup / heat_template / HOT_create_instance.sh
index 4de29b3..55198be 100755 (executable)
@@ -2,10 +2,10 @@
 
 set -x
 
-GERRIT_REFSPEC_DEBUG=$1
-
 bottlenecks_env_prepare()
 {
+    echo "Bottlenecks env prepare start $(date)"
+
     if [ -d $BOTTLENECKS_REPO_DIR ]; then
         rm -rf ${BOTTLENECKS_REPO_DIR}
     fi
@@ -21,6 +21,8 @@ bottlenecks_env_prepare()
 
     source $BOTTLENECKS_REPO_DIR/rubbos/rubbos_scripts/1-1-1/scripts/env_preparation.sh
     chmod 600 $KEY_PATH/bottlenecks_key
+
+    echo "Bottlenecks env prepare end $(date)"
 }
 
 wait_heat_stack_complete() {
@@ -39,7 +41,8 @@ wait_heat_stack_complete() {
             exit 1
         fi
 
-        if [ $BOTTLENECKS_DEBUG = True ]; then
+        #if [ $BOTTLENECKS_DEBUG = True ]; then
+        if false; then
             heat stack-show bottlenecks
             nova list | grep rubbos_
             for i in $(nova list | grep rubbos_ | grep ERROR | awk '{print $2}')
@@ -75,7 +78,7 @@ wait_rubbos_control_ok() {
 
 bottlenecks_check_instance_ok()
 {
-    echo "check instance"
+    echo "Bottlenecks check instance ok start $(date)"
 
     wait_heat_stack_complete 120
     wait_rubbos_control_ok 300
@@ -101,11 +104,13 @@ bottlenecks_check_instance_ok()
             sleep 10
         done
     fi
+
+    echo "Bottlenecks check instance ok end $(date)"
 }
 
 bottlenecks_create_instance()
 {
-    echo "create bottlenecks instance using heat template"
+    echo "Bottlenecks create instance using heat template start $(date)"
 
     echo "upload keypair"
     nova keypair-add --pub_key $KEY_PATH/bottlenecks_key.pub $KEY_NAME
@@ -117,6 +122,29 @@ bottlenecks_create_instance()
     cd $HOT_PATH
     heat stack-create bottlenecks -f ${TEMPLATE_NAME} \
          -P "image=$IMAGE_NAME;key_name=$KEY_NAME;public_net=$PUBLIC_NET_NAME;flavor=$FLAVOR_NAME"
+
+    echo "Bottlenecks create instance using heat template end $(date)"
+}
+
+bottlenecks_rubbos_wait_finish()
+{
+    echo "Start checking rubbos running status..."
+    retry=0
+    while true
+    do
+        ssh $ssh_args ec2-user@$control_ip "FILE=/tmp/rubbos_finished; if [ -f \$FILE ]; then exit 0; else exit 1; fi"
+        if [ $? = 0 ]; then
+            echo "Rubbos test case successfully finished :)"
+            return 0
+        fi
+        echo "Rubbos running $retry ..."
+        sleep 30
+        let retry+=1
+        if [[ $retry -ge $1 ]]; then
+            echo "Rubbos test case timeout :("
+            return 1
+        fi
+    done
 }
 
 bottlenecks_rubbos_run()
@@ -137,18 +165,25 @@ bottlenecks_rubbos_run()
 
     echo "GERRIT_REFSPEC_DEBUG=$GERRIT_REFSPEC_DEBUG" >> $BOTTLENECKS_REPO_DIR/utils/infra_setup/vm_dev_setup/hosts.conf
 
+    echo "POD_NAME=$POD_NAME" >> $BOTTLENECKS_REPO_DIR/utils/infra_setup/vm_dev_setup/hosts.conf
+    echo "INSTALLER_TYPE=$INSTALLER_TYPE" >> $BOTTLENECKS_REPO_DIR/utils/infra_setup/vm_dev_setup/hosts.conf
+    echo "BOTTLENECKS_VERSION=$BOTTLENECKS_VERSION" >> $BOTTLENECKS_REPO_DIR/utils/infra_setup/vm_dev_setup/hosts.conf
+    echo "BOTTLENECKS_DB_TARGET=$BOTTLENECKS_DB_TARGET" >> $BOTTLENECKS_REPO_DIR/utils/infra_setup/vm_dev_setup/hosts.conf
+
     scp $ssh_args -r \
         $BOTTLENECKS_REPO_DIR/utils/infra_setup/vm_dev_setup \
         ec2-user@$control_ip:/tmp
     ssh $ssh_args \
-        ec2-user@$control_ip "bash /tmp/vm_dev_setup/setup_env.sh"
+        ec2-user@$control_ip "bash /tmp/vm_dev_setup/setup_env.sh" &
+
+    bottlenecks_rubbos_wait_finish 200
 
     rm -rf $BOTTLENECKS_REPO_DIR/utils/infra_setup/vm_dev_setup/hosts.conf
 }
 
 bottlenecks_cleanup()
 {
-    echo "clean up bottlenecks images and keys"
+    echo "Bottlenecks cleanup start $(date)"
 
     if heat stack-list; then
         for stack in $(heat stack-list | grep -e bottlenecks | awk '{print $2}'); do
@@ -178,11 +213,13 @@ bottlenecks_cleanup()
             nova flavor-delete $flavor || true
         done
     fi
+
+    echo "Bottlenecks cleanup end $(date)"
 }
 
 bottlenecks_load_bottlenecks_image()
 {
-    echo "load bottlenecks image"
+    echo "Bottlenecks load image start $(date)"
 
     curl --connect-timeout 10 -o /tmp/bottlenecks-trusty-server.img $IMAGE_URL -v
 
@@ -201,12 +238,12 @@ bottlenecks_load_bottlenecks_image()
          exit 1
     fi
 
-    echo "bottlenecks image id: $IMAGE_ID_BOTTLENECKS"
+    echo "bottlenecks image end id: $IMAGE_ID_BOTTLENECKS $(date)"
 }
 
 main()
 {
-    echo "create instances with heat template"
+    echo "main start $(date)"
 
     BOTTLENECKS_DEBUG=True
     BOTTLENECKS_REPO=https://gerrit.opnfv.org/gerrit/bottlenecks
@@ -221,14 +258,20 @@ main()
     TEMPLATE_NAME=bottlenecks_rubbos_hot.yaml
     PUBLIC_NET_NAME=net04_ext
     ssh_args="-o StrictHostKeyChecking=no -o BatchMode=yes -i $KEY_PATH/bottlenecks_key"
+    : ${POD_NAME:='opnfv-jump-2'}
+    : ${INSTALLER_TYPE:='fuel'}
+    : ${BOTTLENECKS_VERSION:='master'}
+    : ${BOTTLENECKS_DB_TARGET:='213.77.62.197'}
 
     bottlenecks_env_prepare
+    set -x
     bottlenecks_cleanup
     bottlenecks_load_bottlenecks_image
     bottlenecks_create_instance
     bottlenecks_check_instance_ok
     bottlenecks_rubbos_run
     bottlenecks_cleanup
+    echo "main end $(date)"
 }
 
 main