Better output directory format (human readable)

Use commits SHA hashes as unique references
This commit is contained in:
gdm85 2015-01-16 10:53:12 +01:00
parent 0f0c14a80a
commit 3aaaa2e188
2 changed files with 74 additions and 35 deletions

View File

@ -7,11 +7,11 @@
#
if [ $# -lt 2 ]; then
echo "Usage: build-bitcoin.sh version linux [win] [osx] [...]" 1>&2
echo "Usage: build-bitcoin.sh commit linux [win] [osx] [...]" 1>&2
exit 1
fi
VERSION="$1"
COMMIT="$1"
shift
## remaining parameters are OS targets to be build (e.g. win,osx,linux)
@ -29,19 +29,20 @@ cd .. || exit $?
if [ ! -d bitcoin ]; then
git clone https://github.com/bitcoin/bitcoin.git && \
cd bitcoin && \
git checkout v$VERSION && \
git checkout $COMMIT && \
cd .. || exit $?
fi
## old logic using descriptors (only linux supported
if ! verlte 0.10.0rc1 ${VERSION}; then
## old logic using descriptors (only linux supported)
if echo "$COMMIT" | grep ^v >/dev/null && ! verlte v0.10.0rc1 $COMMIT; then
## make sure only Linux is being built
if [[ ! $# -eq 1 && "$1" != "linux" ]]; then
echo "For versions before 0.10.0rc1, only Linux building is supported" 1>&2
exit 1
fi
VERSION=$(echo "$COMMIT" | awk '{ print substr($0, 2) }')
cd gitian-builder/inputs || exit $?
## get each dependency
## they are validated afterwards by gbuild
@ -75,7 +76,7 @@ fi
## proceed to build of each of the specified gitian descriptors
cd gitian-builder || exit $?
for DESC in $@; do
./bin/gbuild -j$NPROC --commit bitcoin=v$VERSION -u bitcoin=$CLONE "$CLONE/contrib/gitian-descriptors/gitian-${DESC}.yml" || exit $?
./bin/gbuild -j$NPROC --commit bitcoin=$COMMIT -u bitcoin=$CLONE "$CLONE/contrib/gitian-descriptors/gitian-${DESC}.yml" || exit $?
done
echo "Build completed successfully, output files are in: ~/gitian-builder/build/out/"
echo "Successfully built gitian-${DESC} at $COMMIT"

View File

@ -15,9 +15,6 @@ SCRIPTS=$(dirname $(readlink -m $0)) || exit $?
## place this file in script's directory in order to build for Mac OS X
SDK=MacOSX10.7.sdk.tar.gz
## change the assert directory as desired
SIGNER="$USER"
if [ $# -lt 1 ]; then
echo "Usage: gitian-build.sh linux [win] [osx] [...]" 1>&2
exit 1
@ -42,19 +39,21 @@ else
fi
fi
## retrieve latest tagged release/release candidate
set -o pipefail && \
MOSTRECENT="$(curl -s https://api.github.com/repos/bitcoin/bitcoin/tags | jq -r '.[0].name' | awk '{ print substr($0, 2) }')" || exit $?
## change the assert directory as desired
if [ -z "$SIGNER" ]; then
SIGNER="$USER"
fi
## volumes inside container that are provided externally (bind mount)
LRESULT="$SCRIPTS/gitian-result"
LSIGS="$SCRIPTS/gitian-sigs"
LSOURCE="$SCRIPTS/gitian-cache"
LDEST="$SCRIPTS/gitian-built"
CRESULT="/home/debian/gitian-builder/result"
CSIGS="/home/debian/gitian.sigs"
CSOURCE="/home/debian/gitian-builder/cache"
CDEST="/home/debian/gitian-builder/build"
## customize output volumes
if [ -z "$OUTPUTDIR" ]; then
OUTPUTDIR="$SCRIPTS/output"
fi
function read_commit() {
local SHA="$1"
set -o pipefail && \
curl -s https://api.github.com/repos/bitcoin/bitcoin/commits/${SHA} | jq -r '.[0].sha'
}
## run all necessary containers, detached
## setup proper volumes for input/output collection
@ -66,7 +65,7 @@ function run_all() {
rm -rf "$LDEST/${OS}" && \
mkdir -p "$LDEST/${OS}" || return $?
done
mkdir -p "$LSIGS/${MOSTRECENT}/${SIGNER}" && \
mkdir -p "$LSIGS" && \
mkdir -p "$LSOURCE" && \
mkdir -p "$LRESULT" && \
chown -R 1000.1000 "$LDEST" "$LSOURCE" "$LSIGS" "$LRESULT" || return $?
@ -104,28 +103,67 @@ function build_all() {
I=0
for CID in "${CREATED[@]}"; do
OS=${OSES[$I]}
local OS_LOG_FILE="$LLOGS/build-${OS}.log"
echo "Execution log for ${OS} ({$HCOMMIT}) --> $OS_LOG_FILE" 1>&2
## first, fix rights of mounted volumes
# echo -n "docker exec $CID chown -R debian.debian '$CSOURCE' '$CDEST' && " && \
echo -n "docker exec $CID su -c 'cd /home/debian && source .bash_profile && ./build-bitcoin.sh $MOSTRECENT ${OS} && " && \
echo "cd gitian-builder && ./bin/gasserts --signer $SIGNER --release ${MOSTRECENT} --destination ../gitian.sigs/ ../bitcoin/contrib/gitian-descriptors/gitian-${OS}.yml' debian"
echo -n "docker exec $CID su -c 'cd /home/debian && source .bash_profile && ./build-bitcoin.sh $COMMIT ${OS} && " && \
echo -n "cd gitian-builder && ./bin/gasserts --signer $SIGNER --release ${HCOMMIT} --destination ../gitian.sigs/ ../bitcoin/contrib/gitian-descriptors/gitian-${OS}.yml' debian " && \
echo " >> $OS_LOG_FILE 2>&1"
let I+=1
done | $PARALLEL
}
set -o pipefail || exit $?
## always get latest release/rc if no commit environment was specified
if [ ! -z "$COMMIT" ]; then
HCOMMIT="$COMMIT"
else
HCOMMIT="$(curl -s https://api.github.com/repos/bitcoin/bitcoin/tags | jq -r '.[0].name' | awk '{ print substr($0, 2) }')" || exit $?
fi
## get commit short hash
## NOTE: this overwrites environment provided by user
COMMIT=$(read_commit "$HCOMMIT") || exit $?
###
### declarations for input/output data volumes
###
## always add human readable commit and commit to volume path variables
REL_OD="$OUTPUTDIR/${HCOMMIT}-${COMMIT}"
LRESULT="${REL_OD}/result-${HCOMMIT}-${COMMIT}"
LSIGS="${REL_OD}/sigs"
LDEST="${REL_OD}/built"
LLOGS="${REL_OD}"
## depends-cache does not sport human readable prefix, being the only input volume for containers
LSOURCE="${OUTPUTDIR}/${COMMIT}/depends-cache"
## path of above volumes inside the containers
CRESULT="/home/debian/gitian-builder/result"
CSIGS="/home/debian/gitian.sigs"
CSOURCE="/home/debian/gitian-builder/cache"
CDEST="/home/debian/gitian-builder/build"
## ---------------- main -------------------- ##
CREATED="$(run_all $@ | tr '\n' ' ')" && \
echo "Building bitcoin v$MOSTRECENT for $@" && \
build_all ${CREATED[@]} $@ && \
echo "Build results are available in '$SCRIPTS/built/'"
echo "Building bitcoin (${HCOMMIT}) for $@" && \
build_all ${CREATED[@]} $@
RV=$?
## cleanup
echo "Cleaning up created containers..."
#echo "Cleaning up created containers..."
for CID in $CREATED; do
# docker stop $CID
# docker rm $CID
docker pause $CID
docker stop $CID
docker rm $CID
done
## return build exit code
if [ $RV -eq 0 ]; then
echo -n "Completed successfully "
else
echo -n "Failed "
fi
echo "with exit code = $RV"
exit $RV