Skip to content

Commit

Permalink
Bug 1752111 - Make l10n bumper run on autoland instead of mozilla-cen…
Browse files Browse the repository at this point in the history
…tral r=aki

Differential Revision: https://phabricator.services.mozilla.com/D154305
  • Loading branch information
gabrielBusta committed Aug 24, 2022
1 parent a4a8140 commit 7082d43
Show file tree
Hide file tree
Showing 14 changed files with 98 additions and 65 deletions.
6 changes: 3 additions & 3 deletions .cron.yml
Original file line number Diff line number Diff line change
Expand Up @@ -29,8 +29,6 @@ jobs:
- mozilla-central
when:
by-project:
# `l10n-bumper` job should have enough time to finish before this
# job runs
mozilla-central: [{hour: 10, minute: 0}, {hour: 22, minute: 0}]
# No default

Expand Down Expand Up @@ -277,12 +275,14 @@ jobs:
treeherder-symbol: l10n-bump
target-tasks-method: l10n_bump
run-on-projects:
- autoland
- mozilla-central
- mozilla-beta
when:
by-project:
# 3h15m before launch of `nightly-desktop`
mozilla-central: [{hour: 6, minute: 45}, {hour: 18, minute: 45}]
autoland: [{hour: 6, minute: 45}, {hour: 18, minute: 45}]
mozilla-central: []
# 3h15m before launch of `daily-releases`
mozilla-beta: [{hour: 18, minute: 45}]
# No default
Expand Down
5 changes: 4 additions & 1 deletion taskcluster/ci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -555,7 +555,10 @@ workers:
worker-type:
by-release-level:
production: '{trust-domain}-3-tree'
staging: '{trust-domain}-1-tree'
staging:
by-project:
autoland: '{trust-domain}-3-tree'
default: '{trust-domain}-1-tree'
tree-dev:
provisioner: scriptworker-k8s
implementation: treescript
Expand Down
86 changes: 49 additions & 37 deletions taskcluster/ci/l10n-bump/kind.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@ transforms:
- gecko_taskgraph.transforms.release_version_bump:transforms
- gecko_taskgraph.transforms.task:transforms


job-defaults:
worker-type: tree
worker:
Expand All @@ -19,15 +18,20 @@ job-defaults:
by-project:
mozilla-beta: false
default: true
ignore-closed-tree: false
ignore-closed-tree:
by-project:
autoland: true
default: false
push:
by-project:
mozilla-(central|beta): true
autoland: true
default: false
source-repo:
by-release-type:
beta: https://hg.mozilla.org/releases/mozilla-beta
default: https://hg.mozilla.org/mozilla-central
nightly: https://hg.mozilla.org/mozilla-central
default: https://hg.mozilla.org/integration/autoland
l10n-bump-info:
by-release-type:
# XXX whenever the `beta` config changes, make sure to make
Expand All @@ -52,23 +56,27 @@ job-defaults:
- win64-devedition
- win64-aarch64
- win64-aarch64-devedition
platform-configs: [{
"platforms": [
"linux",
"linux-devedition",
"linux64",
"linux64-devedition",
"macosx64",
"macosx64-devedition",
"win32",
"win32-devedition",
"win64",
"win64-devedition",
"win64-aarch64",
"win64-aarch64-devedition",
],
"path": "browser/locales/shipped-locales",
}]
platform-configs:
[
{
"platforms":
[
"linux",
"linux-devedition",
"linux64",
"linux64-devedition",
"macosx64",
"macosx64-devedition",
"win32",
"win32-devedition",
"win64",
"win64-devedition",
"win64-aarch64",
"win64-aarch64-devedition",
],
"path": "browser/locales/shipped-locales",
},
]
default:
name: Firefox l10n changesets
path: browser/locales/l10n-changesets.json
Expand All @@ -89,23 +97,27 @@ job-defaults:
- win64-devedition
- win64-aarch64
- win64-aarch64-devedition
platform-configs: [{
"platforms": [
"linux",
"linux-devedition",
"linux64",
"linux64-devedition",
"macosx64",
"macosx64-devedition",
"win32",
"win32-devedition",
"win64",
"win64-devedition",
"win64-aarch64",
"win64-aarch64-devedition",
],
"path": "browser/locales/all-locales",
}]
platform-configs:
[
{
"platforms":
[
"linux",
"linux-devedition",
"linux64",
"linux64-devedition",
"macosx64",
"macosx64-devedition",
"win32",
"win32-devedition",
"win64",
"win64-devedition",
"win64-aarch64",
"win64-aarch64-devedition",
],
"path": "browser/locales/all-locales",
},
]

