ocl integration draft.
[joid.git] / ci / 01-deploybundle.sh
index 1c3a510..25ee38e 100755 (executable)
@@ -2,10 +2,15 @@
 #placeholder for deployment script.
 set -ex
 
-#copy and download charms
+#    ./01-deploybundle.sh $opnfvtype $openstack $opnfvlab $opnfvsdn $opnfvfeature $opnfvdistro
+
+    #copy and download charms
     cp $4/fetch-charms.sh ./fetch-charms.sh
-    sh ./fetch-charms.sh
+    #modify the ubuntu series wants to deploy
+    sed -i -- "s|distro=trusty|distro=$6|g" ./fetch-charms.sh
+    ./fetch-charms.sh $6
 
+osdomname=''
 
 case "$1" in
     'nonha' )
@@ -24,63 +29,54 @@ case "$1" in
         ;;
 esac
 
+#check whether charms are still executing the code even juju-deployer says installed.
+check_status() {
+    retval=0
+    timeoutiter=0
+    while [ $retval -eq 0 ]; do
+       sleep 30
+       juju status > status.txt
+       if [ "$(grep -c "executing" status.txt )" -ge 2 ]; then
+           echo " still executing the reltionship within charms ..."
+           if [ $timeoutiter -ge 60 ]; then
+               retval=1
+           fi
+           timeoutiter=$((timeoutiter+1))
+       else
+           retval=1
+       fi
+    done
+    status=`juju action do heat/0 domain-setup`
+    echo $status
+    echo "...... deployment finishing ......."
+}
+
+#read the value from deployment.yaml
+if [ -e ~/.juju/deployment.yaml ]; then
+   cp ~/.juju/deployment.yaml ./deployment.yaml
+   if [ -e ~/.juju/deployconfig.yaml ]; then
+      cp ~/.juju/deployconfig.yaml ./deployconfig.yaml
+      extport=`grep "ext-port" deployconfig.yaml | cut -d ' ' -f 4 | sed -e 's/ //' | tr ',' ' '`
+      sed --i "s@#ext-port: \"eth1\"@ext-port: \"$extport\"@g" ./bundles.yaml
+      datanet=`grep "dataNetwork" deployconfig.yaml | cut -d ' ' -f 4 | sed -e 's/ //'`
+      if [ "$datanet" != "''" ]; then
+          sed -i -- "s@#os-data-network: 10.4.8.0/21@os-data-network: $datanet@g" ./bundles.yaml
+      fi
+      admnet=`grep "admNetwork" deployconfig.yaml | cut -d ' ' -f 4 | sed -e 's/ //'`
+      sed --i "s@10.4.1.1@$admnet@g" ./bundles.yaml
+      cephdisk=`grep "ceph-disk" deployconfig.yaml | cut -d ':' -f 2 | sed -e 's/ //'`
+      sed --i "s@osd-devices: /srv@osd-devices: $cephdisk@g" ./bundles.yaml
+      osdomname=`grep "os-domain-name" deployconfig.yaml | cut -d ':' -f 2 | sed -e 's/ //'`
+      if [ "$osdomname" != "''" ]; then
+          sed --i "s@#use-internal-endpoints: true@use-internal-endpoints: true@g" ./bundles.yaml
+          sed --i "s@#endpoint-type: internalURL@endpoint-type: internalURL@g" ./bundles.yaml
+          sed --i "s@#os-public-hostname: pod.maas@os-public-hostname: api.$osdomname@g" ./bundles.yaml
+          sed --i "s@#console-proxy-ip: pod.maas@console-proxy-ip: $osdomname@g" ./bundles.yaml
+      fi
+   fi
+fi
+
 case "$3" in
