Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 # Copyright 2015 The Chromium Authors. All rights reserved. | 1 # Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 # Use of this source code is governed by a BSD-style license that can be | 2 # Use of this source code is governed by a BSD-style license that can be |
| 3 # found in the LICENSE file. | 3 # found in the LICENSE file. |
| 4 | 4 |
| 5 from datetime import datetime | 5 from datetime import datetime |
| 6 | 6 |
| 7 from common import appengine_util | 7 from common import appengine_util |
| 8 from common.pipeline_wrapper import BasePipeline | 8 from common.pipeline_wrapper import BasePipeline |
| 9 from common.pipeline_wrapper import pipeline | |
| 9 from model import analysis_status | 10 from model import analysis_status |
| 10 from model.wf_analysis import WfAnalysis | 11 from model.wf_analysis import WfAnalysis |
| 11 from waterfall.detect_first_failure_pipeline import DetectFirstFailurePipeline | 12 from waterfall.detect_first_failure_pipeline import DetectFirstFailurePipeline |
| 12 from waterfall.extract_deps_info_pipeline import ExtractDEPSInfoPipeline | 13 from waterfall.extract_deps_info_pipeline import ExtractDEPSInfoPipeline |
| 13 from waterfall.extract_signal_pipeline import ExtractSignalPipeline | 14 from waterfall.extract_signal_pipeline import ExtractSignalPipeline |
| 14 from waterfall.identify_culprit_pipeline import IdentifyCulpritPipeline | 15 from waterfall.identify_culprit_pipeline import IdentifyCulpritPipeline |
| 15 from waterfall.pull_changelog_pipeline import PullChangelogPipeline | 16 from waterfall.pull_changelog_pipeline import PullChangelogPipeline |
| 16 from waterfall.start_try_job_on_demand_pipeline import ( | 17 from waterfall.start_try_job_on_demand_pipeline import ( |
| 17 StartTryJobOnDemandPipeline) | 18 StartTryJobOnDemandPipeline) |
| 19 from waterfall.trigger_swarming_tasks_pipeline import ( | |
| 20 TriggerSwarmingTasksPipeline) | |
| 18 | 21 |
| 19 | 22 |
| 20 class AnalyzeBuildFailurePipeline(BasePipeline): | 23 class AnalyzeBuildFailurePipeline(BasePipeline): |
| 21 | 24 |
| 22 def __init__(self, master_name, builder_name, build_number, build_completed, | 25 def __init__(self, master_name, builder_name, build_number, build_completed, |
| 23 force_rerun_try_job): | 26 force_rerun_try_job): |
| 24 super(AnalyzeBuildFailurePipeline, self).__init__( | 27 super(AnalyzeBuildFailurePipeline, self).__init__( |
| 25 master_name, builder_name, build_number, build_completed, | 28 master_name, builder_name, build_number, build_completed, |
| 26 force_rerun_try_job) | 29 force_rerun_try_job) |
| 27 self.master_name = master_name | 30 self.master_name = master_name |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 65 # The yield statements below return PipelineFutures, which allow subsequent | 68 # The yield statements below return PipelineFutures, which allow subsequent |
| 66 # pipelines to refer to previous output values. | 69 # pipelines to refer to previous output values. |
| 67 # https://github.com/GoogleCloudPlatform/appengine-pipelines/wiki/Python | 70 # https://github.com/GoogleCloudPlatform/appengine-pipelines/wiki/Python |
| 68 failure_info = yield DetectFirstFailurePipeline( | 71 failure_info = yield DetectFirstFailurePipeline( |
| 69 master_name, builder_name, build_number) | 72 master_name, builder_name, build_number) |
| 70 change_logs = yield PullChangelogPipeline(failure_info) | 73 change_logs = yield PullChangelogPipeline(failure_info) |
| 71 deps_info = yield ExtractDEPSInfoPipeline(failure_info, change_logs) | 74 deps_info = yield ExtractDEPSInfoPipeline(failure_info, change_logs) |
| 72 signals = yield ExtractSignalPipeline(failure_info) | 75 signals = yield ExtractSignalPipeline(failure_info) |
| 73 heuristic_result = yield IdentifyCulpritPipeline( | 76 heuristic_result = yield IdentifyCulpritPipeline( |
| 74 failure_info, change_logs, deps_info, signals, build_completed) | 77 failure_info, change_logs, deps_info, signals, build_completed) |
| 75 yield StartTryJobOnDemandPipeline( | 78 |
| 76 failure_info, signals, build_completed, force_rerun_try_job, | 79 with pipeline.InOrder(): |
| 77 heuristic_result) | 80 # Trigger swarming tasks when test failure happens. |
| 81 yield TriggerSwarmingTasksPipeline( | |
| 82 master_name, builder_name, build_number, failure_info) | |
| 83 yield StartTryJobOnDemandPipeline( | |
|
stgao
2016/07/12 20:26:52
nit: maybe add a comment here too.
chanli
2016/07/12 20:41:19
Done.
| |
| 84 failure_info, signals, build_completed, force_rerun_try_job, | |
| 85 heuristic_result) | |
| OLD | NEW |