mirror of
				https://git.launchpad.net/ubuntu-dev-tools
				synced 2025-10-25 19:14:04 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			566 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			566 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/bash
 | |
| #
 | |
| # Copyright 2006-2010 (C) Canonical Ltd.
 | |
| # Authors:
 | |
| #  Kees Cook <kees@ubuntu.com>
 | |
| #  Emmet Hikory <persia@ubuntu.com>
 | |
| #  Scott Moser <smoser@ubuntu.com>
 | |
| #
 | |
| # ##################################################################
 | |
| #
 | |
| # This program is free software; you can redistribute it and/or
 | |
| # modify it under the terms of the GNU General Public License
 | |
| # as published by the Free Software Foundation; either version 3
 | |
| # of the License, or (at your option) any later version.
 | |
| #
 | |
| # This program is distributed in the hope that it will be useful,
 | |
| # but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| # GNU General Public License for more details.
 | |
| #
 | |
| # See file /usr/share/common-licenses/GPL for more details.
 | |
| #
 | |
| # ##################################################################
 | |
| #
 | |
| # This script creates chroots designed to be used in a snapshot mode
 | |
| # (either with LVM or aufs) with schroot and sbuild.
 | |
| # Much love to "man sbuild-setup", https://wiki.ubuntu.com/PbuilderHowto,
 | |
| # and https://help.ubuntu.com/community/SbuildLVMHowto.
 | |
| #
 | |
| # It will deal with sbuild having not be installed and configured before.
 | |
| set -e
 | |
| 
 | |
| # For when schroot enters the chroot, we cannot be in a directory that
 | |
| # will not exist in the chroot.
 | |
| cd /
 | |
| 
 | |
| # Make sure we've got a regular user
 | |
| if [ -w /etc/passwd ]; then
 | |
|     echo "Please run this script as a regular user, not root." >&2
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| # Perform once-only things to initially set up for using sbuild+schroot
 | |
| if [ ! -w /var/lib/sbuild ]; then
 | |
|     # Load all the packages you'll need to do work
 | |
|     sudo apt-get install sbuild schroot debootstrap
 | |
|     # Add self to the sbuild group
 | |
|     sudo adduser "$USER" sbuild
 | |
| 
 | |
|     # Prepare a usable default .sbuildrc
 | |
|     if [ ! -e ~/.sbuildrc ]; then
 | |
|         cat > ~/.sbuildrc <<EOM
 | |
| # *** VERIFY AND UPDATE \$mailto and \$maintainer_name BELOW ***
 | |
| 
 | |
| # Mail address where logs are sent to (mandatory, no default!)
 | |
| \$mailto = '$USER';
 | |
| 
 | |
| # Name to use as override in .changes files for the Maintainer: field
 | |
| # (mandatory, no default!).
 | |
| \$maintainer_name='$USER <$USER@localhost>';
 | |
| 
 | |
| # Directory for chroot symlinks and sbuild logs.  Defaults to the
 | |
| # current directory if unspecified.
 | |
| #\$build_dir='$HOME/ubuntu/build';
 | |
| 
 | |
| # Directory for writing build logs to
 | |
| \$log_dir="$HOME/ubuntu/logs";
 | |
| 
 | |
| # don't remove this, Perl needs it:
 | |
| 1;
 | |
| EOM
 | |
|         sensible-editor ~/.sbuildrc
 | |
|         # Create target directories, if needed
 | |
|         eval $(egrep '^\$(build|log)_dir[ 	]*=' ~/.sbuildrc | cut -c2-)
 | |
|         if [ -n "$log_dir" ]; then
 | |
|             mkdir -p "$log_dir"
 | |
|         fi
 | |
|         if [ -n "$build_dir" ]; then
 | |
|             mkdir -p "$build_dir"
 | |
|         fi
 | |
|     else
 | |
|         echo "Your ~/.sbuildrc already exists -- leaving it as-is."
 | |
|     fi
 | |
| 
 | |
|     echo '***********************************************'
 | |
|     echo '* Before continuing, you MUST restart your    *'
 | |
|     echo '* session to gain "sbuild" group permissions! *' 
 | |
|     echo '***********************************************'
 | |
|     exit 0
 | |
| fi
 | |
| 
 | |
| if ! id | fgrep -q '(sbuild)'; then
 | |
