about summary refs log tree commit diff
path: root/tests/linux-sandbox.sh
diff options
context:
space:
mode:
authorEelco Dolstra <edolstra@gmail.com>2017-05-02T13·09+0200
committerEelco Dolstra <edolstra@gmail.com>2017-05-02T13·46+0200
commit7dedd3fa2455f1e219bc671d04d1dd1eaec54dfa (patch)
treebe813e01c4602114b6594f70b0eeaef9582561c1 /tests/linux-sandbox.sh
parentc5bea16611ae1aa99680bbd5d94bc69811869885 (diff)
Add a test for diverted stores
Diffstat (limited to 'tests/linux-sandbox.sh')
-rw-r--r--tests/linux-sandbox.sh27
1 files changed, 27 insertions, 0 deletions
diff --git a/tests/linux-sandbox.sh b/tests/linux-sandbox.sh
new file mode 100644
index 000000000000..740b2c357099
--- /dev/null
+++ b/tests/linux-sandbox.sh
@@ -0,0 +1,27 @@
+source common.sh
+
+clearStore
+
+if [[ $(uname) != Linux ]]; then exit; fi
+
+# Note: we need to bind-mount $SHELL into the chroot. Currently we
+# only support the case where $SHELL is in the Nix store, because
+# otherwise things get complicated (e.g. if it's in /bin, do we need
+# /lib as well?).
+if [[ ! $SHELL =~ /nix/store ]]; then exit; fi
+
+chmod -R u+w $TEST_ROOT/store0 || true
+rm -rf $TEST_ROOT/store0
+
+export NIX_STORE_DIR=/my/store
+export NIX_REMOTE="local?root=$TEST_ROOT/store0"
+
+outPath=$( nix-build dependencies.nix --no-out-link --option build-sandbox-paths /nix/store)
+
+[[ $outPath =~ /my/store/.*-dependencies ]]
+
+nix path-info -r $outPath | grep input-2
+
+nix ls-store -R -l $outPath | grep foobar
+
+nix cat-store $outPath/foobar | grep FOOBAR