Roll src/third_party/WebKit f007c95:0171005 (svn 185074:185088)
[chromium-blink-merge.git] / chrome / PRESUBMIT.py
blobbf91a9c937cdbc8d97b33957c44a56be801d8e8b
1 # Copyright (c) 2011 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 chrome/
7 See http://dev.chromium.org/developers/how-tos/depottools/presubmit-scripts
8 for more details about the presubmit API built into gcl.
9 """
11 import re
13 INCLUDE_CPP_FILES_ONLY = (
14 r'.*\.cc$', r'.*\.h$'
17 EXCLUDE = (
18 # Objective C confuses everything.
19 r'.*cocoa.*',
20 r'.*_mac\.(cc|h)$',
21 r'.*_mac_.*',
22 # All the messages files do weird multiple include trickery
23 r'.*_messages.*\.h$',
24 r'render_messages.h$',
25 # Autogenerated window resources files are off limits
26 r'.*resource.h$',
27 # Header trickery
28 r'.*-inl\.h$',
29 # Templates
30 r'sigslotrepeater\.h$',
31 # GCC attribute trickery
32 r'sel_main\.cc$',
33 # Mozilla code
34 r'mork_reader\.h$',
35 r'mork_reader\.cc$',
36 r'nss_decryptor_linux\.cc$',
37 # Has safe printf usage that cpplint complains about
38 r'safe_browsing_util\.cc$',
39 # Bogus ifdef tricks
40 r'renderer_webkitplatformsupport_impl\.cc$',
41 # Lines > 100 chars
42 r'gcapi\.cc$',
45 def _CheckChangeLintsClean(input_api, output_api):
46 """Makes sure that the chrome/ code is cpplint clean."""
47 black_list = input_api.DEFAULT_BLACK_LIST + EXCLUDE
48 sources = lambda x: input_api.FilterSourceFile(
49 x, white_list=INCLUDE_CPP_FILES_ONLY, black_list=black_list)
50 return input_api.canned_checks.CheckChangeLintsClean(
51 input_api, output_api, sources)
53 def _CheckNoContentUnitTestsInChrome(input_api, output_api):
54 """Makes sure that no unit tests from content/ are included in unit_tests."""
55 problems = []
56 for f in input_api.AffectedFiles():
57 if not f.LocalPath().endswith('chrome_tests.gypi'):
58 continue
60 for line_num, line in f.ChangedContents():
61 m = re.search(r"'(.*\/content\/.*unittest.*)'", line)
62 if m:
63 problems.append(m.group(1))
65 if not problems:
66 return []
67 return [output_api.PresubmitPromptWarning(
68 'Unit tests located in content/ should be added to the ' +
69 'content_tests.gypi:content_unittests target.',
70 items=problems)]
72 def _CommonChecks(input_api, output_api):
73 """Checks common to both upload and commit."""
74 results = []
75 results.extend(_CheckNoContentUnitTestsInChrome(input_api, output_api))
76 return results
78 def CheckChangeOnUpload(input_api, output_api):
79 results = []
80 results.extend(_CommonChecks(input_api, output_api))
81 results.extend(_CheckChangeLintsClean(input_api, output_api))
82 return results
84 def CheckChangeOnCommit(input_api, output_api):
85 results = []
86 results.extend(_CommonChecks(input_api, output_api))
87 return results