X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/98036435a54261258faadedeef0675eecfe4ff39..8f8a0ac695f4440412de0245fc748c2792cb1496:/build/run-build-packages-one-target.sh?ds=sidebyside diff --git a/build/run-build-packages-one-target.sh b/build/run-build-packages-one-target.sh index e5e7f0bfa4..c981b2a9ef 100755 --- a/build/run-build-packages-one-target.sh +++ b/build/run-build-packages-one-target.sh @@ -1,4 +1,7 @@ #!/bin/bash +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 read -rd "\000" helpmessage < - Distribution to build packages for (default: debian7) + Distribution to build packages for (default: debian8) --command Build command to execute (default: use built-in Docker image command) --test-packages - Run package install test script "test-packages-$target.sh" + Run package install test script "test-packages-[target].sh" --debug Output debug information (default: false) ---only-test +--only-build + Build only a specific package +--only-test Test only a specific package +--build-version + Version to build (default: + \$ARVADOS_BUILDING_VERSION-\$ARVADOS_BUILDING_ITERATION or + 0.1.timestamp.commithash) WORKSPACE=path Path to the Arvados source tree to build packages from @@ -40,13 +49,13 @@ if ! [[ -d "$WORKSPACE" ]]; then fi PARSEDOPTS=$(getopt --name "$0" --longoptions \ - help,debug,test-packages,target:,command:,only-test: \ + help,debug,test-packages,target:,command:,only-test:,only-build:,build-version: \ -- "" "$@") if [ $? -ne 0 ]; then exit 1 fi -TARGET=debian7 +TARGET=debian8 COMMAND= DEBUG= @@ -62,10 +71,15 @@ while [ $# -gt 0 ]; do TARGET="$2"; shift ;; --only-test) + test_packages=1 packages="$2"; shift ;; + --only-build) + ONLY_BUILD="$2"; shift + ;; --debug) DEBUG=" --debug" + ARVADOS_DEBUG="1" ;; --command) COMMAND="$2"; shift @@ -73,6 +87,18 @@ while [ $# -gt 0 ]; do --test-packages) test_packages=1 ;; + --build-version) + if [[ -z "$2" ]]; then + : + elif ! [[ "$2" =~ (.*)-(.*) ]]; then + echo >&2 "FATAL: --build-version '$2' does not include an iteration. Try '${2}-1'?" + exit 1 + else + ARVADOS_BUILDING_VERSION="${BASH_REMATCH[1]}" + ARVADOS_BUILDING_ITERATION="${BASH_REMATCH[2]}" + fi + shift + ;; --) if [ $# -gt 1 ]; then echo >&2 "$0: unrecognized argument '$2'. Try: $0 --help" @@ -85,14 +111,28 @@ done set -e +if [[ -n "$ARVADOS_BUILDING_VERSION" ]]; then + echo "build version='$ARVADOS_BUILDING_VERSION', package iteration='$ARVADOS_BUILDING_ITERATION'" +fi + if [[ -n "$test_packages" ]]; then - if [[ -n "$(find $WORKSPACE/packages/$TARGET -name *.rpm)" ]] ; then + if [[ -n "$(find $WORKSPACE/packages/$TARGET -name '*.rpm')" ]] ; then + set +e + /usr/bin/which createrepo >/dev/null + if [[ "$?" != "0" ]]; then + echo >&2 + echo >&2 "Error: please install createrepo. E.g. sudo apt-get install createrepo" + echo >&2 + exit 1 + fi + set -e createrepo $WORKSPACE/packages/$TARGET fi - if [[ -n "$(find $WORKSPACE/packages/$TARGET -name *.deb)" ]] ; then + if [[ -n "$(find $WORKSPACE/packages/$TARGET -name '*.deb')" ]] ; then (cd $WORKSPACE/packages/$TARGET - dpkg-scanpackages . 2> >(grep -v 'warning' 1>&2) | gzip -c > Packages.gz + dpkg-scanpackages . 2> >(grep -v 'warning' 1>&2) | tee Packages | gzip -c > Packages.gz + apt-ftparchive -o APT::FTPArchive::Release::Origin=Arvados release . > Release ) fi @@ -121,29 +161,26 @@ popd if test -z "$packages" ; then packages="arvados-api-server - arvados-data-manager + arvados-client arvados-docker-cleaner arvados-git-httpd arvados-node-manager arvados-src arvados-workbench + crunch-dispatch-local + crunch-dispatch-slurm + crunch-run crunchstat + keep-balance + keep-block-check keepproxy keep-rsync keepstore keep-web - libarvados-perl" - - case "$TARGET" in - centos6) - packages="$packages python27-python-arvados-fuse - python27-python-arvados-python-client python27-python-arvados-cwl-runner" - ;; - *) - packages="$packages python-arvados-fuse - python-arvados-python-client python-arvados-cwl-runner" - ;; - esac + libarvados-perl + python-arvados-fuse + python-arvados-python-client + python-arvados-cwl-runner" fi FINAL_EXITCODE=0 @@ -164,11 +201,14 @@ docker_volume_args=( if [[ -n "$test_packages" ]]; then for p in $packages ; do + if [[ -n "$ONLY_BUILD" ]] && [[ "$p" != "$ONLY_BUILD" ]]; then + continue + fi echo echo "START: $p test on $IMAGE" >&2 if docker run --rm \ "${docker_volume_args[@]}" \ - --env ARVADOS_DEBUG=1 \ + --env ARVADOS_DEBUG=$ARVADOS_DEBUG \ --env "TARGET=$TARGET" \ --env "WORKSPACE=/arvados" \ "$IMAGE" $COMMAND $p @@ -183,9 +223,20 @@ if [[ -n "$test_packages" ]]; then else echo echo "START: build packages on $IMAGE" >&2 + # Move existing packages and other files into the processed/ subdirectory + if [[ ! -e "${WORKSPACE}/packages/${TARGET}/processed" ]]; then + mkdir -p "${WORKSPACE}/packages/${TARGET}/processed" + fi + set +e + mv -f ${WORKSPACE}/packages/${TARGET}/* ${WORKSPACE}/packages/${TARGET}/processed/ 2>/dev/null + set -e + # Build packages if docker run --rm \ "${docker_volume_args[@]}" \ - --env ARVADOS_DEBUG=1 \ + --env ARVADOS_BUILDING_VERSION="$ARVADOS_BUILDING_VERSION" \ + --env ARVADOS_BUILDING_ITERATION="$ARVADOS_BUILDING_ITERATION" \ + --env ARVADOS_DEBUG=$ARVADOS_DEBUG \ + --env "ONLY_BUILD=$ONLY_BUILD" \ "$IMAGE" $COMMAND then echo