Skip to content

Commit

Permalink
Make --keep-going work with drv that don't have a system
Browse files Browse the repository at this point in the history
  • Loading branch information
RossComputerGuy committed Jan 10, 2025
1 parent 2d9b213 commit 5e27b27
Show file tree
Hide file tree
Showing 7 changed files with 67 additions and 3 deletions.
2 changes: 2 additions & 0 deletions src/libstore/build-result.hh
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ struct BuildResult
NotDeterministic,
ResolvesToAlreadyValid,
NoSubstituters,
NoCompatibleBuilder,
} status = MiscFailure;

/**
Expand Down Expand Up @@ -64,6 +65,7 @@ struct BuildResult
case NotDeterministic: return "NotDeterministic";
case ResolvesToAlreadyValid: return "ResolvesToAlreadyValid";
case NoSubstituters: return "NoSubstituters";
case NoCompatibleBuilder: return "NoCompatibleBuilder";
default: return "Unknown";
};
}();
Expand Down
4 changes: 2 additions & 2 deletions src/libstore/build/worker.cc
Original file line number Diff line number Diff line change
Expand Up @@ -339,7 +339,7 @@ void Worker::run(const Goals & _topGoals)
waitForInput();
else if (awake.empty() && 0U == settings.maxBuildJobs) {
if (getMachines().empty())
throw Error(
throw NoCompatibleBuilder(
R"(
Unable to start any build;
either increase '--max-jobs' or enable remote builds.
Expand All @@ -348,7 +348,7 @@ void Worker::run(const Goals & _topGoals)
)"
);
else
throw Error(
throw NoCompatibleBuilder(
R"(
Unable to start any build;
remote machines may not have all required system features.
Expand Down
1 change: 1 addition & 0 deletions src/libstore/store-api.hh
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,7 @@ MakeError(InvalidPath, Error);
MakeError(Unsupported, Error);
MakeError(SubstituteGone, Error);
MakeError(SubstituterDisabled, Error);
MakeError(NoCompatibleBuilder, Error);

MakeError(InvalidStoreReference, Error);

Expand Down
6 changes: 5 additions & 1 deletion src/libstore/unix/build/local-derivation-goal.cc
Original file line number Diff line number Diff line change
Expand Up @@ -264,6 +264,10 @@ Goal::Co LocalDerivationGoal::tryLocalBuild()
buildUser.reset();
worker.permanentFailure = true;
co_return done(BuildResult::InputRejected, {}, std::move(e));
} catch (NoCompatibleBuilder & e) {
outputLocks.unlock();
buildUser.reset();
co_return done(BuildResult::NoCompatibleBuilder, {}, std::move(e));
}

started();
Expand Down Expand Up @@ -532,7 +536,7 @@ void LocalDerivationGoal::startBuilder()

/* Right platform? */
if (!parsedDrv->canBuildLocally(worker.store))
throw Error("a '%s' with features {%s} is required to build '%s', but I am a '%s' with features {%s}",
throw NoCompatibleBuilder("a '%s' with features {%s} is required to build '%s', but I am a '%s' with features {%s}",
drv->platform,
concatStringsSep(", ", parsedDrv->getRequiredSystemFeatures()),
worker.store.printStorePath(drvPath),
Expand Down
33 changes: 33 additions & 0 deletions tests/functional/keep-going.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
with import ./config.nix;

rec {

# Hack to get the scheduler to do what we want: The `good` derivation can
# only be built after `delay_good` (which takes a long time to build) while
# the others don't have any dependency.
# This means that if we build this with parallelism (`-j2`), then we can be
# reasonably sure that the failing derivations will be scheduled _before_ the
# `good` one (and so we can check that `--keep-going` works fine)
delay_good = mkDerivation {
name = "delay-good";
buildCommand = "sleep 3; touch $out";
};

good = mkDerivation {
name = "good";
buildCommand = "mkdir $out; echo foo > $out/bar";
delay = delay_good;
};

failing = mkDerivation {
name = "failing";
buildCommand = false;
};

requiresFooSystemFeature = mkDerivation {
name = "requires-foo-system-feature";
buildCommand = "mkdir $out; echo foo > $out/bar";
requiredSystemFeatures = [ "foo" ];
};

}
23 changes: 23 additions & 0 deletions tests/functional/keep-going.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
#!/usr/bin/env bash

source common.sh

clearStore

mkdir -p "$TEST_ROOT/sync"
# XXX: These invocations of nix-build should always return 100 according to the manpage, but often return 1
(! nix-build ./keep-going.nix -j2 --extra-sandbox-paths "$TEST_ROOT/sync" --no-out-link 2>&1 \
| while read -r ln; do
echo "nix build: $ln"
if echo "$ln" | grepQuiet ...; then
touch "$TEST_ROOT/sync/failing-drv-failed"
fi
done)
(! nix-build ./keep-going.nix -A good -j0 --no-out-link) || \
fail "Hello shouldn't have been built because of earlier errors"

clearStore

(! nix-build ./keep-going.nix --keep-going -j2 --no-out-link)
nix-build ./keep-going.nix -A good -j0 --no-out-link || \
fail "Hello should have been built despite the errors because of '--keep-going'"
1 change: 1 addition & 0 deletions tests/functional/meson.build
Original file line number Diff line number Diff line change
Expand Up @@ -164,6 +164,7 @@ suites = [
'debugger.sh',
'extra-sandbox-profile.sh',
'help.sh',
'keep-going.sh',
],
'workdir': meson.current_source_dir(),
},
Expand Down

0 comments on commit 5e27b27

Please sign in to comment.