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

Side by Side Diff: build/util/PRESUBMIT.py

Issue 12261026: Added separate checkout and config file generation to bisect script (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Misc fixes and changes. Created 7 years, 10 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 unified diff | Download patch
OLDNEW
(Empty)
1 # Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file.
4
5 """Top-level presubmit script for testing.
tonyg 2013/02/14 23:30:06 Comment needs updating
shatch 2013/02/14 23:59:46 Done.
6
7 See http://dev.chromium.org/developers/how-tos/depottools/presubmit-scripts for
8 details on the presubmit API built into gcl.
9 """
10
11 import imp
12
13 def _ExamineBisectConfigFile(input_api, output_api):
14 for f in input_api.AffectedFiles():
15 if not f.LocalPath().endswith('run-bisect-perf-regression.cfg'):
16 continue
17
18 try:
19 cfg_file = imp.load_source('config', 'run-bisect-perf-regression.cfg')
20
21 valid_keys = ['command', 'good_revision', 'bad_revision', 'metric']
tonyg 2013/02/14 23:30:06 I'm not sure I'd lock down the key names. We might
shatch 2013/02/14 23:59:46 If you added a new key name, would you not want PR
22
23 for k, v in cfg_file.config.iteritems():
24 if not k in valid_keys or v:
25 return f.LocalPath()
26 except (IOError, AttributeError, TypeError):
27 return f.LocalPath()
28
29 return None
30
31 def _CheckNoChangesToBisectConfigFile(input_api, output_api):
32 results = _ExamineBisectConfigFile(input_api, output_api)
33 if results:
34 return [output_api.PresubmitError(
shatch 2013/02/14 23:00:34 Should this be just a warning or an error?
tonyg 2013/02/14 23:30:06 error sounds good
35 'The bisection config file should only contain a config dict with '
36 'empty fields. Changes to this file should never be submitted.',
37 items=[results])]
38
39 return []
40
41 def CommonChecks(input_api, output_api):
42 results = []
43 results.extend(_CheckNoChangesToBisectConfigFile(input_api, output_api))
44 return results
45
46 def CheckChangeOnUpload(input_api, output_api):
47 return CommonChecks(input_api, output_api)
tonyg 2013/02/14 23:30:06 I'm not sure I'd perform this check on upload. Jus
shatch 2013/02/14 23:59:46 I'm a little unfamiliar with the PRESUBMIT scripts
48
49 def CheckChangeOnCommit(input_api, output_api):
50 return CommonChecks(input_api, output_api)
OLDNEW
« no previous file with comments | « no previous file | build/util/run-bisect-perf-regression.cfg » ('j') | build/util/run-bisect-perf-regression.cfg » ('J')

Powered by Google App Engine
This is Rietveld 408576698