Greg Edelston | ff55089 | 2022-09-27 17:29:09 -0600 | [diff] [blame] | 1 | # Copyright 2019 The ChromiumOS Authors. |
David Burger | c0effc2 | 2020-03-04 08:27:07 -0700 | [diff] [blame] | 2 | # Use of this source code is governed by a BSD-style license that can be |
| 3 | # found in the LICENSE file. |
Lann Martin | 46361ee | 2019-03-14 15:30:47 -0600 | [diff] [blame] | 4 | |
recipe-roller | 4202bc6 | 2020-09-17 17:38:22 -0700 | [diff] [blame] | 5 | import git_cl |
Madeleine Hardt | 93db483 | 2021-08-13 17:48:24 +0000 | [diff] [blame] | 6 | from subprocess2 import CalledProcessError |
| 7 | |
George Engelbrecht | 1344a58 | 2021-08-24 09:56:25 -0600 | [diff] [blame] | 8 | UNLINTABLE_FILES = set(['recipes.py']) |
| 9 | |
Madeleine Hardt | 93db483 | 2021-08-13 17:48:24 +0000 | [diff] [blame] | 10 | |
| 11 | def PylintCheck(input_api, output_api): |
| 12 | """Run pylint checks for modified files.""" |
George Engelbrecht | 4a0d0fe | 2021-08-25 13:53:27 -0600 | [diff] [blame] | 13 | |
Madeleine Hardt | 93db483 | 2021-08-13 17:48:24 +0000 | [diff] [blame] | 14 | pylint_errors = [] |
George Engelbrecht | 4a0d0fe | 2021-08-25 13:53:27 -0600 | [diff] [blame] | 15 | |
Greg Edelston | ff55089 | 2022-09-27 17:29:09 -0600 | [diff] [blame] | 16 | # Find pylint (currently v2.7). |
George Engelbrecht | 4a0d0fe | 2021-08-25 13:53:27 -0600 | [diff] [blame] | 17 | canned_checks_path = input_api.canned_checks.__file__ |
| 18 | canned_checks_path = input_api.os_path.abspath(canned_checks_path) |
| 19 | depot_tools_path = input_api.os_path.dirname(canned_checks_path) |
Greg Edelston | ff55089 | 2022-09-27 17:29:09 -0600 | [diff] [blame] | 20 | pylint_path = input_api.os_path.join(depot_tools_path, 'pylint-2.7') |
George Engelbrecht | 4a0d0fe | 2021-08-25 13:53:27 -0600 | [diff] [blame] | 21 | |
George Engelbrecht | b3f23ac | 2021-08-25 13:06:17 -0600 | [diff] [blame] | 22 | for affected in input_api.AffectedFiles(include_deletes=False): |
George Engelbrecht | 1344a58 | 2021-08-24 09:56:25 -0600 | [diff] [blame] | 23 | affected_str = str(affected) |
| 24 | if affected_str.endswith(".py"): |
| 25 | if affected_str in UNLINTABLE_FILES: |
| 26 | continue |
Madeleine Hardt | 93db483 | 2021-08-13 17:48:24 +0000 | [diff] [blame] | 27 | try: |
| 28 | input_api.subprocess.check_output( |
George Engelbrecht | 4a0d0fe | 2021-08-25 13:53:27 -0600 | [diff] [blame] | 29 | [pylint_path, '--rcfile', 'pylintrc', |
George Engelbrecht | 1344a58 | 2021-08-24 09:56:25 -0600 | [diff] [blame] | 30 | '%s' % (affected_str)]) |
Madeleine Hardt | 93db483 | 2021-08-13 17:48:24 +0000 | [diff] [blame] | 31 | except CalledProcessError as error: |
| 32 | pylint_errors.append("%s" % error) |
| 33 | if pylint_errors: |
| 34 | pylint_errors = [ |
| 35 | output_api.PresubmitError(( |
| 36 | 'Please fix pylint errors or add \'#pylint: disable=your-error\' in the source code ' |
| 37 | 'at the end of the relevant line:\n\n%s') % |
| 38 | "\n".join(pylint_errors)) |
| 39 | ] |
| 40 | return pylint_errors |
recipe-roller | 4202bc6 | 2020-09-17 17:38:22 -0700 | [diff] [blame] | 41 | |
Lann Martin | 46361ee | 2019-03-14 15:30:47 -0600 | [diff] [blame] | 42 | |
Dhanya Ganesh | 07c1aa4 | 2022-04-20 17:53:57 +0000 | [diff] [blame] | 43 | def FormatCheck(input_api, output_api): |
recipe-roller | 4202bc6 | 2020-09-17 17:38:22 -0700 | [diff] [blame] | 44 | bad_format = False |
| 45 | cmd = [ |
| 46 | '-C', |
| 47 | input_api.change.RepositoryRoot(), 'cl', 'format', '--dry-run', |
| 48 | '--presubmit', '--python', '--no-clang-format', '--diff' |
| 49 | ] |
Madeleine Hardt | 93db483 | 2021-08-13 17:48:24 +0000 | [diff] [blame] | 50 | _, out = git_cl.RunGitWithCode(cmd, suppress_stderr=True) |
recipe-roller | 4202bc6 | 2020-09-17 17:38:22 -0700 | [diff] [blame] | 51 | for line in out.splitlines(): |
| 52 | if line.startswith('--- ') or line.startswith('+++ '): |
| 53 | if not ' recipes.py\t' in line: |
| 54 | bad_format = True |
| 55 | break |
| 56 | |
| 57 | if bad_format: |
Dhanya Ganesh | 07c1aa4 | 2022-04-20 17:53:57 +0000 | [diff] [blame] | 58 | return input_api.canned_checks.CheckPatchFormatted( |
recipe-roller | 4202bc6 | 2020-09-17 17:38:22 -0700 | [diff] [blame] | 59 | input_api, output_api, check_python=True, check_clang_format=False, |
| 60 | result_factory=output_api.PresubmitError) |
Greg Edelston | ff55089 | 2022-09-27 17:29:09 -0600 | [diff] [blame] | 61 | return None |
Andrew Lamb | 9b2d086 | 2019-04-03 16:38:52 -0600 | [diff] [blame] | 62 | |
Dhanya Ganesh | 07c1aa4 | 2022-04-20 17:53:57 +0000 | [diff] [blame] | 63 | |
| 64 | def CommitChecks(input_api, output_api): |
| 65 | file_filter = lambda x: x.LocalPath() == 'infra/config/recipes.cfg' |
| 66 | results = input_api.canned_checks.CheckJsonParses(input_api, output_api, |
| 67 | file_filter=file_filter) |
| 68 | |
| 69 | # recipes.py test run |
| 70 | results += input_api.RunTests([ |
| 71 | input_api.Command( |
| 72 | name='recipes test', |
| 73 | cmd=[input_api.python_executable, 'recipes.py', 'test', 'run'], |
| 74 | kwargs={}, |
| 75 | message=output_api.PresubmitError, |
| 76 | ) |
| 77 | ]) |
| 78 | results += PylintCheck(input_api, output_api) |
| 79 | # Python formatting issues are errors, but we need to ignore recipes.py, which |
| 80 | # we do not control. |
| 81 | fmt_results = FormatCheck(input_api, output_api) |
| 82 | if fmt_results: |
| 83 | results += fmt_results |
Lann Martin | 46361ee | 2019-03-14 15:30:47 -0600 | [diff] [blame] | 84 | return results |
| 85 | |
| 86 | |
Dhanya Ganesh | 07c1aa4 | 2022-04-20 17:53:57 +0000 | [diff] [blame] | 87 | def UploadChecks(input_api, output_api): |
| 88 | file_filter = lambda x: x.LocalPath() == 'infra/config/recipes.cfg' |
| 89 | results = input_api.canned_checks.CheckJsonParses(input_api, output_api, |
| 90 | file_filter=file_filter) |
Navil Perez | 6d4fa16 | 2022-04-22 21:01:25 +0000 | [diff] [blame] | 91 | results += PylintCheck(input_api, output_api) |
Dhanya Ganesh | 07c1aa4 | 2022-04-20 17:53:57 +0000 | [diff] [blame] | 92 | # Python formatting issues are errors, but we need to ignore recipes.py, which |
| 93 | # we do not control. |
| 94 | fmt_results = FormatCheck(input_api, output_api) |
| 95 | if fmt_results: |
| 96 | results += fmt_results |
| 97 | return results |
| 98 | |
| 99 | |
| 100 | CheckChangeOnUpload = UploadChecks |
| 101 | CheckChangeOnCommit = CommitChecks |