2018-01-19 12:58:28 +00:00
|
|
|
source common.sh
|
|
|
|
|
2019-02-17 21:26:49 +00:00
|
|
|
checkBuildTempDirRemoved ()
|
|
|
|
{
|
|
|
|
buildDir=$(sed -n 's/CHECK_TMPDIR=//p' $1 | head -1)
|
|
|
|
checkBuildIdFile=${buildDir}/checkBuildId
|
|
|
|
[[ ! -f $checkBuildIdFile ]] || ! grep $checkBuildId $checkBuildIdFile
|
|
|
|
}
|
|
|
|
|
|
|
|
# written to build temp directories to verify created by this instance
|
|
|
|
checkBuildId=$(date +%s%N)
|
|
|
|
|
2018-01-19 12:58:28 +00:00
|
|
|
clearStore
|
|
|
|
|
|
|
|
nix-build dependencies.nix --no-out-link
|
|
|
|
nix-build dependencies.nix --no-out-link --check
|
|
|
|
|
2019-02-17 21:26:49 +00:00
|
|
|
# check for dangling temporary build directories
|
|
|
|
# only retain if build fails and --keep-failed is specified, or...
|
|
|
|
# ...build is non-deterministic and --check and --keep-failed are both specified
|
|
|
|
nix-build check.nix -A failed --argstr checkBuildId $checkBuildId \
|
|
|
|
--no-out-link 2> $TEST_ROOT/log || status=$?
|
|
|
|
[ "$status" = "100" ]
|
|
|
|
checkBuildTempDirRemoved $TEST_ROOT/log
|
|
|
|
|
|
|
|
nix-build check.nix -A failed --argstr checkBuildId $checkBuildId \
|
|
|
|
--no-out-link --keep-failed 2> $TEST_ROOT/log || status=$?
|
|
|
|
[ "$status" = "100" ]
|
|
|
|
if checkBuildTempDirRemoved $TEST_ROOT/log; then false; fi
|
|
|
|
|
|
|
|
nix-build check.nix -A deterministic --argstr checkBuildId $checkBuildId \
|
|
|
|
--no-out-link 2> $TEST_ROOT/log
|
|
|
|
checkBuildTempDirRemoved $TEST_ROOT/log
|
|
|
|
|
|
|
|
nix-build check.nix -A deterministic --argstr checkBuildId $checkBuildId \
|
|
|
|
--no-out-link --check --keep-failed 2> $TEST_ROOT/log
|
|
|
|
if grep -q 'may not be deterministic' $TEST_ROOT/log; then false; fi
|
|
|
|
checkBuildTempDirRemoved $TEST_ROOT/log
|
|
|
|
|
|
|
|
nix-build check.nix -A nondeterministic --argstr checkBuildId $checkBuildId \
|
|
|
|
--no-out-link 2> $TEST_ROOT/log
|
|
|
|
checkBuildTempDirRemoved $TEST_ROOT/log
|
|
|
|
|
|
|
|
nix-build check.nix -A nondeterministic --argstr checkBuildId $checkBuildId \
|
|
|
|
--no-out-link --check 2> $TEST_ROOT/log || status=$?
|
|
|
|
grep 'may not be deterministic' $TEST_ROOT/log
|
|
|
|
[ "$status" = "104" ]
|
|
|
|
checkBuildTempDirRemoved $TEST_ROOT/log
|
|
|
|
|
|
|
|
nix-build check.nix -A nondeterministic --argstr checkBuildId $checkBuildId \
|
|
|
|
--no-out-link --check --keep-failed 2> $TEST_ROOT/log || status=$?
|
|
|
|
|
|
|
|
# The above nix-build fails with status=1 on darwin (not sure why)
|
|
|
|
# ...but the primary purpose of the test case is to verify the temp directory is retained
|
|
|
|
if [ "$(uname -s)" != "Darwin" ]; then
|
2018-01-19 12:58:28 +00:00
|
|
|
grep 'may not be deterministic' $TEST_ROOT/log
|
2019-06-15 13:28:32 +00:00
|
|
|
[ "$status" = "104" ]
|
2019-02-17 21:26:49 +00:00
|
|
|
fi
|
|
|
|
if checkBuildTempDirRemoved $TEST_ROOT/log; then false; fi
|
2018-01-19 12:58:28 +00:00
|
|
|
|
|
|
|
clearStore
|
|
|
|
|
|
|
|
nix-build dependencies.nix --no-out-link --repeat 3
|
|
|
|
|
2019-05-11 21:32:53 +00:00
|
|
|
nix-build check.nix -A nondeterministic --no-out-link --repeat 1 2> $TEST_ROOT/log || status=$?
|
|
|
|
[ "$status" = "1" ]
|
2018-01-19 12:58:28 +00:00
|
|
|
grep 'differs from previous round' $TEST_ROOT/log
|
|
|
|
|
2018-01-22 15:56:10 +00:00
|
|
|
path=$(nix-build check.nix -A fetchurl --no-out-link --hashed-mirrors '')
|
2018-01-19 13:53:34 +00:00
|
|
|
|
|
|
|
chmod +w $path
|
|
|
|
echo foo > $path
|
|
|
|
chmod -w $path
|
|
|
|
|
2018-01-22 15:56:10 +00:00
|
|
|
nix-build check.nix -A fetchurl --no-out-link --check --hashed-mirrors ''
|
2018-01-19 13:53:34 +00:00
|
|
|
# Note: "check" doesn't repair anything, it just compares to the hash stored in the database.
|
|
|
|
[[ $(cat $path) = foo ]]
|
|
|
|
|
2018-01-22 15:56:10 +00:00
|
|
|
nix-build check.nix -A fetchurl --no-out-link --repair --hashed-mirrors ''
|
2018-01-19 13:53:34 +00:00
|
|
|
[[ $(cat $path) != foo ]]
|
2019-05-11 21:32:53 +00:00
|
|
|
|
|
|
|
nix-build check.nix -A hashmismatch --no-out-link --hashed-mirrors '' || status=$?
|
|
|
|
[ "$status" = "102" ]
|
|
|
|
|
|
|
|
echo -n > ./dummy
|
|
|
|
nix-build check.nix -A hashmismatch --no-out-link --hashed-mirrors ''
|
|
|
|
echo 'Hello World' > ./dummy
|
|
|
|
|
|
|
|
nix-build check.nix -A hashmismatch --no-out-link --check --hashed-mirrors '' || status=$?
|
|
|
|
[ "$status" = "102" ]
|
|
|
|
|
|
|
|
# Multiple failures with --keep-going
|
|
|
|
nix-build check.nix -A nondeterministic --no-out-link
|
|
|
|
nix-build check.nix -A nondeterministic -A hashmismatch --no-out-link --check --keep-going --hashed-mirrors '' || status=$?
|
2019-06-15 13:28:32 +00:00
|
|
|
[ "$status" = "110" ]
|