blob: 57ecbe5a6650a532c33a93457dfbf04bfca6ba3a [file] [log] [blame]
# Copyright 2016 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
import json
import logging
from common import constants
from gae_libs.handlers.base_handler import BaseHandler, Permission
from waterfall import build_failure_analysis_pipelines
from waterfall import build_util
def _TriggerNewAnalysesOnDemand(builds):
for build in builds:
master_name = build['master_name']
builder_name = build['builder_name']
build_number = build['build_number']
failed_steps = build.get('failed_steps')
# TODO(stgao): make alerts-dispatcher send information of whether a build
# is completed.
build_info = build_util.GetBuildInfo(master_name, builder_name,
build_number)
if not build_info:
logging.error('Failed to retrieve build data for %s/%s/%s, steps=%s',
master_name, builder_name, build_number, repr(failed_steps))
continue # Skip the build, wait for next request to recheck.
build_completed = build_info.completed
build_failure_analysis_pipelines.ScheduleAnalysisIfNeeded(
master_name,
builder_name,
build_number,
failed_steps=failed_steps,
build_completed=build_completed,
force=False,
queue_name=constants.WATERFALL_ANALYSIS_QUEUE)
class ProcessFailureAnalysisRequests(BaseHandler):
"""Triggers new analyses on demand.
This handler checks the build failures in the request, and triggers new
analyses for a build in two situations:
1. A new step failed.
2. The build became completed after last analysis. This will potentially
trigger a try-job run.
"""
PERMISSION_LEVEL = Permission.APP_SELF
def HandlePost(self):
builds = json.loads(self.request.body).get('builds', [])
_TriggerNewAnalysesOnDemand(builds)