|
| 1 | +import logging |
| 2 | + |
| 3 | +from mozci.ci_manager import TaskClusterBuildbotManager |
| 4 | +from mozci.sources import buildjson, buildbot_bridge |
| 5 | +from mozci import query_jobs |
| 6 | +from thclient import TreeherderClient |
| 7 | +from pulse_actions.publisher import MessageHandler |
| 8 | + |
| 9 | +logging.basicConfig(format='%(levelname)s:\t %(message)s') |
| 10 | +LOG = logging.getLogger() |
| 11 | +MEMORY_SAVING_MODE = True |
| 12 | + |
| 13 | + |
| 14 | +def on_runnable_job_stage_event(data, message, dry_run): |
| 15 | + return on_runnable_job_event(data, message, dry_run, stage=True) |
| 16 | + |
| 17 | + |
| 18 | +def on_runnable_job_prod_event(data, message, dry_run): |
| 19 | + return on_runnable_job_event(data, message, dry_run, stage=False) |
| 20 | + |
| 21 | + |
| 22 | +def on_runnable_job_event(data, message, dry_run, stage): |
| 23 | + # Cleaning mozci caches |
| 24 | + buildjson.BUILDS_CACHE = {} |
| 25 | + query_jobs.JOBS_CACHE = {} |
| 26 | + repo_name = data["project"] |
| 27 | + requester = data["requester"] |
| 28 | + resultset_id = data["resultset_id"] |
| 29 | + buildernames = data["buildernames"] |
| 30 | + |
| 31 | + if stage: |
| 32 | + treeherder_client = TreeherderClient(host='treeherder.allizom.org') |
| 33 | + else: |
| 34 | + treeherder_client = TreeherderClient() |
| 35 | + |
| 36 | + mgr = TaskClusterBuildbotManager() |
| 37 | + |
| 38 | + LOG.info("New jobs requested by %s on repo_name %s with resultset_id: %s" % |
| 39 | + (data["requester"], data["project"], data["resultset_id"])) |
| 40 | + resultset = treeherder_client.get_resultsets(repo_name, id=resultset_id)[0] |
| 41 | + revision = resultset["revision"] |
| 42 | + author = resultset["author"] |
| 43 | + status = None |
| 44 | + |
| 45 | + message_sender = MessageHandler() |
| 46 | + # Everyone can press the button, but only authorized users can trigger jobs |
| 47 | + # TODO: remove this when proper LDAP identication is set up on TH |
| 48 | + if author != requester and not requester.endswith('@mozilla.com'): |
| 49 | + message.ack() |
| 50 | + |
| 51 | + # We publish a message saying we will not trigger the job |
| 52 | + pulse_message = { |
| 53 | + 'resultset_id': resultset_id, |
| 54 | + 'requester': requester, |
| 55 | + 'status': "Could not determine if the user is authorized, nothing was triggered."} |
| 56 | + routing_key = '{}.{}'.format(repo_name, 'runnable') |
| 57 | + message_sender.publish_message(pulse_message, routing_key) |
| 58 | + |
| 59 | + raise Exception("Requester %s is not allowed to trigger jobs." % |
| 60 | + requester) |
| 61 | + |
| 62 | + builders_graph = buildbot_bridge.buildbot_graph_builder(buildernames, revision) |
| 63 | + mgr.schedule_graph( |
| 64 | + repo_name=repo_name, |
| 65 | + revision=revision, |
| 66 | + builders_graph=builders_graph, |
| 67 | + dry_run=dry_run) |
| 68 | + |
| 69 | + # Send a pulse message showing what we did |
| 70 | + message_sender = MessageHandler() |
| 71 | + pulse_message = { |
| 72 | + 'resultset_id': resultset_id, |
| 73 | + 'graph': builders_graph, |
| 74 | + 'requester': requester, |
| 75 | + 'status': status} |
| 76 | + routing_key = '{}.{}'.format(repo_name, 'runnable') |
| 77 | + message_sender.publish_message(pulse_message, routing_key) |
| 78 | + |
| 79 | + # We need to ack the message to remove it from our queue |
| 80 | + message.ack() |
0 commit comments