jobs:
l10n-bumper:
Expand Down
2 changes: 1 addition & 1 deletion taskcluster/gecko_taskgraph/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -107,7 +107,7 @@
Required("implementation"): str,
Required("os"): str,
Required("worker-type"): optionally_keyed_by(
"level", "release-level", str
"level", "release-level", "project", str
),
}
},
Expand Down
5 changes: 3 additions & 2 deletions taskcluster/gecko_taskgraph/morph.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,6 @@
from taskgraph.task import Task
from taskgraph.taskgraph import TaskGraph

from .util.attributes import release_level
from .util.workertypes import get_worker_type

here = os.path.abspath(os.path.dirname(__file__))
Expand Down Expand Up @@ -71,7 +70,9 @@ def derive_misc_task(
image_taskid = label_to_taskid["docker-image-" + image]

provisioner_id, worker_type = get_worker_type(
graph_config, "misc", parameters["level"], release_level(parameters["project"])
graph_config,
parameters,
"misc",
)

deps = copy.copy(dependencies)
Expand Down
1 change: 1 addition & 0 deletions taskcluster/gecko_taskgraph/test/test_transforms_job.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ def config():
"head_repository": "http://hg.example.com",
"head_rev": "abcdef",
"level": 1,
"project": "example",
}
)
return TransformConfig(
Expand Down
4 changes: 2 additions & 2 deletions taskcluster/gecko_taskgraph/transforms/build.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ def set_defaults(config, jobs):
job["treeherder"].setdefault("kind", "build")
job["treeherder"].setdefault("tier", 1)
_, worker_os = worker_type_implementation(
config.graph_config, job["worker-type"]
config.graph_config, config.params, job["worker-type"]
)
worker = job.setdefault("worker", {})
worker.setdefault("env", {})
Expand Down Expand Up @@ -172,7 +172,7 @@ def use_profile_data(config, jobs):
job["worker"]["env"].update({"TASKCLUSTER_PGO_PROFILE_USE": "1"})

_, worker_os = worker_type_implementation(
config.graph_config, job["worker-type"]
config.graph_config, config.params, job["worker-type"]
)
if worker_os == "linux":
# LTO linkage needs more open files than the default from run-task.
Expand Down
6 changes: 4 additions & 2 deletions taskcluster/gecko_taskgraph/transforms/job/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -134,7 +134,9 @@ def rewrite_when_to_optimization(config, jobs):
@transforms.add
def set_implementation(config, jobs):
for job in jobs:
impl, os = worker_type_implementation(config.graph_config, job["worker-type"])
impl, os = worker_type_implementation(
config.graph_config, config.params, job["worker-type"]
)
if os:
job.setdefault("tags", {})["os"] = os
if impl:
Expand Down Expand Up @@ -164,7 +166,7 @@ def add_resource_monitor(config, jobs):
for job in jobs:
if job.get("attributes", {}).get("resource-monitor"):
worker_implementation, worker_os = worker_type_implementation(
config.graph_config, job["worker-type"]
config.graph_config, config.params, job["worker-type"]
)
# Normalise worker os so that linux-bitbar and similar use linux tools.
worker_os = worker_os.split("-")[0]
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,12 @@ def handle_keyed_by(config, tasks):
]
for task in tasks:
fields = default_fields[:]
for additional_field in ("l10n-bump-info", "source-repo", "dontbuild"):
for additional_field in (
"l10n-bump-info",
"source-repo",
"dontbuild",
"ignore-closed-tree",
):
if additional_field in task["worker"]:
fields.append(f"worker.{additional_field}")
for field in fields:
Expand Down
2 changes: 1 addition & 1 deletion taskcluster/gecko_taskgraph/transforms/repackage.py
Original file line number Diff line number Diff line change
Expand Up @@ -475,7 +475,7 @@ def make_job_description(config, jobs):

