Merge "Modify logs publisher"
[ci-management.git] / jjb / hc2vpp / include-raw-hc2vpp-integration-prebuild.sh
index 8c9aed4..dc4ca43 100644 (file)
@@ -1,66 +1,84 @@
 #!/bin/bash
 
 set -ex
-
 # Download the latest VPP java API package
-URL="https://nexus.fd.io/service/local/artifact/maven/content"
 VERSION="RELEASE"
-GROUP="io.fd.vpp"
-ARTIFACTS="vpp-api-java"
+VERSION=`./jvpp-version`
 
-if [ "${OS}" == "ubuntu1404" ]; then
-    OS_PART="ubuntu.trusty.main"
-    PACKAGE="deb deb.md5"
-    CLASS="deb"
-elif [ "${OS}" == "ubuntu1604" ]; then
-    OS_PART="ubuntu.xenial.main"
-    PACKAGE="deb deb.md5"
-    CLASS="deb"
-elif [ "${OS}" == "centos7" ]; then
-    OS_PART="centos7"
-    PACKAGE="rpm rpm.md5"
-    CLASS=""
+# Figure out what system we are running on
+if [[ -f /etc/lsb-release ]];then
+    . /etc/lsb-release
+elif [[ -f /etc/redhat-release ]];then
+    sudo yum install -y redhat-lsb
+    DISTRIB_ID=`lsb_release -si`
+    DISTRIB_RELEASE=`lsb_release -sr`
+    DISTRIB_CODENAME=`lsb_release -sc`
+    DISTRIB_DESCRIPTION=`lsb_release -sd`
 fi
+echo "----- OS INFO -----"
+echo DISTRIB_ID: ${DISTRIB_ID}
+echo DISTRIB_RELEASE: ${DISTRIB_RELEASE}
+echo DISTRIB_CODENAME: ${DISTRIB_CODENAME}
+echo DISTRIB_DESCRIPTION: ${DISTRIB_DESCRIPTION}
 
-if [ "${STREAM}" == "master" ]; then
-    STREAM_PART="master"
-else
-    STREAM_PART="stable.${STREAM}"
+if [[ "$VERSION" == *"-release" ]]; then
+    # at the time when HC2VPP release packages are being build,
+    # jvpp release packages are already promoted to release repository.
+    # Therefore we need to switch to release repository in order to download
+    # correct jvpp package versions
+    STREAM="release"
 fi
 
-REPO="fd.io.${STREAM_PART}.${OS_PART}"
-
-for ART in ${ARTIFACTS}; do
-    for PAC in ${PACKAGE}; do
-        curl "${URL}?r=${REPO}&g=${GROUP}&a=${ART}&p=${PAC}&v=${VERSION}&c=${CLASS}" -O -J || exit
-    done
-done
+echo "----- DOWNLOADING PACKAGES -----"
+if ! [[ -z ${REPO_NAME} ]]; then
+    REPO_URL="https://packagecloud.io/fdio/${STREAM}"
+    echo "REPO_URL: ${REPO_URL}"
+    if [[ "$DISTRIB_ID" == "Ubuntu" ]]; then
+        if [[ -f /etc/apt/sources.list.d/99fd.io.list ]];then
+            echo "Deleting: /etc/apt/sources.list.d/99fd.io.list"
+            sudo rm /etc/apt/sources.list.d/99fd.io.list
+        fi
+        if ! [[ "${STREAM}" == "master" ]]; then
+            echo "stable branch - clearing all fdio repos. new one will be installed."
+            sudo rm  -f /etc/apt/sources.list.d/fdio_*.list
+        fi
+        curl -s https://packagecloud.io/install/repositories/fdio/${STREAM}/script.deb.sh | sudo bash
+        if [[ "${VERSION}" != 'RELEASE' ]]; then
+            # download specific version if set
+            echo VERSION: ${VERSION}
+            apt-get download vpp-api-java=${VERSION} || true
+        else
+            # download latest version for specified stream
+            apt-get download vpp-api-java || true
+        fi
 
-# verify downloaded package
-if [ "${OS}" == "centos7" ]; then
-    FILES=*.rpm
-else
-    FILES=*.deb
+    elif [[ "$DISTRIB_ID" == "CentOS" ]]; then
+        if [[ -f /etc/yum.repos.d/fdio-master.repo ]]; then
+            echo "Deleting: /etc/yum.repos.d/fdio-master.repo"
+            sudo rm /etc/yum.repos.d/fdio-master.repo
+        fi
+        curl -s https://packagecloud.io/install/repositories/fdio/${STREAM}/script.rpm.sh | sudo bash
+        if [[ "${VERSION}" != 'RELEASE' ]]; then
+            # download specific version if set
+            echo VERSION: ${VERSION}
+            yumdownloader vpp-api-java-${VERSION} || true
+        else
+            # download latest version for specified stream
+            yumdownloader vpp-api-java || true
+        fi
+    fi
 fi
 
-for FILE in ${FILES}; do
-    echo " "${FILE} >> ${FILE}.md5
-done
-for MD5FILE in *.md5; do
-    md5sum -c ${MD5FILE} || exit
-    rm ${MD5FILE}
-done
-
 # install vpp-api-java, this extracts jvpp .jar files into usr/share/java
-if [ "${OS}" == "centos7" ]; then
+if [[ "${OS}" == "centos7" ]]; then
     sudo rpm --nodeps --install vpp-api-java*
 else
-    sudo dpkg --ignore-depends=vpp --install vpp-api-java*
+    sudo dpkg --ignore-depends=vpp,vpp-plugin-core --install vpp-api-java*
 fi
-rm vpp-api-java*
+sudo rm vpp-api-java*
 
 # install jvpp jars into maven repo, so that maven picks them up when building hc2vpp
-version=`./jvpp-version`
+version=`./jvpp/version`
 
 current_dir=`pwd`
 cd /usr/share/java
@@ -71,7 +89,7 @@ for item in jvpp*.jar; do
     # Version = 17.01
     basefile=$(basename -s .jar "$item")
     artifactId=$(echo "$basefile" | cut -d '-' -f 1-2)
-    mvn install:install-file -Dfile=${item} -DgroupId=io.fd.vpp -DartifactId=${artifactId} -Dversion=${version} -Dpackaging=jar -Dmaven.repo.local=/tmp/r -Dorg.ops4j.pax.url.mvn.localRepository=/tmp/r
+    mvn install:install-file -Dfile=${item} -DgroupId=io.fd.jvpp -DartifactId=${artifactId} -Dversion=${version} -Dpackaging=jar -Dmaven.repo.local=/tmp/r -Dorg.ops4j.pax.url.mvn.localRepository=/tmp/r
 done
 
 cd ${current_dir}