Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(291)

Unified Diff: appengine/findit/model/flake/master_flake_analysis.py

Issue 2369333002: [Findit] Capture versionized metadata for master_flake_analysis (Closed)
Patch Set: Fixing nits Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: appengine/findit/model/flake/master_flake_analysis.py
diff --git a/appengine/findit/model/flake/master_flake_analysis.py b/appengine/findit/model/flake/master_flake_analysis.py
index 2805c843e5c6f43a3088f709df6e192a2ac079fc..37839df62ffb644e43d933f3aed2986a8f501a86 100644
--- a/appengine/findit/model/flake/master_flake_analysis.py
+++ b/appengine/findit/model/flake/master_flake_analysis.py
@@ -6,20 +6,21 @@ import base64
from google.appengine.ext import ndb
-from model.base_build_model import BaseBuildModel
+from common import time_util
+from model import analysis_status
from model.base_analysis import BaseAnalysis
-from model.flake.flake_swarming_task import FlakeSwarmingTask
+from model.base_build_model import BaseBuildModel
+from model.flake.flake_swarming_task import FlakeSwarmingTaskData
+from model.versioned_model import VersionedModel
-class MasterFlakeAnalysis(BaseAnalysis, BaseBuildModel):
- """Represents an analysis of a flaky test in a Chromium Waterfall."""
+class DataPoint(ndb.Model):
+ build_number = ndb.IntegerProperty(indexed=False)
+ pass_rate = ndb.FloatProperty(indexed=False)
- @staticmethod
- def _CreateAnalysisId(master_name, builder_name,
- build_number, step_name, test_name):
- encoded_test_name = base64.urlsafe_b64encode(test_name)
- return '%s/%s/%s/%s/%s' % (master_name, builder_name,
- build_number, step_name, encoded_test_name)
+
+class MasterFlakeAnalysis(BaseAnalysis, BaseBuildModel, VersionedModel):
+ """Represents an analysis of a flaky test in a Chromium Waterfall."""
@ndb.ComputedProperty
def step_name(self):
@@ -30,29 +31,81 @@ class MasterFlakeAnalysis(BaseAnalysis, BaseBuildModel):
return base64.urlsafe_b64decode(self.key.pairs()[0][1].split('/')[4])
@staticmethod
- def _CreateKey(master_name, builder_name, build_number,
- step_name, test_name): # pragma: no cover
- return ndb.Key('MasterFlakeAnalysis',
- MasterFlakeAnalysis._CreateAnalysisId(
- master_name, builder_name, build_number,
- step_name, test_name))
+ def _CreateAnalysisId(
+ master_name, builder_name, build_number, step_name, test_name):
+ encoded_test_name = base64.urlsafe_b64encode(test_name)
+ return '%s/%s/%s/%s/%s' % (
+ master_name, builder_name, build_number, step_name, encoded_test_name)
- @staticmethod
- def Create(master_name, builder_name, build_number,
- step_name, test_name): # pragma: no cover
- return MasterFlakeAnalysis(
- key=MasterFlakeAnalysis._CreateKey(
- master_name, builder_name, build_number,
- step_name, test_name))
+ # Arguments number differs from overridden method - pylint: disable=W0221
+ @classmethod
+ def Create(cls, master_name, builder_name, build_number, step_name,
+ test_name): # pragma: no cover.
+ return super(MasterFlakeAnalysis, cls).Create(
+ MasterFlakeAnalysis._CreateAnalysisId(
+ master_name, builder_name, build_number, step_name, test_name))
- @staticmethod
- def Get(master_name, builder_name, build_number,
- step_name, test_name): # pragma: no cover
- return MasterFlakeAnalysis._CreateKey(
- master_name, builder_name, build_number, step_name, test_name).get()
-
- # List of tested build_numbers and their corresponding success rates.
- # We need to keep these sorted manually.
- build_numbers = ndb.IntegerProperty(indexed=False, repeated=True)
- success_rates = ndb.FloatProperty(indexed=False, repeated=True)
+ # Arguments number differs from overridden method - pylint: disable=W0221
+ @classmethod
+ def GetVersion(cls, master_name, builder_name, build_number, step_name,
+ test_name, version=None): # pragma: no cover.
+ return super(MasterFlakeAnalysis, cls).GetVersion(
+ key=MasterFlakeAnalysis._CreateAnalysisId(
+ master_name, builder_name, build_number, step_name, test_name),
+ version=version)
+
+ def Reset(self):
+ self.created_time = time_util.GetUTCNow()
+ self.status = analysis_status.PENDING
+ self.completed_time = None
+ self.swarming_rerun_results = []
+ self.error = None
+ self.correct_regression_range = None
+ self.correct_culprit = None
+ self.algorithm_parameters = None
+ self.suspected_flake_build_number = None
+ self.data_points = []
+
+ # The UTC timestamp this analysis was requested.
+ created_time = ndb.DateTimeProperty(indexed=True)
+
+ # The UTC timestamp this analysis was completed.
+ completed_time = ndb.DateTimeProperty(indexed=True)
+
+ # A list of dicts containing information about each swarming rerun's results
+ # that were involved in this analysis. The contents of this list will be used
+ # for metrics, such as the number of cache hits this analysis benefited from,
+ # the number of swarming tasks that were needed end-to-end to find the
+ # regressed build number (if any), etc. See FlakeSwarmingTaskData for exact
+ # fields.
+ swarming_rerun_results = ndb.LocalStructuredProperty(
+ FlakeSwarmingTaskData, repeated=True, compressed=True)
+
+ # Error code and message, if any.
+ error = ndb.JsonProperty(indexed=False)
+
+ # Boolean whether the suspected regression range/build number is correct.
+ correct_regression_range = ndb.BooleanProperty(indexed=True)
+
+ # Boolean whether the suspected CL for found in the regression range
+ # is correct.
+ correct_culprit = ndb.BooleanProperty(indexed=True)
+
+ # The look back algorithm parameters that were used, as specified in Findit's
+ # configuration. For example,
+ # {
+ # 'iterations_to_rerun': 100,
+ # 'lower_flake_threshold': 0.02,
+ # 'max_build_numbers_to_look_back': 500,
+ # 'max_flake_in_a_row': 4,
+ # 'max_stable_in_a_row': 4,
+ # 'upper_flake_threshold': 0.98
+ # }
+ algorithm_parameters = ndb.JsonProperty(indexed=False)
+
+ # The suspected build number to have introduced the flakiness.
suspected_flake_build_number = ndb.IntegerProperty()
+
+ # The data points used to plot the flakiness graph build over build.
+ data_points = ndb.LocalStructuredProperty(
+ DataPoint, repeated=True, compressed=True)
« no previous file with comments | « appengine/findit/model/flake/flake_swarming_task.py ('k') | appengine/findit/model/flake/master_flake_analysis_data.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698