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

Side by Side Diff: PRESUBMIT.py

Issue 5682011: Add RunPylint as a canned presubmit check. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/tools/depot_tools
Patch Set: Addressed review comments Created 10 years 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 | Annotate | Revision Log
« no previous file with comments | « no previous file | presubmit_canned_checks.py » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 # Copyright (c) 2009 The Chromium Authors. All rights reserved. 1 # Copyright (c) 2009 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 """Top-level presubmit script for depot tools. 5 """Top-level presubmit script for depot tools.
6 6
7 See http://dev.chromium.org/developers/how-tos/depottools/presubmit-scripts for 7 See http://dev.chromium.org/developers/how-tos/depottools/presubmit-scripts for
8 details on the presubmit API built into gcl. 8 details on the presubmit API built into gcl.
9 """ 9 """
10 10
11 UNIT_TESTS = [ 11 UNIT_TESTS = [
12 'tests.gcl_unittest', 12 'tests.gcl_unittest',
13 'tests.gclient_scm_test', 13 'tests.gclient_scm_test',
14 'tests.gclient_smoketest', 14 'tests.gclient_smoketest',
15 'tests.gclient_utils_test', 15 'tests.gclient_utils_test',
16 'tests.presubmit_unittest', 16 'tests.presubmit_unittest',
17 'tests.scm_unittest', 17 'tests.scm_unittest',
18 'tests.trychange_unittest', 18 'tests.trychange_unittest',
19 'tests.watchlists_unittest', 19 'tests.watchlists_unittest',
20 ] 20 ]
21 21
22 def CommonChecks(input_api, output_api):
23 output = []
24 output.extend(input_api.canned_checks.RunPythonUnitTests(
25 input_api,
26 output_api,
27 UNIT_TESTS))
28 output.extend(WasGitClUploadHookModified(input_api, output_api))
29
30 def filter_python_sources(affected_file):
31 filepath = affected_file.LocalPath()
32 return ((filepath.endswith('.py') and
33 filepath != 'cpplint.py' and
34 not filepath.startswith('tests')) or
35 filepath == 'git-try')
36
37 output.extend(input_api.canned_checks.RunPylint(
38 input_api,
39 output_api,
40 source_file_filter=filter_python_sources))
41 return output
42
43
22 def CheckChangeOnUpload(input_api, output_api): 44 def CheckChangeOnUpload(input_api, output_api):
23 output = [] 45 return CommonChecks(input_api, output_api)
24 output.extend(input_api.canned_checks.RunPythonUnitTests(input_api,
25 output_api,
26 UNIT_TESTS))
27 output.extend(WasGitClUploadHookModified(input_api, output_api))
28 output.extend(RunPylint(input_api, output_api))
29 return output
30 46
31 47
32 def CheckChangeOnCommit(input_api, output_api): 48 def CheckChangeOnCommit(input_api, output_api):
33 output = [] 49 output = []
34 output.extend(input_api.canned_checks.RunPythonUnitTests(input_api, 50 output.extend(CommonChecks(input_api, output_api))
35 output_api, 51 output.extend(input_api.canned_checks.CheckDoNotSubmit(
36 UNIT_TESTS)) 52 input_api,
37 output.extend(input_api.canned_checks.CheckDoNotSubmit(input_api, 53 output_api))
38 output_api))
39 output.extend(WasGitClUploadHookModified(input_api, output_api))
40 output.extend(RunPylint(input_api, output_api))
41 return output 54 return output
42 55
56
43 def WasGitClUploadHookModified(input_api, output_api): 57 def WasGitClUploadHookModified(input_api, output_api):
44 for affected_file in input_api.AffectedSourceFiles(None): 58 for affected_file in input_api.AffectedSourceFiles(None):
45 if (input_api.os_path.basename(affected_file.LocalPath()) == 59 if (input_api.os_path.basename(affected_file.LocalPath()) ==
46 'git-cl-upload-hook'): 60 'git-cl-upload-hook'):
47 return [output_api.PresubmitPromptWarning( 61 return [output_api.PresubmitPromptWarning(
48 'Don\'t forget to fix git-cl to download the newest version of ' 62 'Don\'t forget to fix git-cl to download the newest version of '
49 'git-cl-upload-hook')] 63 'git-cl-upload-hook')]
50 return [] 64 return []
51
52 def RunPylint(input_api, output_api):
53 import glob
54 files = glob.glob('*.py')
55 # It's a python script
56 files.append('git-try')
57 # It uses non-standard pylint exceptions that makes pylint always fail.
58 files.remove('cpplint.py')
59 try:
60 proc = input_api.subprocess.Popen(['pylint'] + sorted(files))
61 proc.communicate()
62 if proc.returncode:
63 return [output_api.PresubmitError('Fix pylint errors first.')]
64 return []
65 except OSError:
66 if input_api.platform == 'win32':
67 return [output_api.PresubmitNotifyResult(
68 'Warning: Can\'t run pylint because it is not installed. Please '
69 'install manually\n'
70 'Cannot do static analysis of python files.')]
71 return [output_api.PresubmitError(
72 'Please install pylint with "sudo apt-get install python-setuptools; '
73 'sudo easy_install pylint"\n'
74 'Cannot do static analysis of python files.')]
OLDNEW
« no previous file with comments | « no previous file | presubmit_canned_checks.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698