|     echo "You must be a member of the 'sbuild' group." >&2
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| # Set up configurable defaults (loaded after option processing)
 | |
| LV_SIZE="5G"
 | |
| SNAPSHOT_SIZE="4G"
 | |
| SOURCE_CHROOTS_DIR="/var/lib/schroot/chroots"
 | |
| SOURCE_CHROOTS_TGZ="/var/lib/schroot/tarballs"
 | |
| 
 | |
| function usage()
 | |
| {
 | |
|     echo "Usage: $0 [OPTIONS] Release" >&2
 | |
|     echo "Options:"
 | |
|     echo "  --arch=ARCH                What architecture to select"
 | |
|     echo "  --name=NAME                Base name for the schroot (arch is appended)"
 | |
|     echo "  --personality=PERSONALITY  What personality to use (defaults to match --arch)"
 | |
|     echo "  --vg=VG                    use LVM snapshots, with group VG"
 | |
|     echo "  --debug                    Turn on script debugging"
 | |
|     echo "  --skip-updates             Do not include -updates pocket in sources.list"
 | |
|     echo "  --source-template=FILE     Use FILE as the sources.list template"
 | |
|     echo "  --debootstrap-mirror=URL   Use URL as the debootstrap source"
 | |
|     echo "  --debootstrap-include=list Comma separated list of packages to include"
 | |
|     echo "  --debootstrap-exclude=list Comma separated list of packages to exclude"
 | |
|     echo "  --distro=DISTRO            Install specific distro:"
 | |
|     echo "                                 'ubuntu'(default), or 'debian'"
 | |
|     echo "  --type=SCHROOT_TYPE        Define the schroot type:"
 | |
|     echo "                                 'directory'(default), or 'file'"
 | |
|     echo "                                 'lvm-snapshot' is selected via --vg"
 | |
|     echo ""
 | |
|     echo "Configuration (via ~/.mk-sbuild.rc)"
 | |
|     echo "  LV_SIZE                    Size of source LVs (default ${LV_SIZE})"
 | |
|     echo "  SNAPSHOT_SIZE              Size of snapshot LVs (default ${SNAPSHOT_SIZE})"
 | |
|     echo "  SOURCE_CHROOTS_DIR         Directory to store directory source chroots"
 | |
|     echo "  SOURCE_CHROOTS_TGZ         Directory to store file source chroots"
 | |
|     echo "  SCHROOT_CONF_SUFFIX        Lines to append to schroot.conf entries"
 | |
|     echo "  SKIP_UPDATES               Enable --skip-updates"
 | |
|     echo "  DEBOOTSTRAP_MIRROR         Mirror location (same as --debootstrap-mirror)"
 | |
|     echo "  DEBOOTSTRAP_INCLUDE        Included packages (same as --debootstrap-include)"
 | |
|     echo "  DEBOOTSTRAP_EXCLUDE        Excluded packages (same as --debootstrap-exclude)"
 | |
|     echo "  TEMPLATE_SOURCES           A template for sources.list"
 | |
|     echo "  TEMPLATE_SCHROOTCONF       A template for schroot.conf stanza"
 | |
|     exit 1
 | |
| }
 | |
| 
 | |
| 
 | |
| if [ -z "$1" ]; then
 | |
|     usage
 | |
| fi
 | |
| OPTS=`getopt -o '' --long "help,debug,skip-updates,arch:,name:,source-template:,debootstrap-mirror:,debootstrap-include:,debootstrap-exclude:,personality:,distro:,vg:,type:" -- "$@"`
 | |
| eval set -- "$OPTS"
 | |
| 
 | |
| VG=""
 | |
| DISTRO="ubuntu"
 | |
| name=""
 | |
| while :; do
 | |
|     case "$1" in
 | |
|         --debug)
 | |
|             set -x
 | |
|             shift
 | |
|             ;;
 | |
|         --arch)
 | |
|             CHROOT_ARCH="$2"
 | |
|             if [ "$2" = "i386" ] || [ "$2" = "lpia" ] && [ -z "$personality" ];
 | |
|             then
 | |
|                 personality="linux32"
 | |
|             fi
 | |
|             shift 2
 | |
|             ;;
 | |
|         --personality)
 | |
|             personality="$2"
 | |
