From: Praneta Paithankar Date: Fri, 10 Aug 2018 13:54:33 +0000 (-0700) Subject: Automate vCPE vG-MUX and VG build image process X-Git-Tag: 1.3.0~75^2 X-Git-Url: https://gerrit.onap.org/r/gitweb?a=commitdiff_plain;ds=sidebyside;h=302c1e502c8d5fa1f07b8683b81c7bd762da3582;p=demo.git Automate vCPE vG-MUX and VG build image process 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 --- diff --git a/heat/vCPE/vgmux/base_vcpe_vgmux.yaml b/heat/vCPE/vgmux/base_vcpe_vgmux.yaml index 220c88fc..2bbf65c7 100644 --- a/heat/vCPE/vgmux/base_vcpe_vgmux.yaml +++ b/heat/vCPE/vgmux/base_vcpe_vgmux.yaml @@ -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 diff --git a/heat/vCPE/vgmux/build_vcpe_vgmux.yaml b/heat/vCPE/vgmux/build_vcpe_vgmux.yaml index c2bd4f4d..ea007666 100644 --- a/heat/vCPE/vgmux/build_vcpe_vgmux.yaml +++ b/heat/vCPE/vgmux/build_vcpe_vgmux.yaml @@ -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 diff --git a/heat/vCPE/vgw/base_vcpe_vgw.yaml b/heat/vCPE/vgw/base_vcpe_vgw.yaml index e58634c6..5167c0a0 100644 --- a/heat/vCPE/vgw/base_vcpe_vgw.yaml +++ b/heat/vCPE/vgw/base_vcpe_vgw.yaml @@ -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 diff --git a/heat/vCPE/vgw/build_vcpe_vgw.yaml b/heat/vCPE/vgw/build_vcpe_vgw.yaml index a80d1ef3..3bd8532b 100644 --- a/heat/vCPE/vgw/build_vcpe_vgw.yaml +++ b/heat/vCPE/vgw/build_vcpe_vgw.yaml @@ -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 diff --git a/vnfs/vCPE/scripts/v_gmux_build.sh b/vnfs/vCPE/scripts/v_gmux_build.sh index da357b03..b85445a6 100644 --- a/vnfs/vCPE/scripts/v_gmux_build.sh +++ b/vnfs/vCPE/scripts/v_gmux_build.sh @@ -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 "" | 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 diff --git a/vnfs/vCPE/scripts/v_gmux_install.sh b/vnfs/vCPE/scripts/v_gmux_install.sh index c9162aac..b6796c27 100644 --- a/vnfs/vCPE/scripts/v_gmux_install.sh +++ b/vnfs/vCPE/scripts/v_gmux_install.sh @@ -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 diff --git a/vnfs/vCPE/scripts/v_gw_build.sh b/vnfs/vCPE/scripts/v_gw_build.sh index 7c03c385..c8348e41 100644 --- a/vnfs/vCPE/scripts/v_gw_build.sh +++ b/vnfs/vCPE/scripts/v_gw_build.sh @@ -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 "" | 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 diff --git a/vnfs/vCPE/scripts/v_gw_install.sh b/vnfs/vCPE/scripts/v_gw_install.sh index 0b34d05a..107449a7 100644 --- a/vnfs/vCPE/scripts/v_gw_install.sh +++ b/vnfs/vCPE/scripts/v_gw_install.sh @@ -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