mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2024-11-25 23:36:16 +02:00
59086e459c
Disable various tests if the kernel doesn't support unprivileged user namespaces (e.g. Arch Linux disables them) or disable them via a sysctl (Debian, Ubuntu). Fixes #1521 Fixes #1625
28 lines
811 B
Bash
28 lines
811 B
Bash
source common.sh
|
|
|
|
clearStore
|
|
clearCache
|
|
|
|
nix run -f run.nix hello -c hello | grep 'Hello World'
|
|
nix run -f run.nix hello -c hello NixOS | grep 'Hello NixOS'
|
|
|
|
if ! canUseSandbox; then exit; fi
|
|
|
|
chmod -R u+w $TEST_ROOT/store0 || true
|
|
rm -rf $TEST_ROOT/store0
|
|
|
|
clearStore
|
|
|
|
path=$(nix eval --raw -f run.nix hello)
|
|
|
|
# Note: we need the sandbox paths to ensure that the shell is
|
|
# visible in the sandbox.
|
|
nix run --sandbox-build-dir /build-tmp \
|
|
--sandbox-paths '/nix? /bin? /lib? /lib64? /usr?' \
|
|
--store $TEST_ROOT/store0 -f run.nix hello -c hello | grep 'Hello World'
|
|
|
|
path2=$(nix run --sandbox-paths '/nix? /bin? /lib? /lib64? /usr?' --store $TEST_ROOT/store0 -f run.nix hello -c $SHELL -c 'type -p hello')
|
|
|
|
[[ $path/bin/hello = $path2 ]]
|
|
|
|
[[ -e $TEST_ROOT/store0/nix/store/$(basename $path)/bin/hello ]]
|