зеркало из https://github.com/mozilla/gecko-dev.git
538 строки
20 KiB
Python
538 строки
20 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
|
|
|
|
from voluptuous import Required
|
|
from taskgraph.util.taskcluster import get_artifact_url
|
|
from taskgraph.transforms.job import run_job_using
|
|
from taskgraph.util.schema import Schema
|
|
from taskgraph.transforms.tests import (
|
|
test_description_schema,
|
|
normpath
|
|
)
|
|
from taskgraph.transforms.job.common import (
|
|
docker_worker_add_tooltool,
|
|
support_vcs_checkout,
|
|
)
|
|
import os
|
|
|
|
BUILDER_NAME_PREFIX = {
|
|
'linux64-pgo': 'Ubuntu VM 12.04 x64',
|
|
'linux64': 'Ubuntu VM 12.04 x64',
|
|
'linux64-nightly': 'Ubuntu VM 12.04 x64',
|
|
'linux64-asan': 'Ubuntu ASAN VM 12.04 x64',
|
|
'linux64-ccov': 'Ubuntu Code Coverage VM 12.04 x64',
|
|
'linux64-jsdcov': 'Ubuntu Code Coverage VM 12.04 x64',
|
|
'linux64-qr': 'Ubuntu VM 12.04 x64',
|
|
'linux64-stylo-disabled': 'Ubuntu VM 12.04 x64',
|
|
'linux64-stylo-sequential': 'Ubuntu VM 12.04 x64',
|
|
'linux64-devedition': 'Ubuntu VM 12.04 x64',
|
|
'linux64-devedition-nightly': 'Ubuntu VM 12.04 x64',
|
|
'macosx64': 'Rev7 MacOSX Yosemite 10.10.5',
|
|
'macosx64-devedition': 'Rev7 MacOSX Yosemite 10.10.5 DevEdition',
|
|
'android-4.3-arm7-api-16': 'Android 4.3 armv7 api-16+',
|
|
'android-4.2-x86': 'Android 4.2 x86 Emulator',
|
|
'android-4.3-arm7-api-16-gradle': 'Android 4.3 armv7 api-16+',
|
|
'windows10-64': 'Windows 10 64-bit',
|
|
'windows10-64-nightly': 'Windows 10 64-bit',
|
|
'windows10-64-devedition': 'Windows 10 64-bit DevEdition',
|
|
'windows10-64-pgo': 'Windows 10 64-bit',
|
|
'windows10-64-asan': 'Windows 10 64-bit',
|
|
'windows10-64-stylo-disabled': 'Windows 10 64-bit',
|
|
'windows7-32': 'Windows 7 32-bit',
|
|
('windows7-32', 'virtual-with-gpu'): 'Windows 7 VM-GFX 32-bit',
|
|
'windows7-32-nightly': 'Windows 7 32-bit',
|
|
'windows7-32-devedition': 'Windows 7 32-bit DevEdition',
|
|
'windows7-32-pgo': 'Windows 7 32-bit',
|
|
'windows7-32-stylo-disabled': 'Windows 7 32-bit',
|
|
'windows8-64': 'Windows 8 64-bit',
|
|
'windows8-64-nightly': 'Windows 8 64-bit',
|
|
'windows8-64-devedition': 'Windows 8 64-bit DevEdition',
|
|
'windows8-64-pgo': 'Windows 8 64-bit',
|
|
}
|
|
|
|
VARIANTS = [
|
|
'nightly',
|
|
'devedition',
|
|
'pgo',
|
|
'asan',
|
|
'stylo',
|
|
'stylo-disabled',
|
|
'stylo-sequential',
|
|
'qr',
|
|
'ccov',
|
|
'jsdcov',
|
|
]
|
|
|
|
|
|
def get_variant(test_platform):
|
|
for v in VARIANTS:
|
|
if '-{}/'.format(v) in test_platform:
|
|
return v
|
|
return ''
|
|
|
|
|
|
test_description_schema = {str(k): v for k, v in test_description_schema.schema.iteritems()}
|
|
|
|
mozharness_test_run_schema = Schema({
|
|
Required('using'): 'mozharness-test',
|
|
Required('test'): test_description_schema,
|
|
})
|
|
|
|
|
|
def test_packages_url(taskdesc):
|
|
"""Account for different platforms that name their test packages differently"""
|
|
return get_artifact_url('<build>', 'public/build/target.test_packages.json')
|
|
|
|
|
|
@run_job_using('docker-engine', 'mozharness-test', schema=mozharness_test_run_schema)
|
|
@run_job_using('docker-worker', 'mozharness-test', schema=mozharness_test_run_schema)
|
|
def mozharness_test_on_docker(config, job, taskdesc):
|
|
test = taskdesc['run']['test']
|
|
mozharness = test['mozharness']
|
|
worker = taskdesc['worker']
|
|
|
|
# apply some defaults
|
|
worker['docker-image'] = test['docker-image']
|
|
worker['allow-ptrace'] = True # required for all tests, for crashreporter
|
|
worker['loopback-video'] = test['loopback-video']
|
|
worker['loopback-audio'] = test['loopback-audio']
|
|
worker['max-run-time'] = test['max-run-time']
|
|
worker['retry-exit-status'] = test['retry-exit-status']
|
|
|
|
artifacts = [
|
|
# (artifact name prefix, in-image path)
|
|
("public/logs/", "/builds/worker/workspace/build/upload/logs/"),
|
|
("public/test", "/builds/worker/artifacts/"),
|
|
("public/test_info/", "/builds/worker/workspace/build/blobber_upload_dir/"),
|
|
]
|
|
|
|
installer_url = get_artifact_url('<build>', mozharness['build-artifact-name'])
|
|
mozharness_url = get_artifact_url('<build>',
|
|
'public/build/mozharness.zip')
|
|
|
|
worker['artifacts'] = [{
|
|
'name': prefix,
|
|
'path': os.path.join('/builds/worker/workspace', path),
|
|
'type': 'directory',
|
|
} for (prefix, path) in artifacts]
|
|
|
|
worker['caches'] = [{
|
|
'type': 'persistent',
|
|
'name': 'level-{}-{}-test-workspace'.format(
|
|
config.params['level'], config.params['project']),
|
|
'mount-point': "/builds/worker/workspace",
|
|
}]
|
|
|
|
env = worker['env'] = {
|
|
'MOZHARNESS_CONFIG': ' '.join(mozharness['config']),
|
|
'MOZHARNESS_SCRIPT': mozharness['script'],
|
|
'MOZILLA_BUILD_URL': {'task-reference': installer_url},
|
|
'NEED_PULSEAUDIO': 'true',
|
|
'NEED_WINDOW_MANAGER': 'true',
|
|
'ENABLE_E10S': str(bool(test.get('e10s'))).lower(),
|
|
'MOZ_AUTOMATION': '1',
|
|
}
|
|
|
|
if mozharness.get('mochitest-flavor'):
|
|
env['MOCHITEST_FLAVOR'] = mozharness['mochitest-flavor']
|
|
|
|
if mozharness['set-moz-node-path']:
|
|
env['MOZ_NODE_PATH'] = '/usr/local/bin/node'
|
|
|
|
if 'actions' in mozharness:
|
|
env['MOZHARNESS_ACTIONS'] = ' '.join(mozharness['actions'])
|
|
|
|
if 'try' in config.params['project']:
|
|
env['TRY_COMMIT_MSG'] = config.params['message']
|
|
|
|
# handle some of the mozharness-specific options
|
|
|
|
if mozharness['tooltool-downloads']:
|
|
docker_worker_add_tooltool(config, job, taskdesc, internal=True)
|
|
|
|
if test['reboot']:
|
|
raise Exception('reboot: {} not supported on generic-worker'.format(test['reboot']))
|
|
|
|
# assemble the command line
|
|
command = [
|
|
'/builds/worker/bin/run-task',
|
|
]
|
|
|
|
# Support vcs checkouts regardless of whether the task runs from
|
|
# source or not in case it is needed on an interactive loaner.
|
|
support_vcs_checkout(config, job, taskdesc)
|
|
|
|
# If we have a source checkout, run mozharness from it instead of
|
|
# downloading a zip file with the same content.
|
|
if test['checkout']:
|
|
command.extend(['--vcs-checkout', '/builds/worker/checkouts/gecko'])
|
|
env['MOZHARNESS_PATH'] = '/builds/worker/checkouts/gecko/testing/mozharness'
|
|
else:
|
|
env['MOZHARNESS_URL'] = {'task-reference': mozharness_url}
|
|
|
|
command.extend([
|
|
'--',
|
|
'/builds/worker/bin/test-linux.sh',
|
|
])
|
|
|
|
if mozharness.get('no-read-buildbot-config'):
|
|
command.append("--no-read-buildbot-config")
|
|
command.extend([
|
|
{"task-reference": "--installer-url=" + installer_url},
|
|
{"task-reference": "--test-packages-url=" + test_packages_url(taskdesc)},
|
|
])
|
|
command.extend(mozharness.get('extra-options', []))
|
|
|
|
# TODO: remove the need for run['chunked']
|
|
if mozharness.get('chunked') or test['chunks'] > 1:
|
|
# Implement mozharness['chunking-args'], modifying command in place
|
|
if mozharness['chunking-args'] == 'this-chunk':
|
|
command.append('--total-chunk={}'.format(test['chunks']))
|
|
command.append('--this-chunk={}'.format(test['this-chunk']))
|
|
elif mozharness['chunking-args'] == 'test-suite-suffix':
|
|
suffix = mozharness['chunk-suffix'].replace('<CHUNK>', str(test['this-chunk']))
|
|
for i, c in enumerate(command):
|
|
if isinstance(c, basestring) and c.startswith('--test-suite'):
|
|
command[i] += suffix
|
|
|
|
if 'download-symbols' in mozharness:
|
|
download_symbols = mozharness['download-symbols']
|
|
download_symbols = {True: 'true', False: 'false'}.get(download_symbols, download_symbols)
|
|
command.append('--download-symbols=' + download_symbols)
|
|
|
|
worker['command'] = command
|
|
|
|
|
|
@run_job_using('generic-worker', 'mozharness-test', schema=mozharness_test_run_schema)
|
|
def mozharness_test_on_generic_worker(config, job, taskdesc):
|
|
test = taskdesc['run']['test']
|
|
mozharness = test['mozharness']
|
|
worker = taskdesc['worker']
|
|
|
|
is_macosx = worker['os'] == 'macosx'
|
|
is_windows = worker['os'] == 'windows'
|
|
assert is_macosx or is_windows
|
|
|
|
artifacts = [
|
|
{
|
|
'name': 'public/logs',
|
|
'path': 'logs',
|
|
'type': 'directory'
|
|
},
|
|
]
|
|
|
|
# jittest doesn't have blob_upload_dir
|
|
if test['test-name'] != 'jittest':
|
|
artifacts.append({
|
|
'name': 'public/test_info',
|
|
'path': 'build/blobber_upload_dir',
|
|
'type': 'directory'
|
|
})
|
|
|
|
upstream_task = '<build-signing>' if mozharness['requires-signed-builds'] else '<build>'
|
|
installer_url = get_artifact_url(upstream_task, mozharness['build-artifact-name'])
|
|
|
|
taskdesc['scopes'].extend(
|
|
['generic-worker:os-group:{}'.format(group) for group in test['os-groups']])
|
|
|
|
worker['os-groups'] = test['os-groups']
|
|
|
|
if test['reboot']:
|
|
raise Exception('reboot: {} not supported on generic-worker'.format(test['reboot']))
|
|
|
|
worker['max-run-time'] = test['max-run-time']
|
|
worker['artifacts'] = artifacts
|
|
|
|
env = worker.setdefault('env', {})
|
|
env['MOZ_AUTOMATION'] = '1'
|
|
env['GECKO_HEAD_REPOSITORY'] = config.params['head_repository']
|
|
env['GECKO_HEAD_REV'] = config.params['head_rev']
|
|
|
|
# this list will get cleaned up / reduced / removed in bug 1354088
|
|
if is_macosx:
|
|
env.update({
|
|
'IDLEIZER_DISABLE_SHUTDOWN': 'true',
|
|
'LANG': 'en_US.UTF-8',
|
|
'LC_ALL': 'en_US.UTF-8',
|
|
'MOZ_HIDE_RESULTS_TABLE': '1',
|
|
'MOZ_NODE_PATH': '/usr/local/bin/node',
|
|
'MOZ_NO_REMOTE': '1',
|
|
'NO_EM_RESTART': '1',
|
|
'NO_FAIL_ON_TEST_ERRORS': '1',
|
|
'PATH': '/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin',
|
|
'SHELL': '/bin/bash',
|
|
'XPCOM_DEBUG_BREAK': 'warn',
|
|
'XPC_FLAGS': '0x0',
|
|
'XPC_SERVICE_NAME': '0',
|
|
})
|
|
|
|
if is_macosx:
|
|
mh_command = [
|
|
'python2.7',
|
|
'-u',
|
|
'mozharness/scripts/' + mozharness['script']
|
|
]
|
|
elif is_windows:
|
|
mh_command = [
|
|
'c:\\mozilla-build\\python\\python.exe',
|
|
'-u',
|
|
'mozharness\\scripts\\' + normpath(mozharness['script'])
|
|
]
|
|
|
|
for mh_config in mozharness['config']:
|
|
cfg_path = 'mozharness/configs/' + mh_config
|
|
if is_windows:
|
|
cfg_path = normpath(cfg_path)
|
|
mh_command.extend(['--cfg', cfg_path])
|
|
mh_command.extend(mozharness.get('extra-options', []))
|
|
if mozharness.get('no-read-buildbot-config'):
|
|
mh_command.append('--no-read-buildbot-config')
|
|
mh_command.extend(['--installer-url', installer_url])
|
|
mh_command.extend(['--test-packages-url', test_packages_url(taskdesc)])
|
|
if mozharness.get('download-symbols'):
|
|
if isinstance(mozharness['download-symbols'], basestring):
|
|
mh_command.extend(['--download-symbols', mozharness['download-symbols']])
|
|
else:
|
|
mh_command.extend(['--download-symbols', 'true'])
|
|
if mozharness.get('include-blob-upload-branch'):
|
|
mh_command.append('--blob-upload-branch=' + config.params['project'])
|
|
mh_command.extend(mozharness.get('extra-options', []))
|
|
|
|
# TODO: remove the need for run['chunked']
|
|
if mozharness.get('chunked') or test['chunks'] > 1:
|
|
# Implement mozharness['chunking-args'], modifying command in place
|
|
if mozharness['chunking-args'] == 'this-chunk':
|
|
mh_command.append('--total-chunk={}'.format(test['chunks']))
|
|
mh_command.append('--this-chunk={}'.format(test['this-chunk']))
|
|
elif mozharness['chunking-args'] == 'test-suite-suffix':
|
|
suffix = mozharness['chunk-suffix'].replace('<CHUNK>', str(test['this-chunk']))
|
|
for i, c in enumerate(mh_command):
|
|
if isinstance(c, basestring) and c.startswith('--test-suite'):
|
|
mh_command[i] += suffix
|
|
|
|
if 'try' in config.params['project']:
|
|
env['TRY_COMMIT_MSG'] = config.params['message']
|
|
|
|
worker['mounts'] = [{
|
|
'directory': '.',
|
|
'content': {
|
|
'artifact': 'public/build/mozharness.zip',
|
|
'task-id': {
|
|
'task-reference': '<build>'
|
|
}
|
|
},
|
|
'format': 'zip'
|
|
}]
|
|
|
|
if is_windows:
|
|
worker['command'] = [
|
|
{'task-reference': ' '.join(mh_command)}
|
|
]
|
|
else: # is_macosx
|
|
mh_command_task_ref = []
|
|
for token in mh_command:
|
|
mh_command_task_ref.append({'task-reference': token})
|
|
worker['command'] = [
|
|
mh_command_task_ref
|
|
]
|
|
|
|
|
|
@run_job_using('native-engine', 'mozharness-test', schema=mozharness_test_run_schema)
|
|
def mozharness_test_on_native_engine(config, job, taskdesc):
|
|
test = taskdesc['run']['test']
|
|
mozharness = test['mozharness']
|
|
worker = taskdesc['worker']
|
|
is_talos = test['suite'] == 'talos'
|
|
is_macosx = worker['os'] == 'macosx'
|
|
|
|
installer_url = get_artifact_url('<build>', mozharness['build-artifact-name'])
|
|
mozharness_url = get_artifact_url('<build>',
|
|
'public/build/mozharness.zip')
|
|
|
|
worker['artifacts'] = [{
|
|
'name': prefix.rstrip('/'),
|
|
'path': path.rstrip('/'),
|
|
'type': 'directory',
|
|
} for (prefix, path) in [
|
|
# (artifact name prefix, in-image path relative to homedir)
|
|
("public/logs/", "workspace/build/upload/logs/"),
|
|
("public/test", "artifacts/"),
|
|
("public/test_info/", "workspace/build/blobber_upload_dir/"),
|
|
]]
|
|
|
|
if test['reboot']:
|
|
worker['reboot'] = test['reboot']
|
|
|
|
worker['env'] = env = {
|
|
'GECKO_HEAD_REPOSITORY': config.params['head_repository'],
|
|
'GECKO_HEAD_REV': config.params['head_rev'],
|
|
'MOZHARNESS_CONFIG': ' '.join(mozharness['config']),
|
|
'MOZHARNESS_SCRIPT': mozharness['script'],
|
|
'MOZHARNESS_URL': {'task-reference': mozharness_url},
|
|
'MOZILLA_BUILD_URL': {'task-reference': installer_url},
|
|
"MOZ_NO_REMOTE": '1',
|
|
"NO_EM_RESTART": '1',
|
|
"XPCOM_DEBUG_BREAK": 'warn',
|
|
"NO_FAIL_ON_TEST_ERRORS": '1',
|
|
"MOZ_HIDE_RESULTS_TABLE": '1',
|
|
"MOZ_NODE_PATH": "/usr/local/bin/node",
|
|
'MOZ_AUTOMATION': '1',
|
|
}
|
|
# talos tests don't need Xvfb
|
|
if is_talos:
|
|
env['NEED_XVFB'] = 'false'
|
|
|
|
script = 'test-macosx.sh' if is_macosx else 'test-linux.sh'
|
|
worker['context'] = '{}/raw-file/{}/taskcluster/scripts/tester/{}'.format(
|
|
config.params['head_repository'], config.params['head_rev'], script
|
|
)
|
|
|
|
command = worker['command'] = ["./{}".format(script)]
|
|
if mozharness.get('no-read-buildbot-config'):
|
|
command.append("--no-read-buildbot-config")
|
|
command.extend([
|
|
{"task-reference": "--installer-url=" + installer_url},
|
|
{"task-reference": "--test-packages-url=" + test_packages_url(taskdesc)},
|
|
])
|
|
if mozharness.get('include-blob-upload-branch'):
|
|
command.append('--blob-upload-branch=' + config.params['project'])
|
|
command.extend(mozharness.get('extra-options', []))
|
|
|
|
# TODO: remove the need for run['chunked']
|
|
if mozharness.get('chunked') or test['chunks'] > 1:
|
|
# Implement mozharness['chunking-args'], modifying command in place
|
|
if mozharness['chunking-args'] == 'this-chunk':
|
|
command.append('--total-chunk={}'.format(test['chunks']))
|
|
command.append('--this-chunk={}'.format(test['this-chunk']))
|
|
elif mozharness['chunking-args'] == 'test-suite-suffix':
|
|
suffix = mozharness['chunk-suffix'].replace('<CHUNK>', str(test['this-chunk']))
|
|
for i, c in enumerate(command):
|
|
if isinstance(c, basestring) and c.startswith('--test-suite'):
|
|
command[i] += suffix
|
|
|
|
if 'download-symbols' in mozharness:
|
|
download_symbols = mozharness['download-symbols']
|
|
download_symbols = {True: 'true', False: 'false'}.get(download_symbols, download_symbols)
|
|
command.append('--download-symbols=' + download_symbols)
|
|
|
|
|
|
@run_job_using('buildbot-bridge', 'mozharness-test', schema=mozharness_test_run_schema)
|
|
def mozharness_test_buildbot_bridge(config, job, taskdesc):
|
|
test = taskdesc['run']['test']
|
|
mozharness = test['mozharness']
|
|
worker = taskdesc['worker']
|
|
|
|
branch = config.params['project']
|
|
build_platform, build_type = test['build-platform'].split('/')
|
|
test_platform = test['test-platform'].split('/')[0]
|
|
test_name = test.get('try-name', test['test-name'])
|
|
mozharness = test['mozharness']
|
|
|
|
# mochitest e10s follows the pattern mochitest-e10s-<suffix>
|
|
# in buildbot, except for these special cases
|
|
buildbot_specials = [
|
|
'mochitest-webgl',
|
|
'mochitest-clipboard',
|
|
'mochitest-media',
|
|
'mochitest-gpu',
|
|
'mochitest-e10s',
|
|
]
|
|
test_name = test.get('try-name', test['test-name'])
|
|
if test['e10s'] and 'e10s' not in test_name:
|
|
test_name += '-e10s'
|
|
|
|
if test_name.startswith('mochitest') \
|
|
and test_name.endswith('e10s') \
|
|
and not any(map(
|
|
lambda name: test_name.startswith(name),
|
|
buildbot_specials
|
|
)):
|
|
split_mochitest = test_name.split('-')
|
|
test_name = '-'.join([
|
|
split_mochitest[0],
|
|
split_mochitest[-1],
|
|
'-'.join(split_mochitest[1:-1])
|
|
])
|
|
|
|
# in buildbot, mochitest-webgl is called mochitest-gl
|
|
test_name = test_name.replace('webgl', 'gl')
|
|
|
|
if mozharness.get('chunked', False):
|
|
this_chunk = test.get('this-chunk')
|
|
test_name = '{}-{}'.format(test_name, this_chunk)
|
|
elif test.get('this-chunk', 1) != 1:
|
|
raise Exception("Unexpected chunking when 'chunked' attribute is 'false'"
|
|
" for {}".format(test_name))
|
|
|
|
if test.get('suite', '') == 'talos':
|
|
variant = get_variant(test['test-platform'])
|
|
|
|
# On beta and release, we run nightly builds on-push; the talos
|
|
# builders need to run against non-nightly buildernames
|
|
if variant == 'nightly':
|
|
variant = ''
|
|
|
|
# this variant name has branch after the variant type in BBB bug 1338871
|
|
if variant in ('qr', 'stylo', 'stylo-sequential', 'devedition', 'stylo-disabled'):
|
|
name = '{prefix} {variant} {branch} talos {test_name}'
|
|
elif variant:
|
|
name = '{prefix} {branch} {variant} talos {test_name}'
|
|
else:
|
|
name = '{prefix} {branch} talos {test_name}'
|
|
|
|
buildername = name.format(
|
|
prefix=BUILDER_NAME_PREFIX[test_platform],
|
|
variant=variant,
|
|
branch=branch,
|
|
test_name=test_name
|
|
)
|
|
|
|
if buildername.startswith('Ubuntu'):
|
|
buildername = buildername.replace('VM', 'HW')
|
|
else:
|
|
variant = get_variant(test['test-platform'])
|
|
# If we are a pgo type, munge the build_type for the
|
|
# Unittest builder name generation
|
|
if 'pgo' in variant:
|
|
build_type = variant
|
|
prefix = BUILDER_NAME_PREFIX.get(
|
|
(test_platform, test.get('virtualization')),
|
|
BUILDER_NAME_PREFIX[test_platform])
|
|
if variant in ['stylo-disabled']:
|
|
buildername = '{prefix} {variant} {branch} {build_type} test {test_name}'.format(
|
|
prefix=prefix,
|
|
variant=variant,
|
|
branch=branch,
|
|
build_type=build_type,
|
|
test_name=test_name
|
|
)
|
|
else:
|
|
buildername = '{prefix} {branch} {build_type} test {test_name}'.format(
|
|
prefix=prefix,
|
|
branch=branch,
|
|
build_type=build_type,
|
|
test_name=test_name
|
|
)
|
|
|
|
worker.update({
|
|
'buildername': buildername,
|
|
'sourcestamp': {
|
|
'branch': branch,
|
|
'repository': config.params['head_repository'],
|
|
'revision': config.params['head_rev'],
|
|
},
|
|
'properties': {
|
|
'product': test.get('product', 'firefox'),
|
|
'who': config.params['owner'],
|
|
'installer_path': mozharness['build-artifact-name'],
|
|
}
|
|
})
|
|
|
|
if mozharness['requires-signed-builds']:
|
|
upstream_task = '<build-signing>'
|
|
installer_url = get_artifact_url(upstream_task, mozharness['build-artifact-name'])
|
|
worker['properties']['signed_installer_url'] = {'task-reference': installer_url}
|