Automate vCPE vG-MUX and VG build image process 75/60075/1
authorPraneta Paithankar <praneta.paithankar@intel.com>
Fri, 10 Aug 2018 13:54:33 +0000 (06:54 -0700)
committerPraneta Paithankar <praneta.paithankar@intel.com>
Fri, 10 Aug 2018 13:59:06 +0000 (06:59 -0700)
Build script is executed with its heat template.

script_status.txt in /opt folder will show the status of execution of build and install script.

Issue-ID: INT-620

Change-Id: I4b0b5c49ed20458b21423fc83545203e1aea02f5
Signed-off-by: Praneta Paithankar <praneta.paithankar@intel.com>
heat/vCPE/vgmux/base_vcpe_vgmux.yaml
heat/vCPE/vgmux/build_vcpe_vgmux.yaml
heat/vCPE/vgw/base_vcpe_vgw.yaml
heat/vCPE/vgw/build_vcpe_vgw.yaml
vnfs/vCPE/scripts/v_gmux_build.sh
vnfs/vCPE/scripts/v_gmux_install.sh
vnfs/vCPE/scripts/v_gw_build.sh
vnfs/vCPE/scripts/v_gw_install.sh

index 220c88f..2bbf65c 100644 (file)
@@ -237,7 +237,6 @@ resources:
             if [[ "__script_version__" =~ "SNAPSHOT" ]]; then REPO=snapshots; else REPO=releases; fi
             curl -k -L "__nexus_artifact_repo__/service/local/artifact/maven/redirect?r=${REPO}&g=org.onap.demo.vnf.vcpe&a=vcpe-scripts&e=zip&v=__script_version__" -o /opt/vcpe-scripts-__script_version__.zip
             unzip -j /opt/vcpe-scripts-__script_version__.zip -d /opt v_gmux_install.sh
-            sudo su -
             cd /opt
             chmod +x v_gmux_install.sh
             ./v_gmux_install.sh
index c2bd4f4..ea00766 100644 (file)
@@ -206,7 +206,6 @@ resources:
             if [[ "__script_version__" =~ "SNAPSHOT" ]]; then REPO=snapshots; else REPO=releases; fi
             curl -k -L "__nexus_artifact_repo__/service/local/artifact/maven/redirect?r=${REPO}&g=org.onap.demo.vnf.vcpe&a=vcpe-scripts&e=zip&v=__install_script_version__" -o /opt/vcpe-scripts-__script_version__.zip
             unzip -j /opt/vcpe-scripts-__script_version__.zip -d /opt v_gmux_build.sh
-            sudo su -
             cd /opt
             chmod +x v_gmux_build.sh
             ./v_gmux_build.sh
index e58634c..5167c0a 100644 (file)
@@ -236,7 +236,6 @@ resources:
             if [[ "__script_version__" =~ "SNAPSHOT" ]]; then REPO=snapshots; else REPO=releases; fi
             curl -k -L "__nexus_artifact_repo__/service/local/artifact/maven/redirect?r=${REPO}&g=org.onap.demo.vnf.vcpe&a=vcpe-scripts&e=zip&v=__script_version__" -o /opt/vcpe-scripts-__script_version__.zip
             unzip -j /opt/vcpe-scripts-__script_version__.zip -d /opt v_gw_install.sh
-            sudo su -
             cd /opt
             chmod +x v_gw_install.sh
             ./v_gw_install.sh
index a80d1ef..3bd8532 100644 (file)
@@ -188,7 +188,6 @@ resources:
             if [[ "__script_version__" =~ "SNAPSHOT" ]]; then REPO=snapshots; else REPO=releases; fi
             curl -k -L "__nexus_artifact_repo__/service/local/artifact/maven/redirect?r=${REPO}&g=org.onap.demo.vnf.vcpe&a=vcpe-scripts&e=zip&v=__script_version__" -o /opt/vcpe-scripts-__script_version__.zip
             unzip -j /opt/vcpe-scripts-__script_version__.zip -d /opt v_gw_build.sh
-            sudo su -
             cd /opt
             chmod +x v_gw_build.sh
             ./v_gw_build.sh