-    'orangepod1' )
-        # As per your lab vip address list be deafult uses 10.4.1.11 - 10.4.1.20
-         sed -i -- 's/10.4.1.1/192.168.1.2/g' ./bundles.yaml
-        # choose the correct interface to use for data network
-         sed -i -- 's/#os-data-network: 10.4.8.0\/21/os-data-network: 192.168.11.0\/24/g' ./bundles.yaml
-        # Choose the external port to go out from gateway to use.
-         sed -i -- 's/#ext-port: "eth1"/ext-port: "eth1"/g' ./bundles.yaml
-        # Use host for public API for Orange pod2
-        # sed -i -- 's/#os-public-hostname: api.public-fqdn/os-public-hostname: api.pod2.opnfv.fr/g' ./bundles.yaml
-         ;;
-    'orangepod2' )
-        # As per your lab vip address list be deafult uses 10.4.1.11 - 10.4.1.20
-         sed -i -- 's/10.4.1.1/192.168.2.2/g' ./bundles.yaml
-        # choose the correct interface to use for data network
-         sed -i -- 's/#os-data-network: 10.4.8.0\/21/os-data-network: 192.168.12.0\/24/g' ./bundles.yaml
-        # Choose the external port to go out from gateway to use.
-         sed -i -- 's/#ext-port: "eth1"/ext-port: "eth1"/g' ./bundles.yaml
-        # Use host for public API for Orange pod2
-        # sed -i -- 's/#os-public-hostname: api.public-fqdn/os-public-hostname: api.pod2.opnfv.fr/g' ./bundles.yaml
-         ;;
-     'intelpod6' )
-        # As per your lab vip address list be deafult uses 10.4.1.11 - 10.4.1.20
-         sed -i -- 's/10.4.1.1/10.6.1.2/g' ./bundles.yaml
-        # choose the correct interface to use for data network
-         sed -i -- 's/#os-data-network: 10.4.8.0\/21/os-data-network: 10.6.12.0\/24/g' ./bundles.yaml
-        # Choose the external port to go out from gateway to use.
-         sed -i -- 's/#ext-port: "eth1"/ext-port: "eth5"/g' ./bundles.yaml
-        # Provide the gateway MAC to route the traffic externally.
-         sed -i -- 's/#gateway-mac: "default"/gateway-mac: "default"/g' ./bundles.yaml
-         ;;
-     'intelpod5' )
-        # As per your lab vip address list be deafult uses 10.4.1.11 - 10.4.1.20
-         sed -i -- 's/10.4.1.1/10.5.1.2/g' ./bundles.yaml
-        # choose the correct interface to use for data network
-         sed -i -- 's/#os-data-network: 10.4.8.0\/21/os-data-network: 10.5.12.0\/24/g' ./bundles.yaml
-        # Choose the external port to go out from gateway to use.
-         sed -i -- 's/#ext-port: "eth1"/ext-port: "eth5"/g' ./bundles.yaml
-        # Provide the gateway MAC to route the traffic externally.
-         sed -i -- 's/#gateway-mac: "default"/gateway-mac: "default"/g' ./bundles.yaml
-        ;;
-     'attvirpod1' )
-        # As per your lab vip address list be deafult uses 10.4.1.11 - 10.4.1.20
-         sed -i -- 's/10.4.1.1/192.168.10.1/g' ./bundles.yaml
-        # Choose the external port to go out from gateway to use.
-         sed -i -- 's/#ext-port: "eth1"/ext-port: "eth1"/g' ./bundles.yaml
-        ;;
-     'cengnlynxpod1' )
-        # Chose the hard drive(s) to use for CEPH OSD
-         sed -i -- 's|osd-devices: /srv|osd-devices: /dev/sdb|g' ./bundles.yaml
-        # As per your lab vip address list be deafult uses 10.4.1.11 - 10.4.1.20
-         sed -i -- 's/10.4.1.1/10.120.0.1/g' ./bundles.yaml
-        # choose the correct interface to use for data network
-         sed -i -- 's/#os-data-network: 10.4.8.0\/21/os-data-network: 172.16.121.0\/24/g' ./bundles.yaml
-        # Choose the external port to go out from gateway to use.
-         sed -i -- 's/#ext-port: "eth1"/ext-port: "eth1.1202"/g' ./bundles.yaml
-        ;;
      'juniperpod1' )
          sed -i -- 's/10.4.1.1/172.16.50.1/g' ./bundles.yaml
          sed -i -- 's/#ext-port: "eth1"/ext-port: "eth1"/g' ./bundles.yaml
@@ -88,59 +84,81 @@ case "$3" in
      'ravellodemopod' )
          sed -i -- 's/#ext-port: "eth1"/ext-port: "eth2"/g' ./bundles.yaml
         ;;
-     'custom' )
-         sed -i -- 's/10.4.1.1/192.168.122.1/g' ./bundles.yaml
-         sed -i -- 's/#ext-port: "eth1"/ext-port: "eth1"/g' ./bundles.yaml
-        ;;
      'default' )
          sed -i -- 's/10.4.1.1/192.168.122.1/g' ./bundles.yaml
          sed -i -- 's/#ext-port: "eth1"/ext-port: "eth1"/g' ./bundles.yaml
         ;;
 esac
 
