Skip to content

Commit

Permalink
ci: Use concurrency groups to prevent duplicate builds
Browse files Browse the repository at this point in the history
  • Loading branch information
def- committed Jan 2, 2024
1 parent c69d4c3 commit 5a863a9
Showing 1 changed file with 28 additions and 11 deletions.
39 changes: 28 additions & 11 deletions ci/mkpipeline.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@

import argparse
import copy
import hashlib
import os
import subprocess
import sys
Expand Down Expand Up @@ -423,25 +424,41 @@ def visit(step: PipelineStep) -> None:


def trim_builds(pipeline: Any, coverage: bool) -> None:
"""Trim unnecessary x86-64/aarch64 builds if all artifacts already exist."""
"""Trim unnecessary x86-64/aarch64 builds if all artifacts already exist. Also mark remaining builds with a unique concurrency group for the code state so that the same build doesn't happen multiple times."""

def builds_published(arch: Arch) -> bool:
def deps_publish(arch: Arch) -> mzbuild.DependencySet:
repo = mzbuild.Repository(Path("."), arch=arch, coverage=coverage)
deps_publish = repo.resolve_dependencies(
image for image in repo if image.publish
)
return deps_publish.check()
return repo.resolve_dependencies(image for image in repo if image.publish)

def hash(deps: mzbuild.DependencySet) -> str:
h = hashlib.sha1()
for dep in deps:
h.update(dep.spec().encode())
return h.hexdigest()

def visit(step: dict[str, Any]) -> None:
if step.get("id") == "build-x86_64":
if builds_published(Arch.X86_64):
deps = deps_publish(Arch.X86_64)
if deps.check():
step["skip"] = True
else:
# Make sure that builds in different pipelines for the same
# hash at least don't run concurrently, leading to wasted
# resources.
step["concurrency"] = 1
step["concurrency_group"] = f"build-x86_64/{hash(deps)}"
if step.get("id") == "build-aarch64":
branch = os.environ["BUILDKITE_BRANCH"]
if (
branch == "main" or branch.startswith("v") and "." in branch
) and builds_published(Arch.AARCH64):
step["skip"] = True
deps = deps_publish(Arch.AARCH64)
if branch == "main" or branch.startswith("v") and "." in branch:
if deps.check():
step["skip"] = True
else:
# Make sure that builds in different pipelines for the same
# hash at least don't run concurrently, leading to wasted
# resources.
step["concurrency"] = 1
step["concurrency_group"] = f"build-aarch64/{hash(deps)}"

for step in pipeline["steps"]:
visit(step)
Expand Down

0 comments on commit 5a863a9

Please sign in to comment.