7a2acbdc5a
Previously, 'guix shell' for example would leak the socket that's connected to the daemon. * guix/store.scm (open-unix-domain-socket, open-inet-socket): Pass SOCK_CLOEXEC to 'socket'. * tests/guix-shell.sh: Add test.
130 lines
4.7 KiB
Bash
130 lines
4.7 KiB
Bash
# GNU Guix --- Functional package management for GNU
|
|
# Copyright © 2021-2022 Ludovic Courtès <ludo@gnu.org>
|
|
#
|
|
# This file is part of GNU Guix.
|
|
#
|
|
# GNU Guix 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.
|
|
#
|
|
# GNU Guix 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.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#
|
|
# Test the 'guix shell' alias.
|
|
#
|
|
|
|
guix shell --version
|
|
|
|
configdir="t-guix-shell-config-$$"
|
|
tmpdir="t-guix-shell-$$"
|
|
trap 'rm -r "$tmpdir" "$configdir"' EXIT
|
|
mkdir "$tmpdir" "$configdir" "$configdir/guix"
|
|
|
|
XDG_CONFIG_HOME="$(realpath $configdir)"
|
|
export XDG_CONFIG_HOME
|
|
|
|
guix shell --bootstrap --pure guile-bootstrap -- guile --version
|
|
|
|
# '--ad-hoc' is a thing of the past.
|
|
! guix shell --ad-hoc guile-bootstrap
|
|
|
|
# Rejecting unsupported packages.
|
|
! guix shell -s armhf-linux intelmetool -n
|
|
|
|
# Test approximately that the child process does not inherit extra file
|
|
# descriptors. Ideally we'd check there's nothing more than 0, 1, and 2, but
|
|
# we cannot do that because (1) we might be inheriting additional FDs, for
|
|
# example due to <https://issues.guix.gnu.org/57567>, and (2) Bash itself
|
|
# opens a couple of extra FDs.
|
|
initial_fd_list="$(echo /proc/$$/fd/*)"
|
|
fd_list="$(guix shell --bootstrap guile-bootstrap -- \
|
|
"$SHELL" -c 'echo /proc/$$/fd/*')"
|
|
test "$(echo $fd_list | wc -w)" -le "$(echo $initial_fd_list | wc -w)"
|
|
|
|
# Ignoring unauthorized files.
|
|
cat > "$tmpdir/guix.scm" <<EOF
|
|
This is a broken guix.scm file.
|
|
EOF
|
|
! (cd "$tmpdir"; SHELL="$(type -P true)" guix shell --bootstrap 2> "stderr")
|
|
grep "not authorized" "$tmpdir/stderr"
|
|
rm "$tmpdir/stderr"
|
|
|
|
# Authorize the directory.
|
|
echo "$(realpath "$tmpdir")" > "$configdir/guix/shell-authorized-directories"
|
|
|
|
# Ignoring 'manifest.scm' and 'guix.scm' in non-interactive use.
|
|
(cd "$tmpdir"; guix shell --bootstrap -- true)
|
|
mv "$tmpdir/guix.scm" "$tmpdir/manifest.scm"
|
|
(cd "$tmpdir"; guix shell --bootstrap -- true)
|
|
rm "$tmpdir/manifest.scm"
|
|
|
|
# Honoring the local 'manifest.scm' file.
|
|
cat > "$tmpdir/manifest.scm" <<EOF
|
|
(specifications->manifest '("guile-bootstrap"))
|
|
EOF
|
|
cat > "$tmpdir/fake-shell.sh" <<EOF
|
|
#!$SHELL
|
|
# This fake shell allows us to test interactive use.
|
|
exec echo "\$GUIX_ENVIRONMENT"
|
|
EOF
|
|
chmod +x "$tmpdir/fake-shell.sh"
|
|
profile1="$(cd "$tmpdir"; SHELL="$(realpath fake-shell.sh)" guix shell --bootstrap)"
|
|
profile2="$(guix shell --bootstrap guile-bootstrap -- "$SHELL" -c 'echo $GUIX_ENVIRONMENT')"
|
|
test -n "$profile1"
|
|
test "$profile1" = "$profile2"
|
|
rm "$tmpdir/manifest.scm"
|
|
|
|
# Do not read manifest when passed '-q'.
|
|
echo "Broken manifest." > "$tmpdir/manifest.scm"
|
|
(cd "$tmpdir"; SHELL="$(realpath fake-shell.sh)" guix shell --bootstrap -q)
|
|
rm "$tmpdir/manifest.scm"
|
|
|
|
# Make sure '-D' affects only the immediately following '-f', and not packages
|
|
# that appear later: <https://issues.guix.gnu.org/52093>.
|
|
cat > "$tmpdir/empty-package.scm" <<EOF
|
|
(use-modules (guix) (guix tests)
|
|
(guix build-system trivial))
|
|
|
|
(dummy-package "empty-package"
|
|
(build-system trivial-build-system)) ;zero inputs
|
|
EOF
|
|
|
|
guix shell --bootstrap --pure -D -f "$tmpdir/empty-package.scm" \
|
|
guile-bootstrap -- guile --version
|
|
rm "$tmpdir/empty-package.scm"
|
|
|
|
if guile -c '(getaddrinfo "www.gnu.org" "80" AI_NUMERICSERV)' 2> /dev/null
|
|
then
|
|
# Compute the build environment for the initial GNU Make.
|
|
guix shell --bootstrap --no-substitutes --search-paths --pure \
|
|
-D -e '(@ (guix tests) gnu-make-for-tests)' > "$tmpdir/a"
|
|
|
|
# Make sure bootstrap binaries are in the profile.
|
|
profile=`grep "^export PATH" "$tmpdir/a" | sed -r 's|^.*="(.*)/bin"|\1|'`
|
|
|
|
# Make sure the bootstrap binaries are all listed where they belong.
|
|
grep -E "^export PATH=\"$profile/bin\"" "$tmpdir/a"
|
|
grep -E "^export C_INCLUDE_PATH=\"$profile/include\"" "$tmpdir/a"
|
|
grep -E "^export LIBRARY_PATH=\"$profile/lib\"" "$tmpdir/a"
|
|
for dep in bootstrap-binaries-0 gcc-bootstrap-0 glibc-bootstrap-0
|
|
do
|
|
guix gc --references "$profile" | grep "$dep"
|
|
done
|
|
|
|
# 'make-boot0' itself must not be listed.
|
|
! guix gc --references "$profile" | grep make-boot0
|
|
|
|
# Honoring the local 'guix.scm' file.
|
|
echo '(@ (guix tests) gnu-make-for-tests)' > "$tmpdir/guix.scm"
|
|
(cd "$tmpdir"; guix shell --bootstrap --search-paths --pure > "b")
|
|
cmp "$tmpdir/a" "$tmpdir/b"
|
|
rm "$tmpdir/guix.scm"
|
|
fi
|