3cb98030d4
Since we can call package building in form [1]: bash build-fuel-{pkg_type}.sh we need to use more robust way to define absolute path to perestroika ${ROOT} [1]. https://github.com/fuel-infra/jenkins-jobs/blob/master/\ servers/pkgs-ci/fuel-pkg-pipeline.yaml#L104 Change-Id: I21c6cae2fee7c67e3849b65ecca49ca1714c007a
153 lines
7.1 KiB
Bash
Executable File
153 lines
7.1 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
set -o xtrace
|
|
set -o errexit
|
|
|
|
[ -f ".packages-defaults" ] && source .packages-defaults
|
|
BINDIR=$(dirname `readlink -e $0`)
|
|
source "${BINDIR}"/build-functions.sh
|
|
|
|
main () {
|
|
set_default_params
|
|
# Get package tree from gerrit
|
|
fetch_upstream
|
|
local _srcpath="${MYOUTDIR}/${PACKAGENAME}-src"
|
|
local _specpath=$_srcpath
|
|
local _testspath=$_srcpath
|
|
[ "$IS_OPENSTACK" == "true" ] && _specpath="${MYOUTDIR}/${PACKAGENAME}-spec${SPEC_PREFIX_PATH}" && _testspath="${MYOUTDIR}/${PACKAGENAME}-spec"
|
|
local _debianpath=$_specpath
|
|
|
|
if [ -d "${_debianpath}/debian" ] ; then
|
|
# Unpacked sources and specs
|
|
local srcpackagename=`head -1 ${_debianpath}/debian/changelog | cut -d' ' -f1`
|
|
local version=`head -1 ${_debianpath}/debian/changelog | sed 's|^.*(||;s|).*$||' | awk -F "-" '{print $1}'`
|
|
local binpackagenames="`cat ${_debianpath}/debian/control | grep ^Package | cut -d' ' -f 2 | tr '\n' ' '`"
|
|
local epochnumber=`head -1 ${_debianpath}/debian/changelog | grep -o "(.:" | sed 's|(||'`
|
|
local distro=`head -1 ${_debianpath}/debian/changelog | awk -F'[ ;]' '{print $3}'`
|
|
|
|
# Get last commit info
|
|
# $message $author $email $cdate $commitsha $lastgitlog
|
|
get_last_commit_info ${_srcpath}
|
|
|
|
TAR_NAME="${srcpackagename}_${version#*:}.orig.tar.gz"
|
|
if [ "$IS_OPENSTACK" == "true" ] ; then
|
|
# Get version number from the latest git tag for openstack packages
|
|
local release_tag=$(git -C $_srcpath describe --abbrev=0)
|
|
# Deal with PyPi versions like 2015.1.0rc1
|
|
# It breaks version comparison
|
|
# Change it to 2015.1.0~rc1
|
|
local convert_version_py="$(dirname $(readlink -e $0))/convert-version.py"
|
|
version=$(python ${convert_version_py} --tag ${release_tag})
|
|
local TAR_NAME="${srcpackagename}_${version}.orig.tar.gz"
|
|
# Get revision number as commit count for src+spec projects
|
|
local _src_commit_count=`git -C $_srcpath rev-list --no-merges origin/${SOURCE_BRANCH} | wc -l`
|
|
local _spec_commit_count=`git -C $_specpath rev-list --no-merges origin/${SPEC_BRANCH} | wc -l`
|
|
local _rev=$(( $_src_commit_count + $_spec_commit_count ))
|
|
[ "$GERRIT_CHANGE_STATUS" == "NEW" ] && _rev=$(( $_rev + 1 ))
|
|
local release="1~u14.04+mos${_rev}"
|
|
[ "$GERRIT_CHANGE_STATUS" == "NEW" ] && release="${release}+git.${gitshasrc}.${gitshaspec}"
|
|
local fullver=${epochnumber}${version}-${release}
|
|
# Update version and changelog
|
|
local firstline=1
|
|
local _dchopts="-c ${_debianpath}/debian/changelog"
|
|
echo "$lastgitlog" | while read LINE; do
|
|
[ $firstline == 1 ] && local cmd="dch $_dchopts -D $distro -b --force-distribution -v $fullver" || local cmd="dch $_dchopts -a"
|
|
firstline=0
|
|
local commitid=`echo "$LINE" | cut -d'|' -f1`
|
|
local email=`echo "$LINE" | cut -d'|' -f2`
|
|
local author=`echo "$LINE" | cut -d'|' -f3`
|
|
local subject=`echo "$LINE" | cut -d'|' -f4`
|
|
DEBFULLNAME="$author" DEBEMAIL="$email" $cmd "$commitid $subject"
|
|
done
|
|
# Prepare source tarball
|
|
pushd $_srcpath &>/dev/null
|
|
if [ "$PACKAGENAME" == "murano-apps" -o "$PACKAGENAME" == "rally" ]; then
|
|
# Do not perform `setup.py sdist` for murano-apps and rally packages
|
|
tar -czf ${BUILDDIR}/$TAR_NAME $EXCLUDES .
|
|
else
|
|
python setup.py --version # this will download pbr if it's not available
|
|
PBR_VERSION=$release_tag python setup.py sdist -d ${BUILDDIR}/
|
|
# Fix source folder name at sdist tarball
|
|
local sdist_tarball=$(find ${BUILDDIR}/ -maxdepth 1 -name "*.gz")
|
|
if [ "$(tar -tf $sdist_tarball | head -n 1 | cut -d'/' -f1)" != "${srcpackagename}-${version}" ] ; then
|
|
# rename source folder
|
|
local tempdir=$(mktemp -d)
|
|
tar -C $tempdir -xf $sdist_tarball
|
|
mv $tempdir/* $tempdir/${srcpackagename}-${version}
|
|
tar -C $tempdir -czf ${BUILDDIR}/$TAR_NAME ${srcpackagename}-${version}
|
|
rm -f $sdist_tarball
|
|
[ -d "$tempdir" ] && rm -rf $tempdir
|
|
else
|
|
mv $sdist_tarball ${BUILDDIR}/$TAR_NAME || :
|
|
fi
|
|
fi
|
|
popd &>/dev/null
|
|
else
|
|
# Update changelog
|
|
DEBFULLNAME=$author DEBEMAIL=$email dch -c ${_debianpath}/debian/changelog -a "$commitsha $message"
|
|
# Prepare source tarball
|
|
# Exclude debian and tests dir
|
|
mv ${_srcpath}/debian ${_srcpath}/renameforexcludedebian
|
|
[ -d "${_srcpath}/tests" ] && mv ${_srcpath}/tests ${_srcpath}/renameforexcludetests
|
|
pushd ${_srcpath} &>/dev/null
|
|
tar -czf "${BUILDDIR}/${TAR_NAME}" $EXCLUDES --exclude=renameforexcludedebian --exclude=renameforexcludetests *
|
|
popd &>/dev/null
|
|
mv ${_srcpath}/renameforexcludedebian ${_srcpath}/debian
|
|
[ -d "${_srcpath}/renameforexcludetests" ] && mv ${_srcpath}/renameforexcludetests ${_srcpath}/tests
|
|
fi
|
|
mkdir -p ${BUILDDIR}/$srcpackagename
|
|
cp -R ${_debianpath}/debian ${BUILDDIR}/${srcpackagename}/
|
|
else
|
|
# Packed sources (.dsc + .gz )
|
|
cp ${_srcpath}/* $BUILDDIR
|
|
fi
|
|
# Prepare tests folder to provide as parameter
|
|
rm -f ${WRKDIR}/tests.envfile
|
|
[ -d "${_testspath}/tests" ] && echo "TESTS_CONTENT='`tar -cz -C ${_testspath} tests | base64 -w0`'" > ${WRKDIR}/tests.envfile
|
|
|
|
# Build stage
|
|
local REQUEST=$REQUEST_NUM
|
|
[ -n "$LP_BUG" ] && REQUEST=$LP_BUG
|
|
|
|
COMPONENTS="main restricted"
|
|
EXTRAREPO="http://${REMOTE_REPO_HOST}/${DEB_REPO_PATH} ${DEB_DIST_NAME} ${COMPONENTS}"
|
|
[ "$IS_UPDATES" == 'true' ] \
|
|
&& EXTRAREPO="${EXTRAREPO}|http://${REMOTE_REPO_HOST}/${DEB_REPO_PATH} ${DEB_PROPOSED_DIST_NAME} ${COMPONENTS}"
|
|
[ "$GERRIT_CHANGE_STATUS" == "NEW" ] && [ "$IS_UPDATES" == "false" ] \
|
|
&& EXTRAREPO="${EXTRAREPO}|http://${REMOTE_REPO_HOST}/${REPO_REQUEST_PATH_PREFIX}/${REQUEST}/${DEB_REPO_PATH} ${DEB_DIST_NAME} ${COMPONENTS}"
|
|
[ "$GERRIT_CHANGE_STATUS" == "NEW" ] && [ "$IS_UPDATES" == "true" ] \
|
|
&& EXTRAREPO="${EXTRAREPO}|http://${REMOTE_REPO_HOST}/${REPO_REQUEST_PATH_PREFIX}/${REQUEST}/${DEB_REPO_PATH} ${DEB_PROPOSED_DIST_NAME} ${COMPONENTS}"
|
|
export EXTRAREPO
|
|
|
|
pushd $BUILDDIR &>/dev/null
|
|
echo "BUILD_SUCCEEDED=false" > ${WRKDIR}/buildresult.params
|
|
bash -ex ${BINDIR}/docker-builder/build-deb-package.sh
|
|
local exitstatus=`cat buildresult/exitstatus.sbuild || echo 1`
|
|
rm -f buildresult/exitstatus.sbuild
|
|
[ -f "buildresult/buildlog.sbuild" ] && mv buildresult/buildlog.sbuild ${WRKDIR}/buildlog.txt
|
|
fill_buildresult $exitstatus 0 $PACKAGENAME DEB
|
|
if [ "$exitstatus" == "0" ] ; then
|
|
tmpdir=`mktemp -d ${PKG_DIR}/build-XXXXXXXX`
|
|
rm -f ${WRKDIR}/buildresult.params
|
|
cat >${WRKDIR}/buildresult.params<<-EOL
|
|
BUILD_HOST=`hostname -f`
|
|
PKG_PATH=$tmpdir
|
|
GERRIT_CHANGE_STATUS=$GERRIT_CHANGE_STATUS
|
|
REQUEST_NUM=$REQUEST_NUM
|
|
LP_BUG=$LP_BUG
|
|
IS_SECURITY=$IS_SECURITY
|
|
EXTRAREPO="$EXTRAREPO"
|
|
REPO_TYPE=deb
|
|
DIST=$DIST
|
|
EOL
|
|
mv buildresult/* $tmpdir/
|
|
fi
|
|
popd &>/dev/null
|
|
|
|
exit $exitstatus
|
|
}
|
|
|
|
main "$@"
|
|
|
|
exit 0
|