mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-10-19 00:05:36 +00:00
e58a5b2a19
--HG-- extra : rebase_source : c08110089030074cf4a831ce8e94678da03704a6 extra : source : e7f30540870849cf6ba49957d37190fbd89b5f0d
77 lines
2.6 KiB
Python
77 lines
2.6 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/.
|
|
|
|
from __future__ import absolute_import, print_function, unicode_literals
|
|
|
|
import re
|
|
|
|
from taskgraph.util.time import json_time_from_now
|
|
from taskgraph.util.taskcluster import get_artifact_url
|
|
|
|
TASK_REFERENCE_PATTERN = re.compile('<([^>]+)>')
|
|
ARTIFACT_REFERENCE_PATTERN = re.compile('<([^/]+)/([^>]+)>')
|
|
|
|
|
|
def _recurse(val, param_fns):
|
|
def recurse(val):
|
|
if isinstance(val, list):
|
|
return [recurse(v) for v in val]
|
|
elif isinstance(val, dict):
|
|
if len(val) == 1:
|
|
for param_key, param_fn in param_fns.items():
|
|
if val.keys() == [param_key]:
|
|
return param_fn(val[param_key])
|
|
return {k: recurse(v) for k, v in val.iteritems()}
|
|
else:
|
|
return val
|
|
return recurse(val)
|
|
|
|
|
|
def resolve_timestamps(now, task_def):
|
|
"""Resolve all instances of `{'relative-datestamp': '..'}` in the given task definition"""
|
|
return _recurse(task_def, {
|
|
'relative-datestamp': lambda v: json_time_from_now(v, now),
|
|
})
|
|
|
|
|
|
def resolve_task_references(label, task_def, dependencies):
|
|
"""Resolve all instances of
|
|
{'task-reference': '..<..>..'}
|
|
and
|
|
{'artifact-reference`: '..<dependency/artifact/path>..'}
|
|
in the given task definition, using the given dependencies"""
|
|
|
|
def task_reference(val):
|
|
def repl(match):
|
|
key = match.group(1)
|
|
try:
|
|
return dependencies[key]
|
|
except KeyError:
|
|
# handle escaping '<'
|
|
if key == '<':
|
|
return key
|
|
raise KeyError("task '{}' has no dependency named '{}'".format(label, key))
|
|
|
|
return TASK_REFERENCE_PATTERN.sub(repl, val)
|
|
|
|
def artifact_reference(val):
|
|
def repl(match):
|
|
dependency, artifact_name = match.group(1, 2)
|
|
|
|
try:
|
|
task_id = dependencies[dependency]
|
|
except KeyError:
|
|
raise KeyError("task '{}' has no dependency named '{}'".format(label, dependency))
|
|
|
|
assert artifact_name.startswith('public/'), \
|
|
"artifact-reference only supports public artifacts, not `{}`".format(artifact_name)
|
|
return get_artifact_url(task_id, artifact_name)
|
|
|
|
return ARTIFACT_REFERENCE_PATTERN.sub(repl, val)
|
|
|
|
return _recurse(task_def, {
|
|
'task-reference': task_reference,
|
|
'artifact-reference': artifact_reference,
|
|
})
|