2017-07-21 21:08:06 +03:00
|
|
|
# This file is rendered via JSON-e by
|
2019-02-02 02:27:48 +03:00
|
|
|
# - mozilla-taskcluster - See
|
|
|
|
# https://docs.taskcluster.net/reference/integrations/mozilla-taskcluster/docs/taskcluster-yml
|
|
|
|
# {
|
|
|
|
# tasks_for: 'hg-push',
|
|
|
|
# push: {owner, comment, pushlog_id, pushdate},
|
|
|
|
# repository: {url, project, level},
|
|
|
|
# now,
|
|
|
|
# as_slugid: // function
|
2019-02-02 02:27:47 +03:00
|
|
|
# ownTaskId: // taskId of the task that will be created
|
2019-02-02 02:27:48 +03:00
|
|
|
# }
|
|
|
|
#
|
|
|
|
# - cron tasks - See taskcluster/taskgraph/cron/decision.py
|
|
|
|
# {
|
|
|
|
# tasks_for: 'cron',
|
2019-02-02 02:27:48 +03:00
|
|
|
# push: {revision, pushlog_id, pushdate, owner}
|
2019-02-02 02:27:48 +03:00
|
|
|
# repository: {url, project, level},
|
|
|
|
# cron: {task_id, job_name, job_symbol, quoted_args},
|
|
|
|
# now,
|
2019-02-02 02:27:47 +03:00
|
|
|
# ownTaskId: // taskId of the task that will be created
|
2019-02-02 02:27:48 +03:00
|
|
|
# }
|
|
|
|
#
|
|
|
|
# - action tasks - See:
|
|
|
|
# * taskcluster/taskgraph/actions/registry.py,
|
|
|
|
# * https://docs.taskcluster.net/docs/manual/using/actions/spec
|
|
|
|
# * ci-admin:ciadmin/generate/in_tree_actions.py
|
|
|
|
#
|
|
|
|
# The registry generates the hookPayload that appears in actions.json, and
|
|
|
|
# contains data from the decision task as well as JSON-e code to combine that
|
|
|
|
# with data supplied as part of the action spec. When the hook is fired, the
|
|
|
|
# hookPayload is rendered with JSON-e to produce a payload for the hook task
|
|
|
|
# template.
|
|
|
|
#
|
|
|
|
# The ci-admin code wraps the content of this file (.taskcluster.yml) with a
|
|
|
|
# JSON-e $let statement that produces the context described below, and
|
|
|
|
# installs that as the hook task template.
|
|
|
|
#
|
|
|
|
# {
|
|
|
|
# tasks_for: 'action',
|
|
|
|
# push: {owner, pushlog_id, revision},
|
|
|
|
# repository: {url, project, level},
|
|
|
|
# input,
|
|
|
|
# parameters,
|
|
|
|
# taskId, // targetted taskId
|
|
|
|
# taskGroupId, // targetted taskGroupId
|
|
|
|
# action: {name, title, description, taskGroupId, symbol, repo_scope, cb_name}
|
|
|
|
# ownTaskId: // taskId of the task that will be created
|
|
|
|
# }
|
|
|
|
|
2017-07-21 19:05:52 +03:00
|
|
|
version: 1
|
|
|
|
tasks:
|
2018-07-03 21:07:42 +03:00
|
|
|
# NOTE: support for actions in ci-admin requires that the `tasks` property be an array *before* JSON-e rendering
|
|
|
|
# takes place.
|
|
|
|
- $if: 'tasks_for in ["hg-push", "action", "cron"]'
|
|
|
|
then:
|
|
|
|
$let:
|
|
|
|
# sometimes the push user is just `ffxbld` or the like, but we want an email-like field..
|
|
|
|
ownerEmail: {$if: '"@" in push.owner', then: '${push.owner}', else: '${push.owner}@noreply.mozilla.org'}
|
|
|
|
# ensure there's no trailing `/` on the repo URL
|
|
|
|
repoUrl: {$if: 'repository.url[-1] == "/"', then: {$eval: 'repository.url[:-1]'}, else: {$eval: 'repository.url'}}
|
|
|
|
in:
|
2019-02-02 02:27:47 +03:00
|
|
|
taskId: {$if: 'tasks_for != "action"', then: '${ownTaskId}'}
|
2018-07-03 21:07:42 +03:00
|
|
|
taskGroupId:
|
|
|
|
$if: 'tasks_for == "action"'
|
|
|
|
then:
|
|
|
|
'${action.taskGroupId}'
|
|
|
|
else:
|
2019-02-02 02:27:47 +03:00
|
|
|
'${ownTaskId}' # same as taskId; this is how automation identifies a decision tsak
|
2018-07-03 21:07:42 +03:00
|
|
|
schedulerId: 'gecko-level-${repository.level}'
|
2016-05-18 00:26:31 +03:00
|
|
|
|
2018-07-03 21:07:42 +03:00
|
|
|
created: {$fromNow: ''}
|
|
|
|
deadline: {$fromNow: '1 day'}
|
|
|
|
expires: {$fromNow: '1 year 1 second'} # 1 second so artifacts expire first, despite rounding errors
|
|
|
|
metadata:
|
|
|
|
$merge:
|
|
|
|
- owner: "${ownerEmail}"
|
|
|
|
source: "${repoUrl}/raw-file/${push.revision}/.taskcluster.yml"
|
|
|
|
- $if: 'tasks_for == "hg-push"'
|
2017-10-10 04:39:00 +03:00
|
|
|
then:
|
2018-07-03 21:07:42 +03:00
|
|
|
name: "Gecko Decision Task"
|
|
|
|
description: 'The task that creates all of the other tasks in the task graph'
|
2017-10-10 04:39:00 +03:00
|
|
|
else:
|
2018-07-03 21:07:42 +03:00
|
|
|
$if: 'tasks_for == "action"'
|
|
|
|
then:
|
|
|
|
name: "Action: ${action.title}"
|
2019-01-29 23:46:13 +03:00
|
|
|
description: |
|
|
|
|
${action.description}
|
|
|
|
|
|
|
|
Action triggered by clientID `${clientId}`
|
2018-07-03 21:07:42 +03:00
|
|
|
else:
|
|
|
|
name: "Decision Task for cron job ${cron.job_name}"
|
|
|
|
description: 'Created by a [cron task](https://tools.taskcluster.net/tasks/${cron.task_id})'
|
2016-05-18 00:26:31 +03:00
|
|
|
|
2018-07-03 21:07:42 +03:00
|
|
|
provisionerId: "aws-provisioner-v1"
|
|
|
|
workerType: "gecko-${repository.level}-decision"
|
2016-05-18 00:26:31 +03:00
|
|
|
|
2018-07-03 21:07:42 +03:00
|
|
|
tags:
|
|
|
|
$if: 'tasks_for == "hg-push"'
|
2018-07-04 05:46:59 +03:00
|
|
|
then:
|
|
|
|
createdForUser: "${ownerEmail}"
|
|
|
|
kind: decision-task
|
2018-07-03 21:07:42 +03:00
|
|
|
else:
|
|
|
|
$if: 'tasks_for == "action"'
|
2018-04-20 00:32:02 +03:00
|
|
|
then:
|
2018-07-03 21:07:42 +03:00
|
|
|
createdForUser: '${ownerEmail}'
|
|
|
|
kind: 'action-callback'
|
2018-07-04 05:46:59 +03:00
|
|
|
else:
|
|
|
|
$if: 'tasks_for == "cron"'
|
|
|
|
then:
|
|
|
|
kind: cron-task
|
2018-07-03 21:07:42 +03:00
|
|
|
|
|
|
|
routes:
|
|
|
|
$flatten:
|
2018-11-28 01:33:09 +03:00
|
|
|
- "tc-treeherder.v2.${repository.project}.${push.revision}.${push.pushlog_id}"
|
2018-07-03 21:07:42 +03:00
|
|
|
- $if: 'tasks_for == "hg-push"'
|
2018-06-11 18:20:37 +03:00
|
|
|
then:
|
2018-07-03 21:07:42 +03:00
|
|
|
- "index.gecko.v2.${repository.project}.latest.taskgraph.decision"
|
|
|
|
- "index.gecko.v2.${repository.project}.revision.${push.revision}.taskgraph.decision"
|
2018-11-28 01:33:09 +03:00
|
|
|
- "index.gecko.v2.${repository.project}.pushlog-id.${push.pushlog_id}.decision"
|
2018-07-03 21:07:42 +03:00
|
|
|
- "notify.email.${ownerEmail}.on-failed"
|
|
|
|
- "notify.email.${ownerEmail}.on-exception"
|
2018-09-24 16:46:55 +03:00
|
|
|
# Send a notification email if the push comes from try
|
|
|
|
- $if: 'repository.project == "try"'
|
|
|
|
then:
|
|
|
|
"notify.email.${ownerEmail}.on-completed"
|
2018-07-03 21:07:42 +03:00
|
|
|
# These are the old index routes for the decision task.
|
|
|
|
# They are still here so external tools that referenced them continue to work.
|
|
|
|
- "index.gecko.v2.${repository.project}.latest.firefox.decision"
|
|
|
|
- "index.gecko.v2.${repository.project}.revision.${push.revision}.firefox.decision"
|
|
|
|
else:
|
|
|
|
$if: 'tasks_for == "action"'
|
|
|
|
then:
|
|
|
|
- "notify.email.taskcluster-notifications+action-task@mozilla.com.on-failed"
|
|
|
|
- "notify.email.taskcluster-notifications+action-task@mozilla.com.on-exception"
|
2018-11-28 01:33:09 +03:00
|
|
|
- "index.gecko.v2.${repository.project}.pushlog-id.${push.pushlog_id}.actions.${ownTaskId}"
|
2018-07-03 21:07:42 +03:00
|
|
|
else: # cron
|
|
|
|
- "index.gecko.v2.${repository.project}.latest.taskgraph.decision-${cron.job_name}"
|
2018-11-28 01:33:09 +03:00
|
|
|
- "index.gecko.v2.${repository.project}.revision.${push.revision}.taskgraph.decision-${cron.job_name}"
|
|
|
|
- "index.gecko.v2.${repository.project}.pushlog-id.${push.pushlog_id}.decision-${cron.job_name}"
|
2018-10-11 16:29:11 +03:00
|
|
|
# list each cron task on this revision, so actions can find them
|
2019-02-02 02:27:47 +03:00
|
|
|
- 'index.gecko.v2.${repository.project}.revision.${push.revision}.cron.${ownTaskId}'
|
2018-12-20 19:39:43 +03:00
|
|
|
# BUG 1500166 Notify ciduty by email if a nightly hook fails
|
|
|
|
- "notify.email.ciduty+failedcron@mozilla.com.on-failed"
|
|
|
|
- "notify.email.ciduty+exceptioncron@mozilla.com.on-exception"
|
|
|
|
- "notify.email.sheriffs+failedcron@mozilla.org.on-failed"
|
|
|
|
- "notify.email.sheriffs+exceptioncron@mozilla.org.on-exception"
|
2018-09-14 19:47:09 +03:00
|
|
|
# These are the old index routes for the decision task.
|
2018-07-03 21:07:42 +03:00
|
|
|
- "index.gecko.v2.${repository.project}.latest.firefox.decision-${cron.job_name}"
|
2016-05-18 00:26:31 +03:00
|
|
|
|
2018-07-03 21:07:42 +03:00
|
|
|
scopes:
|
|
|
|
$if: 'tasks_for == "hg-push"'
|
2017-10-10 04:39:00 +03:00
|
|
|
then:
|
2018-07-03 21:07:42 +03:00
|
|
|
- 'assume:repo:${repoUrl[8:]}:branch:default'
|
|
|
|
- 'queue:route:notify.email.${ownerEmail}.*'
|
|
|
|
- 'in-tree:hook-action:project-gecko/in-tree-action-${repository.level}-*'
|
2017-10-10 04:39:00 +03:00
|
|
|
else:
|
2018-07-03 21:07:42 +03:00
|
|
|
$if: 'tasks_for == "action"'
|
|
|
|
then:
|
|
|
|
# when all actions are hooks, we can calculate this directly rather than using a variable
|
|
|
|
- '${action.repo_scope}'
|
|
|
|
else:
|
|
|
|
- 'assume:repo:${repoUrl[8:]}:cron:${cron.job_name}'
|
2016-05-18 00:26:31 +03:00
|
|
|
|
2018-07-03 21:07:42 +03:00
|
|
|
dependencies: []
|
|
|
|
requires: all-completed
|
2016-05-18 00:26:31 +03:00
|
|
|
|
2018-09-19 23:41:01 +03:00
|
|
|
priority:
|
|
|
|
# Most times, there is plenty of worker capacity so everything runs
|
|
|
|
# quickly, but sometimes a storm of action tasks lands. Then we
|
|
|
|
# want, from highest to lowest:
|
|
|
|
# - cron tasks (time-sensitive) (low)
|
2018-11-27 01:13:41 +03:00
|
|
|
# - action tasks (avoid interfering with the other two) (very-low)
|
|
|
|
# - decision tasks (minimize user-visible delay) (lowest)
|
2018-09-19 23:41:01 +03:00
|
|
|
# SCM levels all use different workerTypes, so there is no need for priority
|
|
|
|
# between levels; "low" is the highest priority available at all levels, and
|
|
|
|
# nothing runs at any higher priority on these workerTypes.
|
|
|
|
$if: "tasks_for == 'cron'"
|
|
|
|
then: low
|
|
|
|
else:
|
2018-11-27 01:13:41 +03:00
|
|
|
$if: "tasks_for == 'action'"
|
2018-09-19 23:41:01 +03:00
|
|
|
then: very-low
|
2018-11-27 01:13:41 +03:00
|
|
|
else: lowest # tasks_for == 'hg-push'
|
2018-07-03 21:07:42 +03:00
|
|
|
retries: 5
|
2016-05-18 00:26:31 +03:00
|
|
|
|
2018-07-03 21:07:42 +03:00
|
|
|
payload:
|
|
|
|
env:
|
|
|
|
# checkout-gecko uses these to check out the source; the inputs
|
|
|
|
# to `mach taskgraph decision` are all on the command line.
|
|
|
|
$merge:
|
|
|
|
- GECKO_BASE_REPOSITORY: 'https://hg.mozilla.org/mozilla-unified'
|
|
|
|
GECKO_HEAD_REPOSITORY: '${repoUrl}'
|
|
|
|
GECKO_HEAD_REF: '${push.revision}'
|
|
|
|
GECKO_HEAD_REV: '${push.revision}'
|
|
|
|
HG_STORE_PATH: /builds/worker/checkouts/hg-store
|
|
|
|
TASKCLUSTER_CACHES: /builds/worker/checkouts
|
2018-09-25 23:18:19 +03:00
|
|
|
# someday, these will be provided by the worker - Bug 1492664
|
|
|
|
TASKCLUSTER_ROOT_URL: https://taskcluster.net
|
|
|
|
TASKCLUSTER_PROXY_URL: http://taskcluster
|
2018-07-03 21:07:42 +03:00
|
|
|
- $if: 'tasks_for == "action"'
|
|
|
|
then:
|
2018-09-07 20:30:12 +03:00
|
|
|
ACTION_TASK_GROUP_ID: '${action.taskGroupId}' # taskGroupId of the target task
|
2018-07-03 21:07:42 +03:00
|
|
|
ACTION_TASK_ID: {$json: {$eval: 'taskId'}} # taskId of the target task (JSON-encoded)
|
|
|
|
ACTION_INPUT: {$json: {$eval: 'input'}}
|
|
|
|
ACTION_CALLBACK: '${action.cb_name}'
|
|
|
|
ACTION_PARAMETERS: {$json: {$eval: 'parameters'}}
|
2016-05-18 00:26:31 +03:00
|
|
|
|
2018-07-03 21:07:42 +03:00
|
|
|
cache:
|
|
|
|
level-${repository.level}-checkouts-sparse-v2: /builds/worker/checkouts
|
2016-05-18 00:26:31 +03:00
|
|
|
|
2018-07-03 21:07:42 +03:00
|
|
|
features:
|
|
|
|
taskclusterProxy: true
|
|
|
|
chainOfTrust: true
|
2016-05-18 00:26:31 +03:00
|
|
|
|
2018-07-03 21:07:42 +03:00
|
|
|
# Note: This task is built server side without the context or tooling that
|
|
|
|
# exist in tree so we must hard code the hash
|
|
|
|
image: 'taskcluster/decision:2.1.0@sha256:6db3b697d7a3c7aba440d72f04199331b872111cefff57206b8b8b1d53230360'
|
2016-05-18 00:26:31 +03:00
|
|
|
|
2018-07-03 21:07:42 +03:00
|
|
|
maxRunTime: 1800
|
2016-05-18 00:26:31 +03:00
|
|
|
|
2018-07-03 21:07:42 +03:00
|
|
|
command:
|
|
|
|
- /builds/worker/bin/run-task
|
|
|
|
- '--vcs-checkout=/builds/worker/checkouts/gecko'
|
|
|
|
- '--sparse-profile=build/sparse-profiles/taskgraph'
|
|
|
|
- '--'
|
|
|
|
- bash
|
|
|
|
- -cx
|
|
|
|
- $let:
|
|
|
|
extraArgs: {$if: 'tasks_for == "cron"', then: '${cron.quoted_args}', else: ''}
|
|
|
|
in:
|
|
|
|
$if: 'tasks_for == "action"'
|
|
|
|
then: >
|
|
|
|
cd /builds/worker/checkouts/gecko &&
|
|
|
|
ln -s /builds/worker/artifacts artifacts &&
|
|
|
|
./mach --log-no-times taskgraph action-callback
|
|
|
|
else: >
|
|
|
|
cd /builds/worker/checkouts/gecko &&
|
|
|
|
ln -s /builds/worker/artifacts artifacts &&
|
|
|
|
./mach --log-no-times taskgraph decision
|
2018-11-28 01:33:09 +03:00
|
|
|
--pushlog-id='${push.pushlog_id}'
|
|
|
|
--pushdate='${push.pushdate}'
|
2018-07-03 21:07:42 +03:00
|
|
|
--project='${repository.project}'
|
|
|
|
--owner='${ownerEmail}'
|
|
|
|
--level='${repository.level}'
|
|
|
|
--base-repository="$GECKO_BASE_REPOSITORY"
|
|
|
|
--head-repository="$GECKO_HEAD_REPOSITORY"
|
|
|
|
--head-ref="$GECKO_HEAD_REF"
|
|
|
|
--head-rev="$GECKO_HEAD_REV"
|
|
|
|
${extraArgs}
|
2016-05-18 00:26:31 +03:00
|
|
|
|
2018-07-03 21:07:42 +03:00
|
|
|
artifacts:
|
|
|
|
'public':
|
|
|
|
type: 'directory'
|
|
|
|
path: '/builds/worker/artifacts'
|
|
|
|
expires: {$fromNow: '1 year'}
|
2016-05-18 00:26:31 +03:00
|
|
|
|
2018-07-03 21:07:42 +03:00
|
|
|
extra:
|
|
|
|
$merge:
|
|
|
|
- treeherder:
|
|
|
|
$merge:
|
|
|
|
- machine:
|
|
|
|
platform: gecko-decision
|
|
|
|
- $if: 'tasks_for == "hg-push"'
|
2017-10-10 04:39:00 +03:00
|
|
|
then:
|
2018-07-03 21:07:42 +03:00
|
|
|
symbol: D
|
2017-10-10 04:39:00 +03:00
|
|
|
else:
|
2018-07-03 21:07:42 +03:00
|
|
|
$if: 'tasks_for == "action"'
|
|
|
|
then:
|
|
|
|
groupName: 'action-callback'
|
|
|
|
groupSymbol: AC
|
|
|
|
symbol: "${action.symbol}"
|
|
|
|
else:
|
|
|
|
groupSymbol: cron
|
|
|
|
symbol: "${cron.job_symbol}"
|
|
|
|
- $if: 'tasks_for == "action"'
|
|
|
|
then:
|
|
|
|
parent: '${action.taskGroupId}'
|
|
|
|
action:
|
|
|
|
name: '${action.name}'
|
|
|
|
context:
|
|
|
|
taskGroupId: '${action.taskGroupId}'
|
|
|
|
taskId: {$eval: 'taskId'}
|
|
|
|
input: {$eval: 'input'}
|
|
|
|
parameters: {$eval: 'parameters'}
|
2019-01-29 23:46:13 +03:00
|
|
|
clientId: {$eval: 'clientId'}
|
2018-07-03 21:07:42 +03:00
|
|
|
- $if: 'tasks_for == "cron"'
|
|
|
|
then:
|
|
|
|
cron: {$json: {$eval: 'cron'}}
|
|
|
|
- tasks_for: '${tasks_for}'
|
2018-09-24 16:46:55 +03:00
|
|
|
# Email format for try pushes
|
|
|
|
- $if: 'tasks_for == "hg-push" && repository.project == "try"'
|
|
|
|
then:
|
|
|
|
notify:
|
|
|
|
email:
|
|
|
|
subject: "Thank you for your try submission of ${push.revision}. It's the best!"
|
2018-11-09 00:40:53 +03:00
|
|
|
content: "Your try push has been submitted. It's the best! Use the link to view the status of your jobs."
|
2018-09-24 16:46:55 +03:00
|
|
|
link:
|
|
|
|
text: "Treeherder Jobs"
|
|
|
|
href: "https://treeherder.mozilla.org/#/jobs?repo=${repository.project}&revision=${push.revision}"
|
2018-12-20 19:39:43 +03:00
|
|
|
|