forked from lix-project/lix
Add a test for Nix store optimisation
This commit is contained in:
parent
680ab6f83d
commit
0f65793f94
|
@ -9,7 +9,7 @@ TESTS = init.sh hash.sh lang.sh add.sh simple.sh dependencies.sh \
|
||||||
gc-runtime.sh install-package.sh check-refs.sh filter-source.sh \
|
gc-runtime.sh install-package.sh check-refs.sh filter-source.sh \
|
||||||
remote-store.sh export.sh export-graph.sh negative-caching.sh \
|
remote-store.sh export.sh export-graph.sh negative-caching.sh \
|
||||||
binary-patching.sh timeout.sh secure-drv-outputs.sh nix-channel.sh \
|
binary-patching.sh timeout.sh secure-drv-outputs.sh nix-channel.sh \
|
||||||
multiple-outputs.sh import-derivation.sh fetchurl.sh
|
multiple-outputs.sh import-derivation.sh fetchurl.sh optimise-store.sh
|
||||||
|
|
||||||
XFAIL_TESTS =
|
XFAIL_TESTS =
|
||||||
|
|
||||||
|
|
26
tests/optimise-store.sh
Normal file
26
tests/optimise-store.sh
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
source common.sh
|
||||||
|
|
||||||
|
clearStore
|
||||||
|
|
||||||
|
outPath1=$(echo 'with import ./config.nix; mkDerivation { name = "foo1"; builder = builtins.toFile "builder" "mkdir $out; echo hello > $out/foo"; }' | nix-build - --no-out-link)
|
||||||
|
outPath2=$(echo 'with import ./config.nix; mkDerivation { name = "foo2"; builder = builtins.toFile "builder" "mkdir $out; echo hello > $out/foo"; }' | nix-build - --no-out-link)
|
||||||
|
|
||||||
|
inode1="$(perl -e "print ((lstat('$outPath1/foo'))[1])")"
|
||||||
|
inode2="$(perl -e "print ((lstat('$outPath2/foo'))[1])")"
|
||||||
|
if [ "$inode1" != "$inode2" ]; then
|
||||||
|
echo "inodes do not match"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
nlink="$(perl -e "print ((lstat('$outPath1/foo'))[3])")"
|
||||||
|
if [ "$nlink" != 3 ]; then
|
||||||
|
echo "link count incorrect"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
nix-store --gc
|
||||||
|
|
||||||
|
if [ -n "$(ls $NIX_STORE_DIR/.links)" ]; then
|
||||||
|
echo ".links directory not empty after GC"
|
||||||
|
exit 1
|
||||||
|
fi
|
Loading…
Reference in a new issue