index da357b0..b85445a 100644 (file)
@@ -9,7 +9,7 @@ HC2VPP_SOURCE_REPO_RELEASE_TAG=$(cat /opt/config/hc2vpp_source_repo_release_tag.
 HC2VPP_PATCH_URL=$(cat /opt/config/hc2vpp_patch_url.txt)
 LIBEVEL_PATCH_URL=$(cat /opt/config/libevel_patch_url.txt)
 CLOUD_ENV=$(cat /opt/config/cloud_env.txt)
-
+ERROR_MESSAGE="Execution of vG-MUX build script failed. Reason"
 
 # Download required dependencies
 echo "deb http://ppa.launchpad.net/openjdk-r/ppa/ubuntu $(lsb_release -c -s) main" >>  /etc/apt/sources.list.d/java.list
@@ -28,12 +28,14 @@ wget -O Vpp-Add-VES-agent-for-vG-MUX.patch ${VPP_PATCH_URL}
 
 cd vpp
 patch -p1 < ../Vpp-Add-VES-agent-for-vG-MUX.patch
-expect -c "
-        spawn make install-dep;
-        expect {
-                \"Do you want to continue?*\" {send \"Y\r\"; interact}
-        }
-"
+yes Y | make install-dep
+
+# Check vpp build status
+if [ $? -ne 0 ];
+then
+    echo '$ERROR_MESSAGE VPP build failed' > /opt/script_status.txt 
+    exit
+fi
 
 # Install the evel-library first since we need the lib
 cd /opt
@@ -45,6 +47,15 @@ git checkout 312996e2
 patch -p1 < ../vCPE-vG-MUX-libevel-fixup.patch
 cd vnfs/VES5.0/evel/evel-library/bldjobs 
 make
+
+# Check eval-library installation status
+if [ $? -ne 0 ];
+then
+    echo '$ERROR_MESSAGE Installation of eval-library failed' > /opt/script_status.txt 
+    exit
+fi
+
+
 cp ../libs/x86_64/libevel.so /usr/lib
 ldconfig
 
@@ -52,11 +63,24 @@ cd /opt/vpp/build-root
 ./bootstrap.sh
 make V=0 PLATFORM=vpp TAG=vpp install-deb
 
+# Check vpp/build-root build status
+if [ $? -ne 0 ];
+then
+    echo '$ERROR_MESSAGE VPP/build-root build failed' > /opt/script_status.txt 
+    exit
+fi
+
 # Install the VPP package
 apt install -y python-ply-lex-3.5 python-ply-yacc-3.5 python-pycparser python-cffi
 dpkg -i *.deb
-systemctl stop vpp
 
+# Check VPP package installation status
+if [ $? -ne 0 ];
+then
+    echo '$ERROR_MESSAGE Installation of VPP package failed' > /opt/script_status.txt 
+    exit
+fi
+systemctl stop vpp
 
 
 # Download and install HC2VPP from source
@@ -183,6 +207,14 @@ p_version=$(echo "${p_version_snap%-*}")
 mkdir -p  ~/.m2/repository/io/fd/vpp/jvpp-ves/${p_version_snap}
 mvn install:install-file -Dfile=/usr/share/java/jvpp-ves-${p_version}.jar -DgroupId=io.fd.vpp -DartifactId=jvpp-ves -Dversion=${p_version_snap} -Dpackaging=jar
 mvn clean install -nsu -DskipTests=true
+
+# Check hc2vpp installation status
+if [ $? -ne 0 ];
+then
+    echo '$ERROR_MESSAGE Installation of hc2vpp failed' > /opt/script_status.txt 
+    exit
+fi
+
 l_version=$(cat pom.xml | grep "<version>" | head -1)
 l_version=$(echo "${l_version%<*}")
 l_version=$(echo "${l_version#*>}")
@@ -196,4 +228,5 @@ then
     sed -i 's/\(APT::Periodic::Unattended-Upgrade\) "1"/\1 "0"/' /etc/apt/apt.conf.d/20auto-upgrades
 fi
 
+echo 'Execution of vG-MUX build script completed' > /opt/script_status.txt
 
index c9162aa..b6796c2 100644 (file)
@@ -364,8 +364,10 @@ then
     sed -i "s/ens[0-9]*/eth0/g" /etc/network/interfaces.d/*.cfg
     sed -i "s/ens[0-9]*/eth0/g" /etc/udev/rules.d/70-persistent-net.rules
     echo 'network: {config: disabled}' >> /etc/cloud/cloud.cfg.d/99-disable-network-config.cfg
+    echo 'Execution of vG-MUX install script completed' > /opt/script_status.txt
     reboot
 fi
 
 ./v_gmux_init.sh
+echo 'Execution of vG-MUX install script completed' > /opt/script_status.txt
 
index 7c03c38..c8348e4 100644 (file)
@@ -6,7 +6,7 @@ VPP_SOURCE_REPO_RELEASE_TAG=$(cat /opt/config/vpp_source_repo_release_tag.txt)
 HC2VPP_SOURCE_REPO_URL=$(cat /opt/config/hc2vpp_source_repo_url.txt)
 HC2VPP_SOURCE_REPO_RELEASE_TAG=$(cat /opt/config/hc2vpp_source_repo_release_tag.txt)
 CLOUD_ENV=$(cat /opt/config/cloud_env.txt)
-
+ERROR_MESSAGE= "Execution of vGbuild script failed. Reason:"
 
 # Download required dependencies
 echo "deb http://ppa.launchpad.net/openjdk-r/ppa/ubuntu $(lsb_release -c -s) main" >>  /etc/apt/sources.list.d/java.list
@@ -26,23 +26,44 @@ cd /opt
 git clone ${VPP_SOURCE_REPO_URL} -b ${VPP_SOURCE_REPO_RELEASE_TAG} vpp
 
 cd vpp
-yes y | make install-dep
+yes Y | make install-dep
+
+# Check vpp build status
+if [ $? -ne 0 ];
+then
+    echo '$ERROR_MESSAGE VPP build failed' > /opt/script_status.txt 
+    exit
+fi
 
 cd build-root
 ./bootstrap.sh
 make V=0 PLATFORM=vpp TAG=vpp install-deb
 
+# Check vpp/build-root build status
+if [ $? -ne 0 ];
+then
+    echo '$ERROR_MESSAGE VPP/build-root build failed' > /opt/script_status.txt 
+    exit
+fi
+
+apt --allow-unauthenticated install -y python-ply-lex-3.5 python-ply-yacc-3.5 python-pycparser python-cffi
+
 # Install the VPP package
 dpkg -i *.deb
-systemctl stop vpp
 
+# Check vpp package installation status
+if [ $? -ne 0 ];
+then
+    echo '$ERROR_MESSAGE VPP package installation failed' > /opt/script_status.txt 
+    exit
+fi
+
+systemctl stop vpp
 
 
 # Download and install HC2VPP from source
 cd /opt
 git clone ${HC2VPP_SOURCE_REPO_URL} -b ${HC2VPP_SOURCE_REPO_RELEASE_TAG} hc2vpp
-
-apt --allow-unauthenticated install -y python-ply-lex-3.5 python-ply-yacc-3.5 python-pycparser python-cffi
 apt-get install -y maven
 mkdir -p ~/.m2
 cat > ~/.m2/settings.xml << EOF
@@ -155,6 +176,14 @@ EOF
 
 cd hc2vpp
 mvn clean install
+
+# Check hc2vpp build status
+if [ $? -ne 0 ];
+then
+    echo '$ERROR_MESSAGE hc2vpp build failed' > /opt/script_status.txt 
+    exit
+fi
+
 l_version=$(cat pom.xml | grep "<version>" | head -1)
 l_version=$(echo "${l_version%<*}")
 l_version=$(echo "${l_version#*>}")
@@ -168,3 +197,4 @@ then
     sed -i 's/\(APT::Periodic::Unattended-Upgrade\) "1"/\1 "0"/' /etc/apt/apt.conf.d/20auto-upgrades
 fi
 
+echo 'Execution of vG build script completed' > /opt/script_status.txt
index 0b34d05..107449a 100644 (file)
@@ -261,6 +261,7 @@ then
     sed -i "s/ens[0-9]*/eth0/g" /etc/network/interfaces.d/*.cfg
     #sed -i "s/ens[0-9]*/eth0/g" /etc/udev/rules.d/70-persistent-net.rules
     echo 'network: {config: disabled}' >> /etc/cloud/cloud.cfg.d/99-disable-network-config.cfg
+    echo 'Execution of vG install script completed' > /opt/script_status.txt
     reboot
 fi
-
+echo 'Execution of vG install script completed' > /opt/script_status.txt