From d45bec90d486151063b0c2a13afd63f4dccb3a81 Mon Sep 17 00:00:00 2001 From: Peter Palfrader Date: Thu, 4 Dec 2014 21:36:08 +0100 Subject: [PATCH] Update chroot creation scripts to also build buildd chroots --- modules/porterbox/files/setup-all-dchroots | 39 +++++++++++++- modules/porterbox/files/setup-dchroot | 59 ++++++++++++++++++---- 2 files changed, 86 insertions(+), 12 deletions(-) diff --git a/modules/porterbox/files/setup-all-dchroots b/modules/porterbox/files/setup-all-dchroots index efb920fd4..652d08b65 100755 --- a/modules/porterbox/files/setup-all-dchroots +++ b/modules/porterbox/files/setup-all-dchroots @@ -31,6 +31,16 @@ DPKGARCH=$(dpkg --print-architecture) UNAMEARCH=$(uname -m) +if [ "${1:-}" = "buildd" ]; then + MODE=buildd + if ! [ -d /srv/buildd/ ]; then + echo >&2 "Error: /srv/buildd does not exist or is not a directory." + exit 1 + fi +else + MODE=porterbox +fi + get_suites() { case "$1" in armhf|s390x) @@ -42,7 +52,7 @@ get_suites() { sparc) echo "sid wheezy" ;; - arm64) + arm64|ppc64el) echo "sid jessie" ;; amd64|i386) @@ -77,9 +87,34 @@ esac err=0 +do_one() { + local a="$1"; shift + local s="$1"; shift + + case "$MODE" in + buildd) + mkdir -p /srv/buildd/unpack + if ! chronic setup-dchroot -f -a "$a" -D -d '/srv/buildd/unpack' -K "$s" + then + return 1 + fi + ;; + porterbox) + if ! chronic setup-dchroot -f -a "$a" "$s" + then + return 1 + fi + ;; + *) + echo >&2 "Invalid mode $MODE" + exit 1 + esac + return 0 +} + for a in $archs; do for s in `get_suites "$a"`; do - if ! chronic setup-dchroot -f -a "$a" "$s"; then + if ! do_one "$a" "$s"; then err=1 echo >&2 echo >&2 "Error: setting up $s:$a dchroot failed." diff --git a/modules/porterbox/files/setup-dchroot b/modules/porterbox/files/setup-dchroot index f09c8bbeb..e5ea8ac3a 100755 --- a/modules/porterbox/files/setup-dchroot +++ b/modules/porterbox/files/setup-dchroot @@ -39,15 +39,20 @@ OPTIONS: -a ARCH debootstrap arch [$arch] -m MIRROR http mirror to use [$mirror] -b basedir place where to put the tarball [$basedir] - -B install less stuff into chroot + -B install less stuff into chroot [$bare] -c write config only + -D set up a buildd schroot - changes conffile name and various defaults. Run -D -h)." -d dir place where to build the chroot [${builddir:-$basedir}] -f overwrite config and target tarball -g GROUPS groups that should have access to the schroot [$groupuser] + -K keep old tarballs around for a while (4 iterations) -k KEYRING use an alternate keyring [$keyring] + -o USER users that should have access to the schroot [$users] + -O USER users that should have root in the schroot [$usersroot] -p PERS use a different sbuild personality [$personality] -r GROUPS groups that should have root in the schroot [$grouproot] - -s use sbuild compatible naming scheme + -s use sbuild compatible naming scheme [$sbuildnames] + -S SUFFIX conffile suffix [$suffix] -u Ubuntu target -h this help EOF @@ -88,11 +93,11 @@ cat << EOF description=[${name}] Debian $suite chroot for $arch type=file file=$target -groups=$groupuser -root-groups=$grouproot -#source-groups=adm -#source-root-groups=adm EOF +[ -n "$groupuser" ] && echo "groups=$groupuser" +[ -n "$grouproot" ] && echo "root-groups=$grouproot" +[ -n "$users" ] && echo "users=$users" +[ -n "$usersroot" ] && echo "root-users=$usersroot" echo "profile=$personality" @@ -149,11 +154,16 @@ sbuildnames="" ubuntu="" groupuser="Debian,guest" grouproot="" +users="" +usersroot="" bare="" +keep="" +suffix="dchroot" declare -a cleanup +cleanup+=(":") trap do_cleanup EXIT -while getopts "a:b:Bcd:fg:hk:m:p:r:su" OPTION +while getopts "a:b:Bcd:Dfg:hKk:m:o:O:p:r:sS:u" OPTION do case $OPTION in a) @@ -168,6 +178,16 @@ do c) configonly="1" ;; + D) + sbuildnames="0" + bare="1" + groupuser="" + grouproot="" + users="buildd" + usersroot="buildd" + personality="buildd" + suffix="sbuild" + ;; d) builddir="$OPTARG" ;; @@ -181,12 +201,21 @@ do usage exit 0 ;; + K) + keep="4" + ;; k) keyring="$OPTARG" ;; m) mirror="$OPTARG" ;; + o) + users="$OPTARG" + ;; + O) + usersroot="$OPTARG" + ;; p) personality="$OPTARG" ;; @@ -196,6 +225,9 @@ do s) sbuildnames="1" ;; + S) + suffix="$OPTARG" + ;; u) ubuntu="1" ;; @@ -221,7 +253,7 @@ builddir=${builddir:-$basedir} target="$basedir/$tuple.tar.gz" ! [ -e "$target" ] || [ -n "$force" ] || die "Error: $target already exists." -schrootconfig="/etc/schroot/chroot.d/${tuple}-dchroot" +schrootconfig="/etc/schroot/chroot.d/${tuple}-$suffix" ! [ -e "$schrootconfig" ] || [ -n "$force" ] || die "Error: $schrootconfig already exists." @@ -289,7 +321,7 @@ while true; do done EOF chmod +x "$rootdir/usr/local/sbin/policy-rc.d" -[ -z "$ubuntu" ] && chroot "$rootdir" apt-get install -y --force-yes --no-install-recommends locales-all +[ -z "$bare" ] && [ -z "$ubuntu" ] && chroot "$rootdir" apt-get install -y --force-yes --no-install-recommends locales-all chroot "$rootdir" apt-get install -y --force-yes --no-install-recommends build-essential [ -z "$bare" ] && chroot "$rootdir" apt-get install -y --force-yes --no-install-recommends zsh less vim fakeroot devscripts gdb rm -f "$rootdir/etc/apt/sources.list" "$rootdir/etc/apt/sources.list.d/*" @@ -299,6 +331,13 @@ umount "$rootdir/sys" 2>/dev/null || true tartmp=$(tempfile --directory "$basedir" --suffix=".tar.gz") cleanup+=("rm -f $tartmp") -(cd "$rootdir" && tar caf "$tartmp" . && mv "$tartmp" "$target") +( + cd "$rootdir" + tar caf "$tartmp" . + if ! [ -z "$keep" ]; then + savelog -d -l -c 4 "$target" + fi + mv "$tartmp" "$target" +) do_config -- 2.20.1