1 # Copyright 2012 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.
5 """Presubmit script for changes affecting tools/perf/.
7 See http://dev.chromium.org/developers/how-tos/depottools/presubmit-scripts
8 for more details about the presubmit API built into depot_tools.
16 def _CommonChecks(input_api
, output_api
):
17 """Performs common checks, which includes running pylint."""
19 old_sys_path
= sys
.path
21 # Modules in tools/perf depend on telemetry.
22 sys
.path
= [os
.path
.join(os
.pardir
, 'telemetry')] + sys
.path
23 results
.extend(input_api
.canned_checks
.RunPylint(
24 input_api
, output_api
, black_list
=[], pylintrc
='pylintrc',
25 extra_paths_list
=_GetPathsToPrepend(input_api
)))
26 results
.extend(_CheckJson(input_api
, output_api
))
27 results
.extend(_CheckWprShaFiles(input_api
, output_api
))
29 sys
.path
= old_sys_path
33 def _GetPathsToPrepend(input_api
):
34 perf_dir
= input_api
.PresubmitLocalPath()
35 chromium_src_dir
= input_api
.os_path
.join(perf_dir
, '..', '..')
36 telemetry_dir
= input_api
.os_path
.join(chromium_src_dir
, 'tools', 'telemetry')
39 input_api
.os_path
.join(telemetry_dir
, 'third_party', 'mock'),
43 def _CheckWprShaFiles(input_api
, output_api
):
44 """Check whether the wpr sha files have matching URLs."""
45 from catapult_base
import cloud_storage
47 for affected_file
in input_api
.AffectedFiles(include_deletes
=False):
48 filename
= affected_file
.AbsoluteLocalPath()
49 if not filename
.endswith('wpr.sha1'):
51 expected_hash
= cloud_storage
.ReadHash(filename
)
52 is_wpr_file_uploaded
= any(
53 cloud_storage
.Exists(bucket
, expected_hash
)
54 for bucket
in cloud_storage
.BUCKET_ALIASES
.itervalues())
55 if not is_wpr_file_uploaded
:
56 wpr_filename
= filename
[:-5]
57 results
.append(output_api
.PresubmitError(
58 'The file matching %s is not in Cloud Storage yet.\n'
59 'You can upload your new WPR archive file with the command:\n'
60 'depot_tools/upload_to_google_storage.py --bucket '
61 '<Your pageset\'s bucket> %s.\nFor more info: see '
62 'http://www.chromium.org/developers/telemetry/'
63 'record_a_page_set#TOC-Upload-the-recording-to-Cloud-Storage' %
64 (filename
, wpr_filename
)))
68 def _CheckJson(input_api
, output_api
):
69 """Checks whether JSON files in this change can be parsed."""
70 for affected_file
in input_api
.AffectedFiles(include_deletes
=False):
71 filename
= affected_file
.AbsoluteLocalPath()
72 if os
.path
.splitext(filename
)[1] != '.json':
75 input_api
.json
.load(open(filename
))
77 return [output_api
.PresubmitError('Error parsing JSON in %s!' % filename
)]
81 def CheckChangeOnUpload(input_api
, output_api
):
83 report
.extend(_CommonChecks(input_api
, output_api
))
87 def CheckChangeOnCommit(input_api
, output_api
):
89 report
.extend(_CommonChecks(input_api
, output_api
))
93 def _IsBenchmarksModified(change
):
94 """Checks whether CL contains any modification to Telemetry benchmarks."""
95 for affected_file
in change
.AffectedFiles():
96 affected_file_path
= affected_file
.LocalPath()
97 file_path
, _
= os
.path
.splitext(affected_file_path
)
98 if (os
.path
.join('tools', 'perf', 'benchmarks') in file_path
or
99 os
.path
.join('tools', 'perf', 'measurements') in file_path
):
104 def PostUploadHook(cl
, change
, output_api
):
105 """git cl upload will call this hook after the issue is created/modified.
107 This hook adds extra try bots list to the CL description in order to run
108 Telemetry benchmarks on Perf trybots in addtion to CQ trybots if the CL
109 contains any changes to Telemetry benchmarks.
111 benchmarks_modified
= _IsBenchmarksModified(change
)
112 rietveld_obj
= cl
.RpcServer()
114 original_description
= rietveld_obj
.get_description(issue
)
115 if not benchmarks_modified
or re
.search(
116 r
'^CQ_EXTRA_TRYBOTS=.*', original_description
, re
.M | re
.I
):
122 'mac_10_10_perf_bisect',
124 'android_nexus5_perf_bisect'
126 bots
= ['tryserver.chromium.perf:%s' % s
for s
in bots
]
127 bots_string
= ';'.join(bots
)
128 description
= original_description
129 description
+= '\nCQ_EXTRA_TRYBOTS=%s' % bots_string
130 results
.append(output_api
.PresubmitNotifyResult(
131 'Automatically added Perf trybots to run Telemetry benchmarks on CQ.'))
133 if description
!= original_description
:
134 rietveld_obj
.update_description(issue
, description
)