|             shift 2
 | |
|             ;;
 | |
|         --skip-updates)
 | |
|             SKIP_UPDATES="1"
 | |
|             shift
 | |
|             ;;
 | |
|         --name)
 | |
|             name="$2"
 | |
|             shift 2
 | |
|             ;;
 | |
|         --source-template)
 | |
|             TEMPLATE_SOURCES="$2"
 | |
|             shift 2
 | |
|             if [ ! -r $TEMPLATE_SOURCES ]; then
 | |
|                 echo "W: Template file $TEMPLATE_SOURCES is not readable"
 | |
|                 echo "W: Continuing with default sources!"
 | |
|             fi
 | |
|             ;;
 | |
|         --debootstrap-mirror)
 | |
|             DEBOOTSTRAP_MIRROR="$2"
 | |
|             shift 2
 | |
|             ;;
 | |
|         --debootstrap-include)
 | |
|             DEBOOTSTRAP_INCLUDE="$2"
 | |
|             shift 2
 | |
|             ;;
 | |
|         --debootstrap-exclude)
 | |
|             DEBOOTSTRAP_EXCLUDE="$2"
 | |
|             shift 2
 | |
|             ;;
 | |
|         --distro)
 | |
|             DISTRO="$2"
 | |
|             shift 2
 | |
|             ;;
 | |
|         --vg)
 | |
|             VG="$2"
 | |
|             shift 2
 | |
|             ;;
 | |
|         --type)
 | |
|             SCHROOT_TYPE="$2"
 | |
|             shift 2
 | |
|             ;;
 | |
|         --)
 | |
|             shift
 | |
|             break
 | |
|             ;;
 | |
|         --help|*)
 | |
|             usage
 | |
|             ;;
 | |
|      esac
 | |
| done
 | |
| 
 | |
| # To build the chroot, we need to know which release of Ubuntu to debootstrap
 | |
| RELEASE="$1"
 | |
| if [ -z "$RELEASE" ]; then
 | |
|     usage
 | |
| fi
 | |
| 
 | |
| # By default, name the schroot the same as the release
 | |
| if [ -z "$name" ]; then
 | |
|     name="$RELEASE"
 | |
| fi
 | |
| 
 | |
| # By default, use the native architecture.
 | |
| HOST_ARCH=$(dpkg --print-architecture)
 | |
| if [ -z "$CHROOT_ARCH" ]; then
 | |
|     CHROOT_ARCH="$HOST_ARCH"
 | |
| fi
 | |
| 
 | |
| CHROOT_NAME="${name}-${CHROOT_ARCH}"
 | |
| 
 | |
| # Load customizations
 | |
| if [ -r ~/.mk-sbuild.rc ]; then
 | |
|     . ~/.mk-sbuild.rc
 | |
| fi
 | |
| 
 | |
| if [ -z "$SCHROOT_TYPE" ]; then
 | |
|     # To build the LV, we need to know which volume group to use
 | |
|     if [ -n "$VG" ]; then
 | |
|         SCHROOT_TYPE="lvm-snapshot"
 | |
|     else
 | |
|         SCHROOT_TYPE="directory"
 | |
|     fi
 | |
| fi
 | |
| 
 | |
| case "$SCHROOT_TYPE" in
 | |
| "lvm-snapshot")
 | |
|     # Make sure LVM tools that operate on the snapshots have needed module
 | |
|     if ! sudo dmsetup targets | grep -q ^snapshot; then
 | |
|         sudo modprobe dm_snapshot
 | |
|         echo dm_snapshot | sudo tee -a /etc/modules >/dev/null
 | |
|     fi
 | |
| 
 | |
|     # Set up some variables for use in the paths and names
 | |
|     CHROOT_LV="${name}_${CHROOT_ARCH}_chroot"
 | |
|     CHROOT_PATH="/dev/$VG/$CHROOT_LV"
 | |
| 
 | |
|     # Install lvm2 if missing
 | |
|     if ! dpkg -l lvm2 >/dev/null 2>&1; then
 | |
|         sudo apt-get install lvm2
 | |
|     fi
 | |
| 
 | |
|     # Does the specified VG exist?  (vgdisplay doesn't set error codes...)
 | |
|     if [ `sudo vgdisplay -c "$VG" | wc -l` -eq 0 ]; then
 | |
