Skip to content

Commit

Permalink
Merge pull request #11534 from fricklerhandwerk/backport-10652-to-2.1…
Browse files Browse the repository at this point in the history
…8-maintenance

[backport 2.18] libstore: check additionalSandboxProfile
  • Loading branch information
Ericson2314 authored Sep 18, 2024
2 parents 9f52684 + 1524ad3 commit d4d300c
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 4 deletions.
8 changes: 4 additions & 4 deletions src/libstore/build/local-derivation-goal.cc
Original file line number Diff line number Diff line change
Expand Up @@ -172,6 +172,10 @@ void LocalDerivationGoal::killSandbox(bool getStats)

void LocalDerivationGoal::tryLocalBuild()
{
#if __APPLE__
additionalSandboxProfile = parsedDrv->getStringAttr("__sandboxProfile").value_or("");
#endif

unsigned int curBuilds = worker.getNrLocalBuilds();
if (curBuilds >= settings.maxBuildJobs) {
state = &DerivationGoal::tryToBuild;
Expand Down Expand Up @@ -478,10 +482,6 @@ void LocalDerivationGoal::startBuilder()
settings.thisSystem,
concatStringsSep<StringSet>(", ", worker.store.systemFeatures));

#if __APPLE__
additionalSandboxProfile = parsedDrv->getStringAttr("__sandboxProfile").value_or("");
#endif

/* Create a temporary directory where the build will take
place. */
topTmpDir = createTempDir("", "nix-build-" + std::string(drvPath.name()), false, false, 0700);
Expand Down
19 changes: 19 additions & 0 deletions tests/functional/extra-sandbox-profile.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
{ destFile, seed }:

with import ./config.nix;

mkDerivation {
name = "simple";
__sandboxProfile = ''
# Allow writing any file in the filesystem
(allow file*)
'';
inherit seed;
buildCommand = ''
(
set -x
touch ${destFile}
touch $out
)
'';
}
23 changes: 23 additions & 0 deletions tests/functional/extra-sandbox-profile.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
source common.sh

if [[ $(uname) != Darwin ]]; then skipTest "Need Darwin"; fi

DEST_FILE="${TEST_ROOT}/foo"

testSandboxProfile () (
set -e

sandboxMode="$1"

rm -f "${DEST_FILE}"
nix-build --no-out-link ./extra-sandbox-profile.nix \
--option sandbox "$sandboxMode" \
--argstr seed "$RANDOM" \
--argstr destFile "${DEST_FILE}"

ls -l "${DEST_FILE}"
)

testSandboxProfile "false"
expectStderr 2 testSandboxProfile "true"
testSandboxProfile "relaxed"

0 comments on commit d4d300c

Please sign in to comment.