gecko-dev/taskcluster/taskgraph/transforms/name_sanity.py
Tom Prince e8e8ccdaa3 Bug 1535947: [taskgraph] Remove a redundant condition in name_sanity transform; r=aki
In bug 1501776, the `single_dep` and `multi_dep` schemas were aligned, which made both
branch in name_sanity identical. Simplify the code to reflect that.

Differential Revision: https://phabricator.services.mozilla.com/D24109

--HG--
extra : moz-landing-system : lando
2019-03-20 02:23:24 +00:00

45 lines
1.7 KiB
Python

# This Source Code Form is subject to the terms of the Mozilla Public
# 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/.
"""
Generate labels for tasks without names, consistently.
Uses attributes from `primary-dependency`.
"""
from __future__ import absolute_import, print_function, unicode_literals
from taskgraph.transforms.base import TransformSequence
transforms = TransformSequence()
@transforms.add
def make_label(config, jobs):
""" Generate a sane label for a new task constructed from a dependency
Using attributes from the dependent job and the current task kind"""
for job in jobs:
dep_job = job['primary-dependency']
attr = dep_job.attributes.get
if attr('locale', job.get('locale')):
template = "{kind}-{locale}-{build_platform}/{build_type}"
elif attr('l10n_chunk'):
template = "{kind}-{build_platform}-{l10n_chunk}/{build_type}"
elif config.kind.startswith("release-eme-free") or \
config.kind.startswith("release-partner-repack"):
repack_id = job.get("extra", {}).get("repack_id", None)
template = "{kind}-{build_platform}"
if repack_id:
template += "-{}".format(repack_id.replace('/', '-'))
else:
template = "{kind}-{build_platform}/{build_type}"
job['label'] = template.format(
kind=config.kind,
build_platform=attr('build_platform'),
build_type=attr('build_type'),
locale=attr('locale', job.get('locale', '')), # Locale can be absent
l10n_chunk=attr('l10n_chunk', '') # Can be empty
)
yield job