|         echo "Volume group '${VG}' does not appear to exist" >&2
 | |
|         exit 1
 | |
|     fi
 | |
|     ;;
 | |
| "directory")
 | |
|     if [ ! -d "${SOURCE_CHROOTS_DIR}" ]; then
 | |
|         sudo mkdir -p "${SOURCE_CHROOTS_DIR}"
 | |
|     fi
 | |
|     # Set up some variables for use in the paths and names
 | |
|     CHROOT_PATH="${SOURCE_CHROOTS_DIR}/${CHROOT_NAME}"
 | |
|     ;;
 | |
| "file")
 | |
|     if [ ! -d "$SOURCE_CHROOTS_TGZ" ]; then
 | |
|         sudo mkdir -p "$SOURCE_CHROOTS_TGZ"
 | |
|     fi
 | |
|     # Set up some variables for use in the paths and names
 | |
|     CHROOT_PATH="${SOURCE_CHROOTS_TGZ}/${CHROOT_NAME}.tgz"
 | |
|     ;;
 | |
| *)
 | |
|     echo 'unknown source type!?' >&2
 | |
|     exit 1
 | |
|     ;;
 | |
| esac
 | |
| 
 | |
| # Is the specified release known to debootstrap?
 | |
| variant_opt="--variant=buildd"
 | |
| if [ ! -r "/usr/share/debootstrap/scripts/$RELEASE" ]; then
 | |
|     echo "Specified release ($RELEASE) not known to debootstrap" >&2
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| BUILD_PKGS="build-essential fakeroot devscripts apt-utils"
 | |
| # Handle distro-specific logic, unknown to debootstrap
 | |
| case "$DISTRO" in
 | |
| ubuntu)
 | |
|     if [ -z "$DEBOOTSTRAP_MIRROR" ]; then
 | |
|         case "$CHROOT_ARCH" in
 | |
|         amd64 | i386)
 | |
|             DEBOOTSTRAP_MIRROR="http://archive.ubuntu.com/ubuntu"
 | |
|             ;;
 | |
|         armel | hppa | ia64 | lpia | sparc)
 | |
|             DEBOOTSTRAP_MIRROR="http://ports.ubuntu.com/ubuntu-ports"
 | |
|             ;;
 | |
|         powerpc)
 | |
|             if [ "$RELEASE" != "dapper" ]; then
 | |
|                 DEBOOTSTRAP_MIRROR="http://ports.ubuntu.com/ubuntu-ports"
 | |
|             else
 | |
|                 DEBOOTSTRAP_MIRROR="http://archive.ubuntu.com/ubuntu"
 | |
|             fi
 | |
|             ;;
 | |
|         esac
 | |
|     fi
 | |
|     if [ -z "$COMPONENTS" ]; then
 | |
|         COMPONENTS="main restricted universe multiverse"
 | |
|     fi
 | |
|     if [ -z "$SOURCES_SECURITY_SUITE" ]; then
 | |
|         SOURCES_SECURITY_SUITE="RELEASE-security"
 | |
|     fi
 | |
|     if [ -z "$SOURCES_SECURITY_URL" ]; then
 | |
|         case "$CHROOT_ARCH" in
 | |
|         amd64 | i386)
 | |
|             SOURCES_SECURITY_URL="http://security.ubuntu.com/ubuntu"
 | |
|             ;;
 | |
|         armel | hppa | ia64 | lpia | sparc)
 | |
|             SOURCES_SECURITY_URL="http://ports.ubuntu.com/ubuntu-ports"
 | |
|             ;;
 | |
|         powerpc)
 | |
|             if [ "$RELEASE" != "dapper" ]; then
 | |
|                 SOURCES_SECURITY_URL="http://ports.ubuntu.com/ubuntu-ports"
 | |
|             else
 | |
|                 SOURCES_SECURITY_URL="http://security.ubuntu.com/ubuntu"
 | |
|             fi
 | |
|             ;;
 | |
|         esac
 | |
|     fi
 | |
|     # Add edgy+ buildd tools
 | |
|     if [ "$RELEASE" != "breezy" ] && [ "$RELEASE" != "dapper" ]; then
 | |
|         # Disable recommends for a smaller chroot (gutsy and later only)
 | |
