Skip to content

Commit

Permalink
Merge pull request #4308 from tweag/properly-test-early-cutoff
Browse files Browse the repository at this point in the history
Properly test the early cutoff for CA derivations
  • Loading branch information
edolstra committed Dec 3, 2020
2 parents 4f25644 + 8ad72b1 commit 0bd060f
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 12 deletions.
5 changes: 0 additions & 5 deletions src/libstore/build/worker.cc
Expand Up @@ -223,11 +223,6 @@ void Worker::run(const Goals & _topGoals)
uint64_t downloadSize, narSize;
store.queryMissing(topPaths, willBuild, willSubstitute, unknown, downloadSize, narSize);

if (!willBuild.empty() && 0 == settings.maxBuildJobs && getMachines().empty())
throw Error(
"%d derivations need to be built, but neither local builds ('--max-jobs') "
"nor remote builds ('--builders') are enabled", willBuild.size());

debug("entered goal loop");

while (1) {
Expand Down
16 changes: 9 additions & 7 deletions tests/content-addressed.sh
Expand Up @@ -7,30 +7,32 @@ nix --experimental-features 'nix-command ca-derivations' show-derivation --deriv

buildAttr () {
local derivationPath=$1
shift
local args=("--experimental-features" "ca-derivations" "./content-addressed.nix" "-A" "$derivationPath" "--no-out-link")
local seedValue=$2
shift; shift
local args=("--experimental-features" "ca-derivations" "./content-addressed.nix" "-A" "$derivationPath" --arg seed "$seedValue" "--no-out-link")
args+=("$@")
nix-build "${args[@]}"
}

testRemoteCache () {
clearCache
local outPath=$(buildAttr dependentNonCA)
local outPath=$(buildAttr dependentNonCA 1)
nix copy --to file://$cacheDir $outPath
clearStore
buildAttr dependentNonCA --option substituters file://$cacheDir --no-require-sigs |& (! grep "building dependent-non-ca")
buildAttr dependentNonCA 1 --option substituters file://$cacheDir --no-require-sigs |& (! grep "building dependent-non-ca")
}

testDeterministicCA () {
[[ $(buildAttr rootCA) = $(buildAttr rootCA) ]]
[[ $(buildAttr rootCA 1) = $(buildAttr rootCA 2) ]]
}

testCutoffFor () {
local out1 out2
out1=$(buildAttr $1)
out1=$(buildAttr $1 1)
# The seed only changes the root derivation, and not it's output, so the
# dependent derivations should only need to be built once.
out2=$(buildAttr $1 -j0)
buildAttr rootCA 2
out2=$(buildAttr $1 2 -j0)
test "$out1" == "$out2"
}

Expand Down

0 comments on commit 0bd060f

Please sign in to comment.