worker["artifacts"] = _generate_task_output_files(
dep_job,
worker_type_implementation(config.graph_config, worker_type),
worker_type_implementation(config.graph_config, config.params, worker_type),
repackage_config=repackage_config,
locale=locale,
)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -177,7 +177,7 @@ def make_job_description(config, jobs):

worker["artifacts"] = _generate_task_output_files(
dep_job,
worker_type_implementation(config.graph_config, worker_type),
worker_type_implementation(config.graph_config, config.params, worker_type),
repackage_config,
partner=repack_id,
)
Expand Down
7 changes: 4 additions & 3 deletions taskcluster/gecko_taskgraph/transforms/task.py
Original file line number Diff line number Diff line change
Expand Up @@ -1446,7 +1446,9 @@ def set_implementation(config, tasks):
yield task
continue

impl, os = worker_type_implementation(config.graph_config, task["worker-type"])
impl, os = worker_type_implementation(
config.graph_config, config.params, task["worker-type"]
)

tags = task.setdefault("tags", {})
tags["worker-implementation"] = impl
Expand Down Expand Up @@ -1857,9 +1859,8 @@ def build_task(config, tasks):
else:
provisioner_id, worker_type = get_worker_type(
config.graph_config,
config.params,
task["worker-type"],
level=level,
release_level=release_level(config.params["project"]),
)
task["worker-type"] = "/".join([provisioner_id, worker_type])
project = config.params["project"]
Expand Down
25 changes: 18 additions & 7 deletions taskcluster/gecko_taskgraph/util/workertypes.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.


from gecko_taskgraph.util.attributes import release_level as _release_level
from mozbuild.util import memoize
from taskgraph.util.attributes import keymatch
from taskgraph.util.keyed_by import evaluate_keyed_by
Expand All @@ -20,7 +20,7 @@


@memoize
def _get(graph_config, alias, level, release_level):
def _get(graph_config, alias, level, release_level, project):
"""Get the configuration for this worker_type alias: {provisioner,
worker-type, implementation, os}"""
level = str(level)
Expand Down Expand Up @@ -61,10 +61,13 @@ def _get(graph_config, alias, level, release_level):
"alias": alias,
}
)
attrs = {"level": level, "release-level": release_level}
if project:
attrs["project"] = project
worker_config["worker-type"] = evaluate_keyed_by(
worker_config["worker-type"],
f"worker-type alias {alias} field worker-type",
{"level": level, "release-level": release_level},
attrs,
).format(
**{
"trust-domain": graph_config["trust-domain"],
Expand All @@ -76,18 +79,26 @@ def _get(graph_config, alias, level, release_level):
return worker_config


def worker_type_implementation(graph_config, worker_type):
def worker_type_implementation(graph_config, parameters, worker_type):
"""Get the worker implementation and OS for the given workerType, where the
OS represents the host system, not the target OS, in the case of
cross-compiles."""
worker_config = _get(graph_config, worker_type, "1", "staging")
worker_config = _get(
graph_config, worker_type, "1", "staging", parameters["project"]
)
return worker_config["implementation"], worker_config.get("os")


def get_worker_type(graph_config, worker_type, level, release_level):
def get_worker_type(graph_config, parameters, worker_type):
"""
Get the worker type provisioner and worker-type, optionally evaluating
aliases from the graph config.
"""
worker_config = _get(graph_config, worker_type, level, release_level)
worker_config = _get(
graph_config,
worker_type,
parameters["level"],
_release_level(parameters.get("project")),
parameters.get("project"),
)
return worker_config["provisioner"], worker_config["worker-type"]
5 changes: 1 addition & 4 deletions tools/tryselect/task_config.py
Original file line number Diff line number Diff line change
Expand Up @@ -505,10 +505,7 @@ def try_config(self, worker_overrides, worker_suffixes, **kwargs):
)
sys.exit(1)
provisioner, worker_type = get_worker_type(
graph_config,
alias,
level="1",
release_level="staging",
graph_config, worker_type=alias, parameters={"level": "1"}
)
overrides[alias] = "{provisioner}/{worker_type}{suffix}".format(
provisioner=provisioner, worker_type=worker_type, suffix=suffix
Expand Down

0 comments on commit 7082d43

Please sign in to comment.