|         BUILD_PKGS="--no-install-recommends $BUILD_PKGS"
 | |
|         # Add buildd tools
 | |
|         BUILD_PKGS="$BUILD_PKGS pkg-create-dbgsym pkgbinarymangler"
 | |
|     fi
 | |
|     ;;
 | |
| debian)
 | |
|     if [ -z "$DEBOOTSTRAP_MIRROR" ]; then
 | |
|         DEBOOTSTRAP_MIRROR="http://ftp.debian.org/debian"
 | |
|     fi
 | |
|     if [ -z "$COMPONENTS" ]; then
 | |
|         COMPONENTS="main non-free contrib"
 | |
|     fi
 | |
|     # Debian only performs security updates
 | |
|     SKIP_UPDATES=1
 | |
|     if [ -z "$SOURCES_SECURITY_SUITE" ]; then
 | |
|         SOURCES_SECURITY_SUITE="RELEASE/updates"
 | |
|     fi
 | |
|     if [ -z "$SOURCES_SECURITY_URL" ]; then
 | |
|         SOURCES_SECURITY_URL="http://security.debian.org/"
 | |
|     fi
 | |
|     # Unstable (aka "sid") does not have a security repository
 | |
|     if [ "$RELEASE" = 'unstable' ] || [ "$RELEASE" = 'sid' ]; then
 | |
|         SKIP_SECURITY=1
 | |
|     fi
 | |
|     ;;
 | |
| *)
 | |
|     echo "Unknown --distro '$DISTRO': aborting" >&2
 | |
|     exit 1
 | |
|     ;;
 | |
| esac
 | |
| 
 | |
| if [ -n "$DEBOOTSTRAP_INCLUDE" ] ; then
 | |
|     debootstrap_opts="--include=$DEBOOTSTRAP_INCLUDE"
 | |
| fi
 | |
| 
 | |
| if [ -n "$DEBOOTSTRAP_EXCLUDE" ] ; then
 | |
|     debootstrap_opts="$debootstrap_opts --exclude=$DEBOOTSTRAP_EXCLUDE"
 | |
| fi
 | |
| 
 | |
| DEBOOTSTRAP_COMMAND=debootstrap
 | |
| # Use qemu-kvm-extras-static for foreign chroots
 | |
| if [ "$CHROOT_ARCH" != "$HOST_ARCH" ] ; then
 | |
|     case "$CHROOT_ARCH-$HOST_ARCH" in
 | |
|     # Sometimes we don't need qemu
 | |
|     amd64-i386|amd64-lpia|arm-armel|armel-arm|i386-amd64|i386-lpia|lpia-i386|powerpc-ppc64|ppc64-powerpc|sparc-sparc64|sparc64-sparc)
 | |
|         ;;
 | |
|     # Sometimes we do
 | |
|     *)
 | |
|         DEBOOTSTRAP_COMMAND=qemu-debootstrap
 | |
|         if ! which "$DEBOOTSTRAP_COMMAND"; then
 | |
|             sudo apt-get install qemu-kvm-extras-static
 | |
|         fi
 | |
|         ;;
 | |
|     esac
 | |
| fi
 | |
| 
 | |
| case "$SCHROOT_TYPE" in
 | |
| "lvm-snapshot")
 | |
|     # Allocate the "golden" chroot LV
 | |
|     sudo lvcreate -n "$CHROOT_LV" -L "$LV_SIZE" "$VG"
 | |
|     sudo mkfs -t ext4 "$CHROOT_PATH"
 | |
| 
 | |
|     # Mount
 | |
|     MNT=`mktemp -d -t schroot-XXXXXX`
 | |
|     sudo mount "$CHROOT_PATH" "$MNT"
 | |
|     ;;
 | |
| "directory")
 | |
|     MNT="${CHROOT_PATH}"
 | |
|     if [ -d "${MNT}" ]; then
 | |
|         echo "E: ${MNT} already exists; aborting" >&2
 | |
|         exit 1
 | |
|     fi
 | |
|     sudo mkdir -p "${MNT}"
 | |
|     ;;
 | |
| "file")
 | |
|     MNT=`mktemp -d -t schroot-XXXXXX`
 | |
| esac
 | |
| 
 | |
| # debootstrap the chroot
 | |
