aboutsummaryrefslogtreecommitdiffstats
path: root/Tools/portbuild
diff options
context:
space:
mode:
authorlinimon <linimon@FreeBSD.org>2010-06-26 07:14:13 +0800
committerlinimon <linimon@FreeBSD.org>2010-06-26 07:14:13 +0800
commitc82d059210cac1d969f2a12270675a0d9e0f937f (patch)
tree48c116273671e19d89246b7ab6ec06192b88f233 /Tools/portbuild
parentc8c43055ac5a0f56637811e8f50947f35e9e7c59 (diff)
downloadfreebsd-ports-gnome-c82d059210cac1d969f2a12270675a0d9e0f937f.tar.gz
freebsd-ports-gnome-c82d059210cac1d969f2a12270675a0d9e0f937f.tar.zst
freebsd-ports-gnome-c82d059210cac1d969f2a12270675a0d9e0f937f.zip
Generalize the packge building scripts to be able to be run on more than
one 'head' node, rather than just pointyhat itself. Constants are factored out into installation-specific files known as portbuild/conf/server.conf and portbuild/conf/client.conf. There is only one server.conf file. Individual <arch> directories may have their own client.conf files, or may symlink to ../conf/client.conf. Several bugs are fixed and improvements are made: - the name of the journal file is changed from 'make' (ew) to 'journal'. - the 'date' parameter becomes 'datestamp' to delinate the script's uses of the date command vs. the parameter. This is mostly for readability. - add the -nochecksubdirs option. This is only useful for restarted or incremental runs. - refactor the error returns a bit. - exit gracefully if no INDEXFILE. - fix a bug in the 'packages built' logic that would return -2 if no packages were actually built. - change the misnamed 'cvsdone' file to '.updated'. - clean up the 'task waiting' logic. Feature safe: yes
Diffstat (limited to 'Tools/portbuild')
-rwxr-xr-xTools/portbuild/scripts/dopackages128
1 files changed, 82 insertions, 46 deletions
diff --git a/Tools/portbuild/scripts/dopackages b/Tools/portbuild/scripts/dopackages
index 5e85449580e1..b076d49c5f6c 100755
--- a/Tools/portbuild/scripts/dopackages
+++ b/Tools/portbuild/scripts/dopackages
@@ -1,4 +1,7 @@
#!/bin/sh
+# $FreeBSD$
+
+# main server-side script to run a package build
# configurable variables
pb=/var/portbuild
@@ -8,17 +11,22 @@ PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/sbin:/usr/local/bin:${pb}/scripts
# writable by portmgr
umask 002
+journalname="journal"
+
usage () {
- echo "usage: arch branch buildid date [-continue] [-incremental] [-restart] [-nofinish] [-finish] [-nocleanup] [-cdrom] [-nobuild] [-noindex] [-noduds] [-norestr] [-nosrc] [-srccvs] [-noports] [-portscvs] [-noplistcheck] [-nodistfiles] [-fetch-original] [-trybroken]"
+ echo "usage: arch branch buildid datestamp [-incremental] [-continue] [-restart] [-nofinish] [-finish] [-nocleanup] [-keep] [-nobuild] [-noindex] [-noduds] [-norestr] [-nochecksubdirs] [-nosrc] [-srccvs] [-noports] [-portscvs] [-noplistcheck] [-nodistfiles] [-fetch-original] [-cdrom] [-trybroken]"
+# XXX MCL I think it's going to be too hard to move the create in here, now.
echo " -incremental : Start a new incremental build"
echo " -continue : Restart an interrupted build, skipping failed ports"
echo " -restart : Restart an interrupted build, rebuilding failed ports"
echo " -nofinish : Do not post-process upon build completion"
echo " -finish : Post-process a completed build"
echo " -nocleanup : Do not clean up and deactivate the build once it finishes"
+ echo " -keep : Do not automatically recycle this build"
echo " -nobuild : Only do the build preparation steps, do not build packages"
echo " -noindex : Do not build the INDEX"
echo " -noduds : Do not build the duds file"
+ echo " -nochecksubdirs : Do not check the SUBDIRS"
echo " -norestr : Do not build the restricted.sh file"
echo " -nosrc : Do not update the src tree"
echo " -srccvs : Update the src tree via CVS, don't use a pre-existing snapshot"
@@ -27,9 +35,8 @@ usage () {
echo " -noplistcheck : Don't check the plist during the build"
echo " -nodistfiles : Don't collect distfiles"
echo " -fetch-original : Fetch from original MASTER_SITE"
- echo " -trybroken : Try to build BROKEN ports"
- echo " -keep : Do not automatically recycle this build"
echo " -cdrom : Prepare a build for distribution on CDROM "
+ echo " -trybroken : Try to build BROKEN ports"
exit 1
}
@@ -41,12 +48,14 @@ fi
arch=$1
branch=$2
buildid=$3
-date=$4
+datestamp=$4
shift 4
+. ${pb}/conf/server.conf
. ${pb}/scripts/buildenv
validate_env ${arch} ${branch} || usage
+# XXX MCL too early to do this here.
buildid=$(resolve ${pb} ${arch} ${branch} ${buildid})
if [ -z "${buildid}" ]; then
echo "Invalid build ID ${buildid}"
@@ -54,6 +63,7 @@ if [ -z "${buildid}" ]; then
fi
if [ -f ${pb}/${arch}/portbuild.conf ]; then
+ . ${pb}/conf/server.conf
. ${pb}/${arch}/portbuild.conf
else
usage
@@ -83,6 +93,7 @@ portstar() {
}
# usage: makeindex pb arch branch builddir
+# note: can take ~24 minutes!
makeindex () {
pb=$1
arch=$2
@@ -95,7 +106,7 @@ makeindex () {
echo "generating index"
echo "================================================"
echo "index generation started at $(date)"
- ${pb}/scripts/makeindex ${arch} ${branch} ${buildid} || mailexit 1
+ ${pb}/scripts/makeindex ${arch} ${branch} ${buildid} || return 1
echo "index generation ended at $(date)"
echo $(wc -l ${INDEXFILE} | awk '{print $1}') "lines in INDEX"
@@ -110,18 +121,23 @@ checkindex () {
builddir=$1
cd ${builddir}/ports
+ if [ ! -f ${INDEXFILE} ]; then
+ echo "misssing INDEXFILE ${INDEXFILE} in ${builddir}/ports"
+ return 1
+ fi
if grep -q non-existent ${INDEXFILE}; then
echo "errors in INDEX:"
grep -n non-existent ${INDEXFILE}
- mailexit 1
+ return 1
fi
if ! awk -F '|' '{if (NF != 13) { error=1; printf("line %d: %s\n", NR, $0)}} END {if (error == 1) exit(1)}' ${INDEXFILE}; then
echo "error in INDEX"
- mailexit 1
+ return 1
fi
}
# usage: makeduds pb arch branch builddir
+# note: can take ~21 minutes!
makeduds () {
pb=$1
arch=$2
@@ -154,6 +170,7 @@ makeduds () {
}
# usage: restrictedlist pb arch branch builddir
+# note: can take ~25 minutes!
restrictedlist () {
pb=$1
arch=$2
@@ -166,12 +183,13 @@ restrictedlist () {
echo "creating restricted list"
echo "================================================"
echo "restricted list generation started at $(date)"
- ${pb}/scripts/makerestr ${arch} ${branch} ${buildid} || mailexit 1
+ ${pb}/scripts/makerestr ${arch} ${branch} ${buildid} || return 1
echo "restricted list generation ended at $(date)"
echo $(grep -c '^#' ${builddir}/restricted.sh) "ports in ${builddir}/restricted.sh"
}
# usage: cdromlist pb arch branch builddir
+# note: can take ~48 minutes!
cdromlist () {
pb=$1
arch=$2
@@ -218,11 +236,11 @@ dobuild() {
echo "================================================"
echo "started at $(date)"
start=$(date +%s)
- /var/portbuild/evil/qmanager/packagebuild ${arch} ${branch} ${buildid} > ${builddir}/make 2>&1 < /dev/null
+ ${QMANAGER_PATH}/packagebuild ${arch} ${branch} ${buildid} > ${builddir}/${journalname} 2>&1 < /dev/null
echo "ended at $(date)"
end=$(date +%s)
echo "Build took $(date -u -j -r $((end - start)) | awk '{print $4}')"
- echo $(echo $(ls -1 ${builddir}/packages/All | wc -l) - 2 | bc) "packages built"
+ echo $(ls -1 ${builddir}/packages/All | grep tbz | wc -l) "packages built"
echo $(wc -l ${PORTSDIR}/${INDEXFILE} | awk '{print $1}') "lines in INDEX"
@@ -230,9 +248,9 @@ dobuild() {
echo $(echo $(du -sk ${builddir}/distfiles | awk '{print $1}') / 1024 | bc) "MB of distfiles"
cd ${builddir}
- if grep -qE '(ptimeout|pnohang): killing' make; then
+ if grep -qE '(ptimeout|pnohang): killing' ${journalname}; then
echo "The following port(s) timed out:"
- grep -E '(ptimeout|pnohang): killing' make | sed -e 's/^.*ptimeout:/ptimeout:/' -e 's/^.*pnohang:/pnohang:/'
+ grep -E '(ptimeout|pnohang): killing' ${journalname} | sed -e 's/^.*ptimeout:/ptimeout:/' -e 's/^.*pnohang:/pnohang:/'
fi
}
@@ -253,6 +271,7 @@ srccvs=0
noports=0
portscvs=0
norestr=0
+nochecksubdirs=0
noplistcheck=0
cdrom=0
restart=0
@@ -296,6 +315,9 @@ while [ $# -gt 0 ]; do
x-norestr)
norestr=1
;;
+ x-nochecksubdirs)
+ nochecksubdirs=1
+ ;;
x-noplistcheck)
noplistcheck=1
;;
@@ -347,8 +369,6 @@ fi
# We have valid options, start the build
-echo | mail -s "$(basename $0) started for ${arch}-${branch} ${buildid} at $(date)" ${mailto}
-
if [ "$nodistfiles" = 1 ]; then
export NO_DISTFILES=1
fi
@@ -372,26 +392,28 @@ fi
# Start setting up build environment
if [ "${skipstart}" -eq 0 ]; then
+ newbuildid=${datestamp}
+ # this is where the latest/previous dance is performed
# MCL note 20091109: buildid must exist. For now, use the following
# MCL manual command to start new buildenvs, before the first use of
# MCL dopackages: "build create arch branch"
- oldbuildid=${buildid}
- buildid=$(date +%Y%m%d%H%M%S)
- build clone ${arch} ${branch} ${oldbuildid} ${buildid}
+ build clone ${arch} ${branch} ${buildid} ${newbuildid}
+ buildid=${newbuildid}
fi
builddir=${pbab}/builds/${buildid}
-# XXX MCL what does this line do???
-df -k | grep ${buildid}
-# Set up our environment variables
-buildenv ${pb} ${arch} ${branch} ${builddir}
-
# bomb out if build clone failed
if [ ! -d ${builddir} ]; then
mailexit 1
fi
+# Set up our environment variables
+buildenv ${pb} ${arch} ${branch} ${builddir}
+
+# XXX MCL might not return 'latest' ???
+echo | mail -s "$(basename $0) started for ${arch}-${branch} ${buildid} at $(date)" ${mailto}
+
# make necessary subdirectories if they don't exist
mkdir -p ${builddir}/bak/restricted || mailexit 1
@@ -404,7 +426,7 @@ fi
touch ${builddir}/.active
# Update link to current logfile created by dopackages.wrapper
-ln -sf ${pb}/${arch}/archive/buildlogs/log.${branch}.${date} \
+ln -sf ${pb}/${arch}/archive/buildlogs/log.${branch}.${datestamp} \
${builddir}/build.log
if [ "$skipstart" = 0 ]; then
@@ -425,15 +447,18 @@ if [ "$skipstart" = 0 ]; then
echo "running cvs update -PAd on ${PORTSDIR}"
echo "================================================"
cd ${PORTSDIR}
- cvsdone=$(date)
- echo ${cvsdone} > ${builddir}/cvsdone
- cvs -Rq update -PdA -D "${cvsdone}"
+ updated=$(date)
+ echo ${updated} > ${builddir}/.updated
+ cvs -Rq update -PdA -D "${updated}"
# XXX Check for conflicts
else
+ # echo "XXX at build portsupdate portsupdate ${arch} ${branch} ${buildid} $@ "
build portsupdate ${arch} ${branch} ${buildid} $@
+ # echo "XXX past build portsupdate portsupdate ${arch} ${branch} ${buildid} $@ "
fi
else
- rm -f ${builddir}/cvsdone
+ # XXX MCL why???
+ # XXX rm -f ${builddir}/.updated
fi
if [ "$incremental" = 1 ]; then
@@ -453,12 +478,12 @@ if [ "$skipstart" = 0 ]; then
echo "running cvs update -PAd on ${SRCBASE}"
echo "================================================"
cd ${SRCBASE}
- if [ -z "${cvsdone}" ]; then
- # Don't overwrite/create cvsdone if we didnt set it
+ if [ -z "${updated}" ]; then
+ # Don't overwrite/create .updated if we didn't set it
# with the ports update
- cvsdone=$(date)
+ updated=$(date)
fi
- cvs -Rq update -PdA -D "${cvsdone}"
+ cvs -Rq update -PdA -D "${updated}"
# XXX Check for conflicts
else
build srcupdate ${arch} ${branch} ${buildid} $@
@@ -468,17 +493,21 @@ if [ "$skipstart" = 0 ]; then
# Begin build preprocess
- echo "================================================"
- echo "running make checksubdirs"
- echo "================================================"
cd ${PORTSDIR}
- make checksubdirs
+ if [ "$nochecksubdirs" = 0 ]; then
+ echo "================================================"
+ echo "running make checksubdirs"
+ echo "================================================"
+ make checksubdirs
+ fi
+
+ # XXX MCL could background these?
# not run in background to check return status
if [ "$noindex" = 0 ]; then
makeindex ${pb} ${arch} ${branch} ${buildid} ${builddir} || mailexit 1
fi
- checkindex ${builddir}
+ checkindex ${builddir} || mailexit 1
if [ "$noduds" = 0 ]; then
makeduds ${pb} ${arch} ${branch} ${buildid} ${builddir} || mailexit 1
fi
@@ -502,16 +531,16 @@ if [ "$skipstart" = 0 ]; then
fi
lockf -k ${pbab}/failure.lock ${pb}/scripts/prunefailure ${arch} ${branch} ${builddir}
fi
-fi
-if [ "$skipstart" = 0 ]; then
# XXX These can happen after build start
if [ "$norestr" = 0 ]; then
restrictedlist ${pb} ${arch} ${branch} ${buildid} ${builddir} &
+ job_restrictedlist=$!
fi
if [ "$cdrom" = 1 ]; then
cdromlist ${pb} ${arch} ${branch} ${builddir} &
+ job_cdromlist=$!
fi
cd ${builddir}
@@ -546,11 +575,11 @@ if [ "$skipstart" = 0 ]; then
ln -sf ${newlogs} ${builddir}/logs
echo "error logs in ${newerrors}"
- if [ -f "${builddir}/cvsdone" ]; then
- cp -p ${builddir}/cvsdone ${newerrors}/cvsdone
- cp -p ${builddir}/cvsdone ${newlogs}/cvsdone
+ if [ -f "${builddir}/.updated" ]; then
+ cp -p ${builddir}/.updated ${newerrors}/.updated
+ cp -p ${builddir}/.updated ${newlogs}/.updated
else
- rm -f ${newerrors}/cvsdone ${newlogs}/cvsdone
+ rm -f ${newerrors}/.updated ${newlogs}/.updated
fi
cp -p ${builddir}/duds ${newerrors}/duds
cp -p ${builddir}/duds ${newlogs}/duds
@@ -592,6 +621,8 @@ if [ "$skipstart" = 0 ]; then
cd ${PACKAGES}/All
sed "s,$,${PKGSUFFIX}," ${builddir}/.oldports | xargs rm -f
+ # XXX MCL takes an unknown period of time.
+ # XXX MCL return value not checked.
${pb}/scripts/prunepkgs ${PORTSDIR}/${INDEXFILE} ${PACKAGES}
cd ${builddir}/errors/
@@ -606,14 +637,19 @@ if [ "$skipstart" = 0 ]; then
cd ${builddir}
if [ -d packages ]; then
+ # echo "XXX at mv packages .packages~"
mv packages .packages~
rm -rf .packages~ &
+ # echo "XXX past mv packages .packages~"
fi
mkdir -p packages/All
fi
-fi
-# XXX only need to wait for some tasks
+ wait $job_restrictedlist || mailexit 1
+ wait $job_cdromlist || mailexit 1
+fi # if [ "$skipstart" = 0 ]
+
+# only need to wait for some tasks, so this is probably redundant.
wait
if [ "$nobuild" = 0 ]; then
@@ -691,7 +727,7 @@ if [ "$nofinish" = 0 ]; then
done
ls -asFlrt ${builddir}/packages/All > ${builddir}/logs/ls-lrt
- cp -p ${builddir}/make ${builddir}/logs
+ cp -p ${builddir}/${journalname} ${builddir}/logs
echo "================================================"
echo "copying distfiles"
@@ -725,4 +761,4 @@ echo "all done at $(date)"
echo "entire process took $(date -u -j -r $(($endtime - $starttime)) | awk '{print $4}')"
echo "================================================"
-mailexit 0
+exit 0