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

Side by Side Diff: webkit/tools/layout_tests/PRESUBMIT.py

Issue 160442: Add presubmit check to lint test files. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 11 years, 4 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 | Annotate | Revision Log
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Property Changes:
Name: svn:eol-style
+ LF
OLDNEW
(Empty)
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
3 # found in the LICENSE file.
4
5 """test_expectations.txt presubmit script.
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 TEST_EXPECTATIONS = 'test_expectations.txt'
12
13 def LintTestFiles(input_api, output_api):
14 current_dir = input_api.PresubmitLocalPath()
15 # Set 'webkit/tools/layout_tests' in include path.
16 python_paths = [
17 current_dir,
18 input_api.os_path.join(current_dir, '..', '..', '..', 'tools', 'python')
19 ]
20 env = input_api.environ.copy()
21 if env.get('PYTHONPATH'):
22 python_paths.append(env['PYTHONPATH'])
23 env['PYTHONPATH'] = input_api.os_path.pathsep.join(python_paths)
24 args = [
25 input_api.python_executable,
26 input_api.os_path.join(current_dir, 'run_webkit_tests.py'),
27 '--lint-test-files'
28 ]
29 subproc = input_api.subprocess.Popen(
30 args,
31 cwd=current_dir,
32 env=env,
33 stdin=input_api.subprocess.PIPE,
34 stdout=input_api.subprocess.PIPE,
35 stderr=input_api.subprocess.STDOUT)
36 stdoutdata = subproc.communicate()[0]
37 # TODO(ukai): consolidate run_webkit_tests --lint-test-files reports.
38 is_error = lambda line: (input_api.re.match('^Line:', line) or
39 input_api.re.search('ERROR Line:', line))
40 error = filter(is_error, stdoutdata.splitlines())
41 if error:
42 return [output_api.PresubmitError('Lint error\n%s' % '\n'.join(error),
43 long_text=stdoutdata)]
44 return []
45
46 def LintTestExpectations(input_api, output_api):
47 for path in input_api.LocalPaths():
48 if TEST_EXPECTATIONS == input_api.os_path.basename(path):
49 return LintTestFiles(input_api, output_api)
50 return []
51
52
53 def CheckChangeOnUpload(input_api, output_api):
54 return LintTestExpectations(input_api, output_api)
55
56 def CheckChangeOnCommit(input_api, output_api):
57 return LintTestExpectations(input_api, output_api)
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698