| sudo "$DEBOOTSTRAP_COMMAND" --arch="$CHROOT_ARCH" $variant_opt $debootstrap_opts "$RELEASE" "$MNT" "${DEBOOTSTRAP_MIRROR:-http://archive.ubuntu.com/ubuntu}"
 | |
| 
 | |
| # Update the package sources
 | |
| TEMP_SOURCES=`mktemp -t sources-XXXXXX`
 | |
| if [ -z "$TEMPLATE_SOURCES" ]; then
 | |
|     TEMPLATE_SOURCES=~/.mk-sbuild.sources
 | |
| fi
 | |
| if [ -r "$TEMPLATE_SOURCES" ]; then
 | |
|     cat "$TEMPLATE_SOURCES" > "$TEMP_SOURCES"
 | |
| else
 | |
|     cat > "$TEMP_SOURCES" <<EOM
 | |
| deb ${DEBOOTSTRAP_MIRROR} RELEASE ${COMPONENTS}
 | |
| deb-src ${DEBOOTSTRAP_MIRROR} RELEASE ${COMPONENTS}
 | |
| EOM
 | |
|     if [ -z "$SKIP_UPDATES" ]; then
 | |
|         cat >> "$TEMP_SOURCES" <<EOM
 | |
| deb ${DEBOOTSTRAP_MIRROR} RELEASE-updates ${COMPONENTS}
 | |
| deb-src ${DEBOOTSTRAP_MIRROR} RELEASE-updates ${COMPONENTS}
 | |
| EOM
 | |
|     fi
 | |
|     if [ -z "$SKIP_SECURITY" ]; then
 | |
|         cat >> "$TEMP_SOURCES" <<EOM
 | |
| deb ${SOURCES_SECURITY_URL} ${SOURCES_SECURITY_SUITE} ${COMPONENTS}
 | |
| deb-src ${SOURCES_SECURITY_URL} ${SOURCES_SECURITY_SUITE} ${COMPONENTS}
 | |
| EOM
 | |
|     fi
 | |
| fi
 | |
| cat "$TEMP_SOURCES" | sed -e "s|RELEASE|$RELEASE|g" | \
 | |
|     sudo bash -c "cat > $MNT/etc/apt/sources.list"
 | |
| rm -f "$TEMP_SOURCES"
 | |
| # Copy the timezone (comment this out if you want to leave the chroot at UTC)
 | |
| sudo cp /etc/localtime /etc/timezone "$MNT"/etc/
 | |
| # Create a schroot entry for this chroot
 | |
| TEMP_SCHROOTCONF=`mktemp -t schrootconf-XXXXXX`
 | |
| TEMPLATE_SCHROOTCONF=~/.mk-sbuild.schroot.conf
 | |
| TYPED_TEMPLATE_SCHROOTCONF="${TEMPLATE_SCHROOTCONF}.${SCHROOT_TYPE}"
 | |
| 
 | |
| if [ -r "${TYPED_TEMPLATE_SCHROOTCONF}" ]; then
 | |
|     cat "${TYPED_TEMPLATE_SCHROOTCONF}" > "$TEMP_SCHROOTCONF"
 | |
| elif [ -r "${TEMPLATE_SCHROOT}" ]; then
 | |
|     cat "$TEMPLATE_SCHROOTCONF" > "$TEMP_SCHROOTCONF"
 | |
| else
 | |
|         # Please do not remove the blank line above [CHROOT_NAME]
 | |
|         # it helps keep the schroot stanzas separated in the main
 | |
|         # /etc/schroot/schroot.conf file.
 | |
|         cat > "$TEMP_SCHROOTCONF" <<EOM
 | |
| 
 | |
| [CHROOT_NAME]
 | |
| description=CHROOT_NAME
 | |
| priority=3
 | |
| groups=sbuild,root,admin
 | |
| root-groups=root,sbuild,admin
 | |
| # Uncomment these lines to allow "sbuild" and "admin" users to access
 | |
| # the -source chroots directly (useful for automated updates, etc).
 | |
| #source-root-users=root,sbuild,admin
 | |
| #source-root-groups=root,sbuild,admin
 | |
| type=SCHROOT_TYPE
 | |
| EOM
 | |
|     case "$SCHROOT_TYPE" in
 | |
|     "lvm-snapshot")
 | |
|         cat >> "$TEMP_SCHROOTCONF" <<EOM
 | |
