gecko-dev/taskcluster/taskgraph/transforms/build.py
Mike Hommey 4f407cb9b4 Bug 1634204 - Upgrade Linux build docker images to Debian 8. r=froydnj
This gets rid for the need of a number of local packages (mostly related
to Gtk+3). One exception is that we now need a 32-bits version of the
xz-utils package, some -dev package depends on it, and that dependency
can't be fulfilled in the 32-bits image because we already have the
64-bits backport installed, which conflicts with it (we need both
32-bits and 64-bits package to be at the same version when installed).

The system binutils fails to link clang-7 for some reason, so we now use
our toolchain binutils instead, like we already do for newer versions of
clang.

The debian-packages docker image now needs an explicit installation of
git, because it's not pulled in via the recommends of some other
package.

For some reason, snapshot.debian.org doesn't contain the jessie-backports
archive at the same location as others, and only has a few snapshots of
the archive.

Differential Revision: https://phabricator.services.mozilla.com/D73784
2020-05-06 14:16:03 +00:00

178 lines
6.4 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/.
"""
Apply some defaults and minor modifications to the jobs defined in the build
kind.
"""
from __future__ import absolute_import, print_function, unicode_literals
from taskgraph.transforms.base import TransformSequence
from taskgraph.util.attributes import RELEASE_PROJECTS
from taskgraph.util.schema import resolve_keyed_by
from taskgraph.util.workertypes import worker_type_implementation
from mozbuild.artifact_builds import JOB_CHOICES as ARTIFACT_JOBS
import logging
logger = logging.getLogger(__name__)
transforms = TransformSequence()
@transforms.add
def set_defaults(config, jobs):
"""Set defaults, including those that differ per worker implementation"""
for job in jobs:
job['treeherder'].setdefault('kind', 'build')
job['treeherder'].setdefault('tier', 1)
_, worker_os = worker_type_implementation(config.graph_config, job['worker-type'])
worker = job.setdefault('worker', {})
worker.setdefault('env', {})
if worker_os == "linux":
worker.setdefault('docker-image', {'in-tree': 'debian8-amd64-build'})
worker['chain-of-trust'] = True
elif worker_os == "windows":
worker['chain-of-trust'] = True
yield job
@transforms.add
def stub_installer(config, jobs):
for job in jobs:
resolve_keyed_by(
job, 'stub-installer', item_name=job['name'], project=config.params['project'],
**{
'release-type': config.params['release_type'],
}
)
job.setdefault('attributes', {})
if job.get('stub-installer'):
job['attributes']['stub-installer'] = job['stub-installer']
job['worker']['env'].update({"USE_STUB_INSTALLER": "1"})
if 'stub-installer' in job:
del job['stub-installer']
yield job
@transforms.add
def resolve_shipping_product(config, jobs):
for job in jobs:
resolve_keyed_by(
job, 'shipping-product', item_name=job['name'],
**{
'release-type': config.params['release_type'],
}
)
yield job
@transforms.add
def update_channel(config, jobs):
keys = [
'run.update-channel',
'run.mar-channel-id',
'run.accepted-mar-channel-ids',
]
for job in jobs:
job['worker'].setdefault('env', {})
for key in keys:
resolve_keyed_by(
job, key, item_name=job['name'],
**{
'project': config.params['project'],
'release-type': config.params['release_type'],
}
)
update_channel = job['run'].pop('update-channel', None)
if update_channel:
job['run'].setdefault('extra-config', {})['update_channel'] = update_channel
job['attributes']['update-channel'] = update_channel
mar_channel_id = job['run'].pop('mar-channel-id', None)
if mar_channel_id:
job['attributes']['mar-channel-id'] = mar_channel_id
job['worker']['env']['MAR_CHANNEL_ID'] = mar_channel_id
accepted_mar_channel_ids = job['run'].pop('accepted-mar-channel-ids', None)
if accepted_mar_channel_ids:
job['attributes']['accepted-mar-channel-ids'] = accepted_mar_channel_ids
job['worker']['env']['ACCEPTED_MAR_CHANNEL_IDS'] = accepted_mar_channel_ids
yield job
@transforms.add
def mozconfig(config, jobs):
for job in jobs:
resolve_keyed_by(
job, 'run.mozconfig-variant', item_name=job['name'],
**{
'release-type': config.params['release_type'],
}
)
mozconfig_variant = job['run'].pop('mozconfig-variant', None)
if mozconfig_variant:
job['run'].setdefault('extra-config', {})['mozconfig_variant'] = mozconfig_variant
yield job
@transforms.add
def use_profile_data(config, jobs):
for job in jobs:
use_pgo = job.pop('use-pgo', False)
disable_pgo = config.params['try_task_config'].get('disable-pgo', False)
if not use_pgo or disable_pgo:
yield job
continue
# If use_pgo is True, the task uses the generate-profile task of the
# same name. Otherwise a task can specify a specific generate-profile
# task to use in the use_pgo field.
if use_pgo is True:
name = job['name']
else:
name = use_pgo
dependencies = 'generate-profile-{}'.format(name)
job.setdefault('dependencies', {})['generate-profile'] = dependencies
job.setdefault('fetches', {})['generate-profile'] = ['profdata.tar.xz']
job['worker']['env'].update({"TASKCLUSTER_PGO_PROFILE_USE": "1"})
_, worker_os = worker_type_implementation(config.graph_config, job['worker-type'])
if worker_os == "linux":
# LTO linkage needs more open files than the default from run-task.
job['worker']['env'].update({"MOZ_LIMIT_NOFILE": "8192"})
yield job
@transforms.add
def enable_full_crashsymbols(config, jobs):
"""Enable full crashsymbols on jobs with
'enable-full-crashsymbols' set to True and on release branches, or
on try"""
branches = RELEASE_PROJECTS | {'try', }
for job in jobs:
enable_full_crashsymbols = job['attributes'].get('enable-full-crashsymbols')
if enable_full_crashsymbols and config.params['project'] in branches:
logger.debug("Enabling full symbol generation for %s", job['name'])
else:
logger.debug("Disabling full symbol generation for %s", job['name'])
job['worker']['env']['MOZ_DISABLE_FULL_SYMBOLS'] = '1'
job['attributes'].pop('enable-full-crashsymbols', None)
yield job
@transforms.add
def use_artifact(config, jobs):
if config.params.is_try():
use_artifact = config.params['try_task_config'].get('use-artifact-builds', False)
else:
use_artifact = False
for job in jobs:
if (config.kind == 'build' and use_artifact and
not job.get('attributes', {}).get('nightly', False) and
job.get('index', {}).get('job-name') in ARTIFACT_JOBS):
job['treeherder']['symbol'] += 'a'
job['worker']['env']['USE_ARTIFACT'] = '1'
yield job