Skip to content

Commit

Permalink
Cleanup serialized context coming back from a task worker
Browse files Browse the repository at this point in the history
  • Loading branch information
veewee committed Aug 30, 2024
1 parent 58739c1 commit 12dd30d
Show file tree
Hide file tree
Showing 5 changed files with 36 additions and 2 deletions.
2 changes: 1 addition & 1 deletion composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@
"nikic/php-parser": "^5.0",
"php-parallel-lint/php-parallel-lint": "^1.3",
"phpspec/phpspec": "^7.2",
"phpspec/prophecy-phpunit": "^2.0",
"phpspec/prophecy-phpunit": "^2.2",
"phpunit/phpunit": "^9.5.13"
},
"suggest": {
Expand Down
8 changes: 8 additions & 0 deletions src/Runner/FixableTaskResult.php
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,14 @@ public function getContext(): ContextInterface
return $this->result->getContext();
}

public function withContext(ContextInterface $context): static
{
$new = clone $this;
$new->result = $this->result->withContext($context);

return $new;
}

public function withAppendedMessage(string $message): TaskResultInterface
{
$new = clone $this;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,9 @@ static function () use ($task, $runnerContext, $next, $currentEnv): TaskResultIn

return async(function () use ($task, $runnerContext, $execution): TaskResultInterface {
try {
return $execution->getFuture()->await();
$result = $execution->getFuture()->await();

return $this->swapSerializedContext($result, $runnerContext);
} catch (\Throwable $exception) {
return TaskResult::createFailed(
$task,
Expand All @@ -75,4 +77,18 @@ private function wrapException(\Throwable $error): ParallelException
? ParallelException::fromVerboseThrowable($error)
: ParallelException::fromThrowable($error);
}

/**
* The results coming back from a parallel worker contains a serialized context.
* This context can be rather big, which can cause memory issues.
*
* This method will swap the serialized context with the original
* context so that the serialized one gets garbage collected.
*/
private function swapSerializedContext(
TaskResultInterface $result,
TaskRunnerContext $runnerContext
): TaskResultInterface {
return $result->withContext($runnerContext->getTaskContext());
}
}
8 changes: 8 additions & 0 deletions src/Runner/TaskResult.php
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,14 @@ public function getContext(): ContextInterface
return $this->context;
}

public function withContext(ContextInterface $context): static
{
$new = clone $this;
$new->context = $context;

return $new;
}

public function withAppendedMessage(string $message): TaskResultInterface
{
$new = clone $this;
Expand Down
2 changes: 2 additions & 0 deletions src/Runner/TaskResultInterface.php
Original file line number Diff line number Diff line change
Expand Up @@ -33,5 +33,7 @@ public function getMessage(): string;

public function getContext(): ContextInterface;

public function withContext(ContextInterface $context): static;

public function withAppendedMessage(string $message): self;
}

0 comments on commit 12dd30d

Please sign in to comment.