| device=CHROOT_PATH
 | |
| mount-options=-o noatime
 | |
| lvm-snapshot-options=--size SNAPSHOT_SIZE
 | |
| EOM
 | |
|     ;;
 | |
|     directory|file)
 | |
|         cat >> "${TEMP_SCHROOTCONF}" <<EOM
 | |
| union-type=aufs
 | |
| ${SCHROOT_TYPE}=CHROOT_PATH
 | |
| EOM
 | |
|     ;;
 | |
|     esac
 | |
| fi
 | |
| if [ ! -z "$personality" ]; then
 | |
|     echo "personality=$personality" >> "$TEMP_SCHROOTCONF"
 | |
| fi
 | |
| if [ ! -z "$SCHROOT_CONF_SUFFIX" ]; then
 | |
|     echo "$SCHROOT_CONF_SUFFIX" >> "$TEMP_SCHROOTCONF"
 | |
| fi
 | |
| cat "$TEMP_SCHROOTCONF" | sed \
 | |
|         -e "s|CHROOT_NAME|$CHROOT_NAME|g" \
 | |
|         -e "s|CHROOT_PATH|$CHROOT_PATH|g" \
 | |
|         -e "s|SNAPSHOT_SIZE|$SNAPSHOT_SIZE|g" \
 | |
|         -e "s|SCHROOT_TYPE|$SCHROOT_TYPE|g" \
 | |
|         | \
 | |
|         sudo bash -c "cat >> /etc/schroot/schroot.conf"
 | |
| rm -f "$TEMP_SCHROOTCONF"
 | |
| # Create image finalization script
 | |
| sudo bash -c "cat >> $MNT/finish.sh" <<EOM
 | |
| #!/bin/bash
 | |
| #set -x
 | |
| set -e
 | |
| export http_proxy=${http_proxy}
 | |
| # Reload package lists
 | |
| apt-get update || true
 | |
| # Pull down signature requirements
 | |
| apt-get -y --force-yes install gnupg ${DISTRO}-keyring
 | |
| # Reload package lists
 | |
| apt-get update || true
 | |
| # Disable debconf questions so that automated builds won't prompt
 | |
| echo set debconf/frontend Noninteractive | debconf-communicate
 | |
| echo set debconf/priority critical | debconf-communicate
 | |
| # Install basic build tool set, trying to match buildd
 | |
| apt-get -y --force-yes install $BUILD_PKGS
 | |
| # Set up expected /dev entries
 | |
| if [ ! -r /dev/stdin ];  then ln -s /proc/self/fd/0 /dev/stdin;  fi
 | |
| if [ ! -r /dev/stdout ]; then ln -s /proc/self/fd/1 /dev/stdout; fi
 | |
| if [ ! -r /dev/stderr ]; then ln -s /proc/self/fd/2 /dev/stderr; fi
 | |
| # Clean up
 | |
| apt-get clean
 | |
| rm /finish.sh
 | |
| EOM
 | |
| sudo chmod a+x "$MNT"/finish.sh
 | |
| 
 | |
| case "$SCHROOT_TYPE" in
 | |
| "lvm-snapshot")
 | |
|     sudo umount "$MNT"
 | |
|     rmdir "$MNT"
 | |
|     ;;
 | |
| "directory")
 | |
|     ;;
 | |
| "file")
 | |
|     cd "$MNT"
 | |
|     sudo tar czf "$CHROOT_PATH" .
 | |
|     cd /
 | |
|     sudo rm -r "$MNT"
 | |
|     ;;
 | |
| esac
 | |
| 
 | |
| # Run finalization script on the "golden" copy via schroot.
 | |
| sudo schroot -c "$CHROOT_NAME"-source -u root /finish.sh
 | |
| 
 | |
| # Finished
 | |
| echo ""
 | |
| echo "Done building $CHROOT_NAME."
 | |
| echo ""
 | |
| echo " To CHANGE the golden image: sudo schroot -c ${CHROOT_NAME}-source -u root"
 | |
| echo " To ENTER an image snapshot: schroot -c ${CHROOT_NAME}"
 | |
| echo " To BUILD within a snapshot: sbuild -A -d ${CHROOT_NAME} PACKAGE*.dsc"
 | |
| echo ""
 |