forked from lix-project/lix
0be8cc1466
This fixes a bug in the garbage collector where if a path /nix/store/abcd-foo is valid, but we do a isValidPath("/nix/store/abcd-foo.lock") first, then a negative entry for /nix/store/abcd is added to pathInfoCache, so /nix/store/abcd-foo is subsequently considered invalid and deleted.
51 lines
1.2 KiB
Bash
51 lines
1.2 KiB
Bash
source common.sh
|
|
|
|
clearStore
|
|
|
|
drvPath=$(nix-instantiate dependencies.nix)
|
|
outPath=$(nix-store -rvv "$drvPath")
|
|
|
|
# Set a GC root.
|
|
rm -f "$NIX_STATE_DIR"/gcroots/foo
|
|
ln -sf $outPath "$NIX_STATE_DIR"/gcroots/foo
|
|
|
|
[ "$(nix-store -q --roots $outPath)" = "$NIX_STATE_DIR/gcroots/foo -> $outPath" ]
|
|
|
|
nix-store --gc --print-roots | grep $outPath
|
|
nix-store --gc --print-live | grep $outPath
|
|
nix-store --gc --print-dead | grep $drvPath
|
|
if nix-store --gc --print-dead | grep -E $outPath$; then false; fi
|
|
|
|
nix-store --gc --print-dead
|
|
|
|
inUse=$(readLink $outPath/input-2)
|
|
if nix-store --delete $inUse; then false; fi
|
|
test -e $inUse
|
|
|
|
if nix-store --delete $outPath; then false; fi
|
|
test -e $outPath
|
|
|
|
for i in $NIX_STORE_DIR/*; do
|
|
touch $i.lock
|
|
touch $i.chroot
|
|
done
|
|
|
|
nix-collect-garbage
|
|
|
|
# Check that the root and its dependencies haven't been deleted.
|
|
cat $outPath/foobar
|
|
cat $outPath/input-2/bar
|
|
|
|
# Check that the derivation has been GC'd.
|
|
if test -e $drvPath; then false; fi
|
|
|
|
rm "$NIX_STATE_DIR"/gcroots/foo
|
|
|
|
nix-collect-garbage
|
|
|
|
# Check that the output has been GC'd.
|
|
if test -e $outPath/foobar; then false; fi
|
|
|
|
# Check that the store is empty.
|
|
rmdir $NIX_STORE_DIR/.links
|
|
rmdir $NIX_STORE_DIR
|