diff options
Diffstat (limited to 'test.py')
-rwxr-xr-x | test.py | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/test.py b/test.py new file mode 100755 index 0000000000..414d7790f8 --- /dev/null +++ b/test.py @@ -0,0 +1,74 @@ +#!/usr/bin/env python +# +# Copyright 2017, The Android Open Source Project +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# --run-test : To run run-test +# --gtest : To run gtest +# -j : Number of jobs +# --host: for host tests +# --target: for target tests +# All the other arguments will be passed to the run-test testrunner. +import sys +import subprocess +import os +import argparse + +ANDROID_BUILD_TOP = os.environ.get('ANDROID_BUILD_TOP', os.getcwd()) + +parser = argparse.ArgumentParser() +parser.add_argument('-j', default='', dest='n_threads') +parser.add_argument('--run-test', '-r', action='store_true', dest='run_test') +parser.add_argument('--gtest', '-g', action='store_true', dest='gtest') +parser.add_argument('--target', action='store_true', dest='target') +parser.add_argument('--host', action='store_true', dest='host') +options, unknown = parser.parse_known_args() + +if options.run_test or not options.gtest: + testrunner = os.path.join('./', + ANDROID_BUILD_TOP, + 'art/test/testrunner/testrunner.py') + run_test_args = [] + for arg in sys.argv[1:]: + if arg == '--run-test' or arg == '--gtest' \ + or arg == '-r' or arg == '-g': + continue + run_test_args.append(arg) + + test_runner_cmd = [testrunner] + run_test_args + print test_runner_cmd + if subprocess.call(test_runner_cmd): + sys.exit(1) + +if options.gtest or not options.run_test: + build_target = '' + if options.host or not options.target: + build_target += ' test-art-host-gtest' + if options.target or not options.host: + build_target += ' test-art-target-gtest' + + build_command = 'make' + build_command += ' -j' + str(options.n_threads) + + build_command += ' -C ' + ANDROID_BUILD_TOP + build_command += ' ' + build_target + # Add 'dist' to avoid Jack issues b/36169180. + build_command += ' dist' + + print build_command + + if subprocess.call(build_command.split()): + sys.exit(1) + +sys.exit(0) |