summary refs log tree commit diff
path: root/tests/referrers.sh
blob: e3f8e07bc1bbf02749ca69924c5f7df4bcff2791 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
source common.sh

# This takes way to long on Cygwin (because process creation is so slow...).
if test "$system" = i686-cygwin; then exit 0; fi

max=2500

reference=$NIX_STORE_DIR/abcdef
touch $reference
(echo $reference && echo && echo 0) | $nixstore --register-validity 

echo "making registration..."

for ((n = 0; n < $max; n++)); do
    storePath=$NIX_STORE_DIR/$n
    touch $storePath
    ref2=$NIX_STORE_DIR/$((n+1))
    if test $((n+1)) = $max; then
        ref2=$reference
    fi
    (echo $storePath && echo && echo 2 && echo $reference && echo $ref2)
done > $TEST_ROOT/reg_info

echo "registering..."

time $nixstore --register-validity < $TEST_ROOT/reg_info

oldTime=$(cat test-tmp/db/info/1 | grep Registered-At)

echo "sleeping..."

sleep 2

echo "reregistering..."

time $nixstore --register-validity --reregister < $TEST_ROOT/reg_info

newTime=$(cat test-tmp/db/info/1 | grep Registered-At)

if test "$newTime" != "$oldTime"; then
    echo "reregistration changed original registration time"
    exit 1
fi

if test "$(cat test-tmp/db/referrer/1 | wc -w)" -ne 1; then
    echo "reregistration duplicated referrers"
    exit 1
fi

echo "collecting garbage..."
ln -sfn $reference "$NIX_STATE_DIR"/gcroots/ref
time $nixstore --gc

if test "$(cat test-tmp/db/referrer/abcdef | wc -w)" -ne 0; then
    echo "referrers not cleaned up"
    exit 1
fi