| Index: trunk/src/build/android/run_instrumentation_tests.py
|
| ===================================================================
|
| --- trunk/src/build/android/run_instrumentation_tests.py (revision 210250)
|
| +++ trunk/src/build/android/run_instrumentation_tests.py (working copy)
|
| @@ -6,19 +6,73 @@
|
|
|
| """Runs both the Python and Java instrumentation tests."""
|
|
|
| -import logging
|
| +import optparse
|
| import os
|
| import sys
|
|
|
| -from pylib import cmd_helper
|
| +from pylib import buildbot_report
|
| +from pylib import ports
|
| +from pylib.base import base_test_result
|
| +from pylib.host_driven import run_python_tests
|
| +from pylib.instrumentation import dispatch
|
| +from pylib.utils import report_results
|
| +from pylib.utils import run_tests_helper
|
| +from pylib.utils import test_options_parser
|
|
|
|
|
| +def DispatchInstrumentationTests(options):
|
| + """Dispatches the Java and Python instrumentation tests, sharding if possible.
|
| +
|
| + Uses the logging module to print the combined final results and
|
| + summary of the Java and Python tests. If the java_only option is set, only
|
| + the Java tests run. If the python_only option is set, only the python tests
|
| + run. If neither are set, run both Java and Python tests.
|
| +
|
| + Args:
|
| + options: command-line options for running the Java and Python tests.
|
| +
|
| + Returns:
|
| + An integer representing the number of broken tests.
|
| + """
|
| + if not options.keep_test_server_ports:
|
| + # Reset the test port allocation. It's important to do it before starting
|
| + # to dispatch any tests.
|
| + if not ports.ResetTestServerPortAllocation():
|
| + raise Exception('Failed to reset test server port.')
|
| +
|
| + all_results = base_test_result.TestRunResults()
|
| +
|
| + if options.run_java_tests:
|
| + all_results.AddTestRunResults(dispatch.Dispatch(options))
|
| + if options.run_python_tests:
|
| + all_results.AddTestRunResults(run_python_tests.DispatchPythonTests(options))
|
| +
|
| + report_results.LogFull(
|
| + results=all_results,
|
| + test_type='Instrumentation',
|
| + test_package=os.path.basename(options.test_apk),
|
| + annotation=options.annotations,
|
| + build_type=options.build_type,
|
| + flakiness_server=options.flakiness_dashboard_server)
|
| +
|
| + return len(all_results.GetNotPass())
|
| +
|
| +
|
| +def main(argv):
|
| + option_parser = optparse.OptionParser()
|
| + test_options_parser.AddInstrumentationOptions(option_parser)
|
| + options, args = option_parser.parse_args(argv)
|
| + test_options_parser.ValidateInstrumentationOptions(option_parser, options,
|
| + args)
|
| +
|
| + run_tests_helper.SetLogLevel(options.verbose_count)
|
| + ret = 1
|
| + try:
|
| + ret = DispatchInstrumentationTests(options)
|
| + finally:
|
| + buildbot_report.PrintStepResultIfNeeded(options, ret)
|
| + return ret
|
| +
|
| +
|
| if __name__ == '__main__':
|
| - args = ['python',
|
| - os.path.join(os.path.dirname(__file__), 'test_runner.py'),
|
| - 'instrumentation'] + sys.argv[1:]
|
| - logging.warning('*' * 80)
|
| - logging.warning('This script is deprecated and will be removed soon.')
|
| - logging.warning('Use the following instead: %s', ' '.join(args))
|
| - logging.warning('*' * 80)
|
| - sys.exit(cmd_helper.RunCmd(args))
|
| + sys.exit(main(sys.argv))
|
|
|