feat: add incoming ref data to non-flakes entrypoint
We can now implement a Nix library for Buildbot CI. :) We dump it into a file, it's better to pass large stuff and easier to escape things. Signed-off-by: Raito Bezarius <raito@lix.systems>
This commit is contained in:
parent
b3a0b5a69e
commit
456c9551ff
1 changed files with 33 additions and 5 deletions
|
@ -8,6 +8,7 @@ from collections.abc import Generator
|
||||||
from dataclasses import dataclass, field
|
from dataclasses import dataclass, field
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
from typing import TYPE_CHECKING, Any
|
from typing import TYPE_CHECKING, Any
|
||||||
|
import tempfile
|
||||||
|
|
||||||
import buildbot
|
import buildbot
|
||||||
from buildbot.configurators import ConfiguratorBase
|
from buildbot.configurators import ConfiguratorBase
|
||||||
|
@ -367,13 +368,18 @@ class NixEvalCommand(buildstep.ShellMixin, steps.BuildStep):
|
||||||
every attribute.
|
every attribute.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, supported_systems: list[str], **kwargs: Any) -> None:
|
def __init__(self, supported_systems: list[str], incoming_ref_filename: str, **kwargs: Any) -> None:
|
||||||
kwargs = self.setupShellMixin(kwargs)
|
kwargs = self.setupShellMixin(kwargs)
|
||||||
super().__init__(**kwargs)
|
super().__init__(**kwargs)
|
||||||
|
self.incoming_ref_filename = incoming_ref_filename
|
||||||
self.observer = logobserver.BufferLogObserver()
|
self.observer = logobserver.BufferLogObserver()
|
||||||
self.addLogObserver("stdio", self.observer)
|
self.addLogObserver("stdio", self.observer)
|
||||||
self.supported_systems = supported_systems
|
self.supported_systems = supported_systems
|
||||||
|
|
||||||
|
def __del__(self):
|
||||||
|
# Cleanup the incoming ref parameter file.
|
||||||
|
os.unlink(self.incoming_ref_filename)
|
||||||
|
|
||||||
@defer.inlineCallbacks
|
@defer.inlineCallbacks
|
||||||
def run(self) -> Generator[Any, object, Any]:
|
def run(self) -> Generator[Any, object, Any]:
|
||||||
# run nix-eval-jobs --flake .#$FLAKE_TARGET_ATTRIBUTE_FOR_JOBS to generate the dict of stages
|
# run nix-eval-jobs --flake .#$FLAKE_TARGET_ATTRIBUTE_FOR_JOBS to generate the dict of stages
|
||||||
|
@ -453,17 +459,29 @@ class NixEvalCommand(buildstep.ShellMixin, steps.BuildStep):
|
||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
||||||
def make_job_evaluator(name: str, settings: EvaluatorSettings, flake: bool) -> NixEvalCommand:
|
def make_job_evaluator(name: str, settings: EvaluatorSettings, flake: bool, incoming_ref_data: dict[str, Any]) -> NixEvalCommand:
|
||||||
actual_command = []
|
actual_command = []
|
||||||
|
|
||||||
|
try:
|
||||||
|
eval_parameter_json_repr = json.dumps(incoming_ref_data)
|
||||||
|
except ValueError as e:
|
||||||
|
msg = f"Failed to serialize incoming ref data for {name}"
|
||||||
|
raise BuildbotNixError(msg) from e
|
||||||
|
|
||||||
|
eval_parameter_json_fp = tempfile.NamedTemporaryFile(delete_on_close=False)
|
||||||
|
eval_parameter_json_fp.write(eval_parameter_json_repr.encode('utf8'))
|
||||||
|
eval_parameter_json_fp.close()
|
||||||
|
|
||||||
if flake:
|
if flake:
|
||||||
actual_command += ["--flake", f".#{FLAKE_TARGET_ATTRIBUTE_FOR_JOBS}"]
|
actual_command += ["--flake", f".#{FLAKE_TARGET_ATTRIBUTE_FOR_JOBS}"]
|
||||||
else:
|
else:
|
||||||
actual_command += ["--expr", "import ./.ci/buildbot.nix"]
|
actual_command += ["--expr",
|
||||||
|
f"import ./.ci/buildbot.nix {{ incoming_ref_data = builtins.fromJSON (builtins.readFile {eval_parameter_json_fp.name}); }}"]
|
||||||
|
|
||||||
return NixEvalCommand(
|
return NixEvalCommand(
|
||||||
env={},
|
env={},
|
||||||
name=name,
|
name=name,
|
||||||
|
incoming_ref_filename=eval_parameter_json_fp.name,
|
||||||
supported_systems=settings.supported_systems,
|
supported_systems=settings.supported_systems,
|
||||||
command=[
|
command=[
|
||||||
"nix-eval-jobs",
|
"nix-eval-jobs",
|
||||||
|
@ -504,6 +522,14 @@ class NixConfigure(buildstep.CommandMixin, steps.BuildStep):
|
||||||
except Exception:
|
except Exception:
|
||||||
configure_log: Log = yield self.addLog("stdio")
|
configure_log: Log = yield self.addLog("stdio")
|
||||||
|
|
||||||
|
# This information can be passed at job evaluation time
|
||||||
|
# to skip some jobs, e.g. expensive jobs, etc.
|
||||||
|
incoming_ref_data = {
|
||||||
|
# TODO: please just denormalize it properly.
|
||||||
|
'event': {
|
||||||
|
key: value for (key, (value, _)) in self.getProperties().asDict().items() if key.startswith('event.')
|
||||||
|
}
|
||||||
|
}
|
||||||
# Takes precedence.
|
# Takes precedence.
|
||||||
configure_log.addStdout("checking if there's a .ci/buildbot.nix...\n")
|
configure_log.addStdout("checking if there's a .ci/buildbot.nix...\n")
|
||||||
ci_buildbot_defn_exists = yield self.pathExists('build/.ci/buildbot.nix')
|
ci_buildbot_defn_exists = yield self.pathExists('build/.ci/buildbot.nix')
|
||||||
|
@ -514,7 +540,8 @@ class NixConfigure(buildstep.CommandMixin, steps.BuildStep):
|
||||||
make_job_evaluator(
|
make_job_evaluator(
|
||||||
"evaluate `.ci/buildbot.nix` jobs",
|
"evaluate `.ci/buildbot.nix` jobs",
|
||||||
self.evaluator_settings,
|
self.evaluator_settings,
|
||||||
False
|
False,
|
||||||
|
incoming_ref_data
|
||||||
)
|
)
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
|
@ -527,7 +554,8 @@ class NixConfigure(buildstep.CommandMixin, steps.BuildStep):
|
||||||
make_job_evaluator(
|
make_job_evaluator(
|
||||||
"evaluate `flake.nix` jobs",
|
"evaluate `flake.nix` jobs",
|
||||||
self.evaluator_settings,
|
self.evaluator_settings,
|
||||||
True
|
True,
|
||||||
|
incoming_ref_data
|
||||||
)
|
)
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
|
|
Loading…
Reference in a new issue