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

Unified Diff: test.py

Issue 1917383002: test.py: compute coverage per top-level module. (Closed) Base URL: https://chromium.googlesource.com/infra/infra.git@master
Patch Set: Addressing comments, and more polishing Created 4 years, 8 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « infra_libs/.coveragerc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: test.py
diff --git a/test.py b/test.py
index bf199ce850fc315c49227ce84886567a0d25f814..1963b6144efc1bb2e7626affbbfdde70170483ec 100755
--- a/test.py
+++ b/test.py
@@ -14,7 +14,7 @@ import sys
def usage():
- print """\nUsage: %s <action> [<expect_tests options>] [<test names>]
+ print """\nUsage: %s <action> [<test names>] [<expect_tests options>]
where <action> is one of: list, test, train, debug.
@@ -23,12 +23,13 @@ def usage():
./test.py test
Run all tests in the infra package:
./test.py test infra
+ Run all tests and generate an HTML report:
+ ./test.py test infra --html-report /path/to/report/folder
Run one given test in the infra package:
./test.py test infra/libs/git2/test:*testCommitBogus
See expect_tests documentation for more details
""" % sys.argv[0]
- sys.exit(1)
INFRA_ROOT = os.path.dirname(os.path.abspath(__file__))
@@ -58,9 +59,11 @@ WIN_ENABLED_PACKAGES = [
# Parse command-line arguments
if len(sys.argv) == 1:
usage()
+ sys.exit(1)
else:
if not sys.argv[1] in ('list', 'train', 'test', 'debug'):
usage()
+ sys.exit(1)
if sys.platform == 'win32':
python_bin = os.path.join('ENV', 'Scripts', 'python')
@@ -69,31 +72,67 @@ else:
python_bin = os.path.join('ENV', 'bin', 'python')
expect_tests_path = os.path.join('ENV', 'bin', 'expect_tests')
-args = sys.argv[1:]
+command = sys.argv[1]
+args = sys.argv[2:]
+
+modules = []
+flags = []
+for arg in args:
+ if arg.startswith('-'):
+ flags.append(arg)
+ continue
+ if flags:
+ flags.append(arg)
+ else:
+ modules.append(arg)
# Set up default list of packages/directories if none have been provided.
-if all([arg.startswith('--') for arg in sys.argv[2:]]):
+if not modules:
if sys.platform == 'win32':
- args.extend(WIN_ENABLED_PACKAGES)
+ modules.extend(WIN_ENABLED_PACKAGES)
else:
- args.extend(['infra', 'infra_libs']) # TODO(pgervais): add 'test/'
+ modules.extend(['infra', 'infra_libs']) # TODO(pgervais): add 'test/'
appengine_dir = os.path.join(INFRA_ROOT, 'appengine')
if sys.platform != 'win32' and os.path.isdir(appengine_dir):
- args.extend(['appengine_module'])
+ modules.extend(['appengine_module'])
appengine_dirs = [
os.path.join('appengine', d)
for d in os.listdir(appengine_dir)
]
# Use relative paths to shorten the command-line
- args.extend(itertools.chain(
+ modules.extend(itertools.chain(
[d for d in appengine_dirs if os.path.isfile(os.path.join(d, 'app.yaml'))]
))
os.environ['PYTHONPATH'] = ''
os.chdir(INFRA_ROOT)
-if '--help' not in sys.argv and '-h' not in sys.argv:
+if '--help' not in flags and '-h' not in flags:
subprocess.check_call(
[python_bin, os.path.join('bootstrap', 'remove_orphaned_pycs.py')])
-if sys.platform == 'win32' and '--force-coverage' not in args:
- args.append('--no-coverage')
-sys.exit(subprocess.call([python_bin, expect_tests_path] + args))
+else:
+ usage()
+ sys.exit(subprocess.call([python_bin, expect_tests_path, command, '--help']))
+
+if sys.platform == 'win32' and '--force-coverage' not in flags:
+ flags.append('--no-coverage')
+
+exit_code = 0
+failed_modules = []
+for module in modules:
+ print 'Running %s...' % module
+ module_flags = flags[:]
+ module_flags.append('--coveragerc=%s' % os.path.join(
+ INFRA_ROOT, module, '.coveragerc'))
+ module_flags.append('--html-report-subdir=%s' % module)
+ cmd = [python_bin, expect_tests_path, command, module] + module_flags
+ module_exit_code = subprocess.call(cmd)
+ exit_code = module_exit_code or exit_code
+ if module_exit_code:
+ failed_modules.append(module)
+
+if exit_code:
+ print 'Tests failed in modules:\n %s' % '\n '.join(failed_modules)
+else:
+ print 'All tests passed.'
+
+sys.exit(exit_code)
« no previous file with comments | « infra_libs/.coveragerc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698