summaryrefslogtreecommitdiffstats
path: root/debian/tests/build-procenv
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-14 13:46:57 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-14 13:46:57 +0000
commitff49fdb2c5e63bb1e7a0620ed3e80d42d313b04a (patch)
tree0d525f5d5d227d08c6012c3c25216e9586731b34 /debian/tests/build-procenv
parentAdding upstream version 0.85.6. (diff)
downloadsbuild-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-procenv194
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"