-case "$5" in
-    'ipv6' )
-         sed -i -- 's/#prefer-ipv6: true/prefer-ipv6: true/g' ./bundles.yaml
-        ;;
-    'dvr' )
-         sed -i -- 's/#enable-dvr: true/enable-dvr: true/g' ./bundles.yaml
-         sed -i -- 's/#l2-population: true/l2-population: true/g' ./bundles.yaml
-        ;;
-    'sfc' )
-         sed -i -- 's/profile: "openvswitch-odl-Be"/profile: "openvswitch-odl-beryllium-sfc"/g' ./bundles.yaml
-        ;;
-    'vpn' )
-         sed -i -- 's/profile: "openvswitch-odl-Be"/profile: "openvswitch-odl-beryllium-vpn"/g' ./bundles.yaml
+# lets put the if seperateor as "," as this will save me from world.
+fea=""
+IFS=","
+for feature in $5; do
+    if [ "$fea" == "" ]; then
+        fea=$feature
+    else
+        fea=$fea"_"$feature
+    fi
+    case "$feature" in
+        'ipv6' )
+             sed -i -- 's/#prefer-ipv6: true/prefer-ipv6: true/g' ./bundles.yaml
+            ;;
+        'dvr' )
+             sed -i -- 's/#enable-dvr: true/enable-dvr: true/g' ./bundles.yaml
+             sed -i -- 's/#l2-population: true/l2-population: true/g' ./bundles.yaml
+            ;;
+        'sfc' )
+             sed -i -- 's/profile: "openvswitch-odl-Be"/profile: "openvswitch-odl-beryllium-sfc"/g' ./bundles.yaml
+            ;;
+        'vpn' )
+             sed -i -- 's/profile: "openvswitch-odl-Be"/profile: "openvswitch-odl-beryllium-vpn"/g' ./bundles.yaml
+            ;;
+        'odl_l3' )
+             sed -i -- 's/profile: "openvswitch-odl-Be"/profile: "openvswitch-odl-beryllium-l3"/g' ./bundles.yaml
+            ;;
+        'dpdk' )
+             sed -i -- 's/#enable-dpdk: true/enable-dpdk: true/g' ./bundles.yaml
+             sed -i -- 's/#hugepages: "50%"/hugepages: "50%"/g' ./bundles.yaml
+            ;;
+        'lxd' )
+             sed -i -- 's/#- - nova-compute:lxd/- - nova-compute:lxd/g' ./bundles.yaml
+             sed -i -- 's/#- lxd:lxd/- lxd:lxd/g' ./bundles.yaml
+             sed -i -- 's/#virt-type: lxd/virt-type: lxd/g' ./bundles.yaml
+             # adding the lxd subordinate charm
+             echo "    lxd:" >> ./bundles.yaml
+             echo "      charm: local:xenial/lxd" >> ./bundles.yaml
+            ;;
+    esac
+done
+
+#changing the target to the openstack release we want to deploy.
+sed -i -- "s|mitaka|$2|g" ./bundles.yaml
+
+#update source if trusty is target distribution
+case "$6" in
+    'trusty' )
+        sed -i -- "s|#source|source|g" ./bundles.yaml
+        sed -i -- "s|#source-branch:|source-branch:|g" ./bundles.yaml
         ;;
-    'odl_l3' )
-         sed -i -- 's/profile: "openvswitch-odl-Be"/profile: "openvswitch-odl-beryllium-l3"/g' ./bundles.yaml
+    'xenial' )
+        #changing the target to the ubuntu distro we want to deploy.
+        sed -i -- "s|trusty|$6|g" ./bundles.yaml
         ;;
 esac
 
+if [ "$osdomname" != "''" ]; then
+    var=os-$4-$fea-$1-publicapi
+else
+    var=os-$4-$fea-$1
+fi
+
+#lets generate the bundle for all target using genBundle.py
+python genBundle.py  -l deployconfig.yaml  -s $var > bundles.yaml
+
 echo "... Deployment Started ...."
-case "$1" in
-    'nonha' )
-        juju-deployer -vW -d -t 3600 -c bundles.yaml trusty-"$2"-nodes
-        juju-deployer -vW -d -t 7200 -r 5 -c bundles.yaml trusty-"$2"
-        ;;
-    'ha' )
-        juju-deployer -vW -d -t 3600 -c bundles.yaml trusty-"$2"-nodes
-        juju-deployer -vW -d -t 7200 -r 5 -c bundles.yaml trusty-"$2"
-        ;;
-    'tip' )
-        juju-deployer -vW -d -t 3600 -c bundles.yaml trusty-"$2"-nodes
-        juju-deployer -vW -d -t 7200 -r 5 -c bundles.yaml trusty-"$2"
-        ;;
-    * )
-        juju-deployer -vW -d -t 3600 -c bundles.yaml trusty-"$2"-nodes
-        juju-deployer -vW -d -t 7200 -r 5 -c bundles.yaml trusty-"$2"
-        ;;
-esac
+    juju-deployer -vW -d -t 3600 -c bundles.yaml $6-"$2"-nodes
+    check_status
+
+    juju ssh nodes/0 "echo 512 | sudo tee /proc/sys/fs/inotify/max_user_instances"
 
-#case "$4" in
-#    'onos' )
-#         echo "... onos prepare test ..."
-#         sleep 180s
-#         sh onos/juju_test_prepare.sh "$3"
-#        ;;
-#esac
+    juju-deployer -vW -d -t 7200 -r 5 -c bundles.yaml $6-"$2"