diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-14 13:46:57 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-14 13:46:57 +0000 |
commit | ff49fdb2c5e63bb1e7a0620ed3e80d42d313b04a (patch) | |
tree | 0d525f5d5d227d08c6012c3c25216e9586731b34 /debian/tests/build-procenv | |
parent | Adding upstream version 0.85.6. (diff) | |
download | sbuild-ff49fdb2c5e63bb1e7a0620ed3e80d42d313b04a.tar.xz sbuild-ff49fdb2c5e63bb1e7a0620ed3e80d42d313b04a.zip |
Adding debian version 0.85.6.debian/0.85.6
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'debian/tests/build-procenv')
-rw-r--r-- | debian/tests/build-procenv | 194 |
1 files changed, 194 insertions, 0 deletions
diff --git a/debian/tests/build-procenv b/debian/tests/build-procenv new file mode 100644 index 0000000..73f7e25 --- /dev/null +++ b/debian/tests/build-procenv @@ -0,0 +1,194 @@ +#!/bin/sh +#--------------------------------------------------------------------- +# DEP-8 test for sbuild. +# +# Creates a sbuild chroot, builds a package, installs the resulting +# .deb, then runs the command provided by the .deb. +#--------------------------------------------------------------------- +set -e + +die() +{ + msg="$*" + echo "ERROR: $msg" >&2 + exit 1 +} + +# The package we'll ask sbuild to build (we know its buildable since +# it's already in the archive :-) +# +# The advantage of choosing this particular package being that it runs +# *itself* at the end of its build, which has the nice side-effect of +# exposing the full sbuild environment to those perusing the autopkgtest +# logs. +pkg=procenv +components="" + +distro=$(lsb_release -is|tr '[:upper:]' '[:lower:]') +[ -z "$distro" ] && die "cannot establish distribution" + +host_release=$(lsb_release -cs) +[ -z "$host_release" ] && die "cannot establish release running on host" + +if [ "$distro" = ubuntu ] +then + # Build chroot for latest release. + release=$(distro-info --devel) + components=main,universe + + case $(dpkg --print-architecture) in + amd64|i386) + url=http://archive.ubuntu.com/ubuntu + ;; + *) + url=http://ports.ubuntu.com/ubuntu-ports + ;; + esac +elif [ "$distro" = debian ] +then + # Build chroot for latest stable release since + # sid may not be buildable on a particular day. + release=$(distro-info --stable) + + url=http://httpredir.debian.org/debian +else + die "need to know where archive is for distro '$distro'" +fi + +arch=$(dpkg --print-architecture 2>/dev/null) +[ -z "$arch" ] && die "cannot establish architecture" + +[ -z "$AUTOPKGTEST_TMP" ] && die "AUTOPKGTEST_TMP not set" +dir="$AUTOPKGTEST_TMP/schroot-$release" + +if ! mknod "$AUTOPKGTEST_TMP"/test-dev-null c 1 3; then + echo "Cannot make special nodes; running in unprivileged container?" >&2 + exit 77 +else + rm "$AUTOPKGTEST_TMP"/test-dev-null +fi + +# on Debian Salsa CI, $AUTOPKGTEST_NORMAL_USER is empty +if [ -z "$AUTOPKGTEST_NORMAL_USER" ]; then + AUTOPKGTEST_NORMAL_USER=debci + useradd --create-home "$AUTOPKGTEST_NORMAL_USER" +fi +passwd --delete "$AUTOPKGTEST_NORMAL_USER" +usermod --append --groups sudo,sbuild "$AUTOPKGTEST_NORMAL_USER" + +# The expected name of the schroot that sbuild-createchroot will create +chroot="${release}-${arch}-sbuild" + +# schroot does not allow a chroot name to be specified at creation time. +# As such, we must take care to avoid stomping on a developers chroots. +# If we find any that match the chroot we're about to try and make, exit +# with a message. +# +# Note that we are very cautious in the grep check below; we purposely +# don't match on the _type_ of schroot in case new schroot types are +# added and this test is not updated to take account of the new types. + +schroots=$(schroot -l 2>/dev/null) + +if [ -n "$schroots" ] && echo "$schroots"|grep -q ":${release}-${arch}" +then + echo "INFO:" + echo "INFO: Existing schroots detected for current release ($release)" + echo "INFO: and architecture ($arch)" + echo "INFO:" + echo "INFO: Not continuing." + echo "INFO:" + + # exit successfully + exit 0 +fi + +if [ -z "$http_proxy" ]; then + RES=$(apt-config shell http_proxy Acquire::http::Proxy) + # shellcheck disable=SC2086 + eval $RES + export http_proxy + echo "INFO: using proxy: ${http_proxy:-(none)}" +fi + +echo "INFO: Creating sbuild chroot '$chroot' for release '$release' in directory '$dir' from url '$url'" +[ -n "$components" ] && components="--components=$components" +# avoid "debconf: delaying package configuration, since apt-utils is not installed" +runuser -u "$AUTOPKGTEST_NORMAL_USER" -- sudo sbuild-createchroot $components "$release" "$dir" "$url" +if [ -n "$http_proxy" ]; then + echo "Acquire::http { Proxy \"$http_proxy\"; };" > "$dir/etc/apt/apt.conf.d/01proxy" +fi + +echo "INFO: Checking chroot '$chroot' is known" +schroot --list --all-chroots|grep "^chroot:${chroot}$" + +echo "INFO: Displaying information about chroot '$chroot'" +schroot --info "${chroot}" + +echo "INFO: Building package '$pkg' for release '$release'" +runuser -u "$AUTOPKGTEST_NORMAL_USER" -- sbuild --verbose -A -d "$release" "$pkg" 2>&1 + +deb=$(ls ${pkg}_*"_${arch}.deb") + +echo "INFO: Displaying sbuild log" +cat "${pkg}_${arch}.build" + +# Do what we can to check if the .deb looks usable (since we may not +# be able to install it to test it properly) +echo "INFO: Listing information on '$deb'" +dpkg --info "$deb" + +echo "INFO: Listing contents of '$deb'" +dpkg --contents "$deb" + +extract="$AUTOPKGTEST_TMP/extract" +echo "INFO: Extracting '$deb' to '$extract'" +dpkg --extract "$deb" "$extract" + +if [ "$release" = "$host_release" ] +then + echo "INFO: Installing package '$pkg' from '$deb'" + apt -o Apt::Cmd::Disable-Script-Warning=1 -o APT::Get::Assume-Yes=1 install "$(pwd)/$deb" + + # run the command to prove the build worked but also to expose the + # auto-package-test environment used for this test. + cmd=$pkg + echo "INFO: Showing AutoPkgTest environment by running '$cmd' from package '$pkg'" + "$cmd" +else + echo "INFO: Not installing package '$pkg' as host release ('$host_release')" + echo "INFO: differs to release package is built for ('$release')" +fi + +# There is no sbuild/schroot command to actually delete the chroot, but +# we do want to clean up fully. The best we can do is end the schroot +# session, and remove the sym links. Removing the chroot itself is not +# necessary since it is created below $AUTOPKGTEST_TMP so will be removed +# automatically by the AutoPkgTest environment. + +echo "INFO: Establishing schroot sessions for chroot '$chroot'" +session=$(schroot --list --all-sessions|grep "^session:${release}-${arch}-" || :) +if [ -n "$session" ] +then + count=$(echo "$session"|wc -l) + [ "$count" -eq 1 ] || die "expected 1 session, found $count" + + echo "INFO: Ending schroot session '$session'" + schroot --end-session --chroot "$session" +else + echo "INFO: No schroot session to end" +fi + +echo "INFO: Cleaning up" + +echo "INFO: Removing sbuild chroot symbolic link for '$chroot'" +link=$(ls "/etc/sbuild/chroot/${chroot}") +# remove soon-to-be-broken symbolic link +[ -h "$link" ] && rm "$link" + +# remove soon-to-be stale configuration file +echo "INFO: Removing schroot configuration file for '$chroot'" +config=$(ls "/etc/schroot/chroot.d/${chroot}-"*) +[ -f "$config" ] && rm "$config" + +echo "INFO: SUCCESS" |