Mathias Rav | dd6a6de | 2018-05-18 10:18:33 +0200 | [diff] [blame] | 1 | # Copyright (c) 2018, the R8 project authors. Please see the AUTHORS file |
| 2 | # for details. All rights reserved. Use of this source code is governed by a |
| 3 | # BSD-style license that can be found in the LICENSE file. |
| 4 | |
Ian Zerny | 0f5fc73 | 2018-11-15 14:34:41 +0100 | [diff] [blame] | 5 | import glob |
Christoffer Quist Adamsen | d7a5b72 | 2022-02-24 18:12:02 +0100 | [diff] [blame] | 6 | import time |
Mathias Rav | dd6a6de | 2018-05-18 10:18:33 +0200 | [diff] [blame] | 7 | import subprocess |
Jinseong Jeon | 158a3f1 | 2019-02-08 01:40:59 -0800 | [diff] [blame] | 8 | from threading import Timer |
Ian Zerny | e92325b | 2020-03-13 13:29:27 +0100 | [diff] [blame] | 9 | |
| 10 | import gradle |
| 11 | import jdk |
Mathias Rav | dd6a6de | 2018-05-18 10:18:33 +0200 | [diff] [blame] | 12 | import utils |
| 13 | |
Ian Zerny | e92325b | 2020-03-13 13:29:27 +0100 | [diff] [blame] | 14 | |
Mathias Rav | dd6a6de | 2018-05-18 10:18:33 +0200 | [diff] [blame] | 15 | def run(tool, args, build=None, debug=True, |
Rico Wind | 5fdec15 | 2018-12-17 09:16:14 +0100 | [diff] [blame] | 16 | profile=False, track_memory_file=None, extra_args=None, |
Søren Gjesse | 943389f | 2020-03-13 10:40:25 +0100 | [diff] [blame] | 17 | stderr=None, stdout=None, return_stdout=False, timeout=0, quiet=False, |
Christoffer Quist Adamsen | d7a5b72 | 2022-02-24 18:12:02 +0100 | [diff] [blame] | 18 | cmd_prefix=None, jar=None, main=None, time_consumer=None): |
Ian Zerny | e92325b | 2020-03-13 13:29:27 +0100 | [diff] [blame] | 19 | cmd = [] |
Søren Gjesse | c853feb | 2020-03-16 09:34:41 +0100 | [diff] [blame] | 20 | if cmd_prefix: |
| 21 | cmd.extend(cmd_prefix) |
Mathias Rav | dd6a6de | 2018-05-18 10:18:33 +0200 | [diff] [blame] | 22 | if build is None: |
| 23 | build, args = extract_build_from_args(args) |
| 24 | if build: |
Tamas Kenez | a730a7e | 2018-12-10 15:02:28 +0100 | [diff] [blame] | 25 | gradle.RunGradle(['r8lib' if tool.startswith('r8lib') else 'r8']) |
Mathias Rav | dd6a6de | 2018-05-18 10:18:33 +0200 | [diff] [blame] | 26 | if track_memory_file: |
| 27 | cmd.extend(['tools/track_memory.sh', track_memory_file]) |
Ian Zerny | 3f54e22 | 2019-02-12 10:51:17 +0100 | [diff] [blame] | 28 | cmd.append(jdk.GetJavaExecutable()) |
Mathias Rav | 56df69d | 2018-06-07 12:38:21 +0200 | [diff] [blame] | 29 | if extra_args: |
| 30 | cmd.extend(extra_args) |
Ian Zerny | ad5218a | 2021-01-21 16:07:58 +0100 | [diff] [blame] | 31 | agent, args = extract_debug_agent_from_args(args) |
| 32 | if agent: |
| 33 | cmd.append( |
| 34 | '-agentlib:jdwp=transport=dt_socket,server=y,suspend=y,address=*:5005') |
Mathias Rav | dd6a6de | 2018-05-18 10:18:33 +0200 | [diff] [blame] | 35 | if debug: |
| 36 | cmd.append('-ea') |
| 37 | if profile: |
| 38 | cmd.append('-agentlib:hprof=cpu=samples,interval=1,depth=8') |
Christoffer Quist Adamsen | 870fa46 | 2020-12-15 10:50:54 +0100 | [diff] [blame] | 39 | if jar: |
| 40 | cmd.extend(['-cp', jar, main]) |
| 41 | elif tool == 'r8lib-d8': |
Søren Gjesse | 95becbf | 2018-12-11 08:48:00 +0100 | [diff] [blame] | 42 | cmd.extend(['-cp', utils.R8LIB_JAR, 'com.android.tools.r8.D8']) |
Christoffer Quist Adamsen | 7ff1409 | 2021-04-15 11:48:12 +0200 | [diff] [blame] | 43 | elif tool == 'r8lib-l8': |
| 44 | cmd.extend(['-cp', utils.R8LIB_JAR, 'com.android.tools.r8.L8']) |
Tamas Kenez | a730a7e | 2018-12-10 15:02:28 +0100 | [diff] [blame] | 45 | elif tool == 'r8lib-r8': |
| 46 | cmd.extend(['-cp', utils.R8LIB_JAR, 'com.android.tools.r8.R8']) |
Søren Gjesse | 80e0048 | 2021-04-06 13:17:35 +0200 | [diff] [blame] | 47 | elif tool == 'r8lib-tracereferences': |
| 48 | cmd.extend(['-cp', utils.R8LIB_JAR, 'com.android.tools.r8.tracereferences.TraceReferences']) |
Tamas Kenez | a730a7e | 2018-12-10 15:02:28 +0100 | [diff] [blame] | 49 | else: |
Søren Gjesse | 95becbf | 2018-12-11 08:48:00 +0100 | [diff] [blame] | 50 | cmd.extend(['-jar', utils.R8_JAR, tool]) |
Søren Gjesse | c4e6a28 | 2018-10-04 12:37:03 +0200 | [diff] [blame] | 51 | lib, args = extract_lib_from_args(args) |
| 52 | if lib: |
| 53 | cmd.extend(["--lib", lib]) |
Mathias Rav | dd6a6de | 2018-05-18 10:18:33 +0200 | [diff] [blame] | 54 | cmd.extend(args) |
Morten Krogh-Jespersen | ae9557c | 2019-10-23 15:14:02 +0200 | [diff] [blame] | 55 | utils.PrintCmd(cmd, quiet=quiet) |
Christoffer Quist Adamsen | d7a5b72 | 2022-02-24 18:12:02 +0100 | [diff] [blame] | 56 | start = time.time() |
Jinseong Jeon | 158a3f1 | 2019-02-08 01:40:59 -0800 | [diff] [blame] | 57 | if timeout > 0: |
| 58 | kill = lambda process: process.kill() |
| 59 | proc = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE) |
| 60 | timer = Timer(timeout, kill, [proc]) |
| 61 | try: |
| 62 | timer.start() |
| 63 | stdout, stderr = proc.communicate() |
| 64 | finally: |
| 65 | timer.cancel() |
Christoffer Quist Adamsen | 4c6d15d | 2022-09-08 11:30:04 +0200 | [diff] [blame] | 66 | result = stdout.decode('utf-8') if return_stdout else proc.returncode |
Jinseong Jeon | 158a3f1 | 2019-02-08 01:40:59 -0800 | [diff] [blame] | 67 | else: |
Christoffer Quist Adamsen | d7a5b72 | 2022-02-24 18:12:02 +0100 | [diff] [blame] | 68 | result = ( |
Christoffer Quist Adamsen | 4c6d15d | 2022-09-08 11:30:04 +0200 | [diff] [blame] | 69 | subprocess.check_output(cmd).decode('utf-8') |
Christoffer Quist Adamsen | d7a5b72 | 2022-02-24 18:12:02 +0100 | [diff] [blame] | 70 | if return_stdout |
| 71 | else subprocess.call(cmd, stdout=stdout, stderr=stderr)) |
| 72 | duration = int((time.time() - start) * 1000) |
| 73 | if time_consumer: |
| 74 | time_consumer(duration) |
| 75 | return result |
Mathias Rav | dd6a6de | 2018-05-18 10:18:33 +0200 | [diff] [blame] | 76 | |
Ian Zerny | 0f5fc73 | 2018-11-15 14:34:41 +0100 | [diff] [blame] | 77 | def run_in_tests(tool, args, build=None, debug=True, extra_args=None): |
| 78 | if build is None: |
| 79 | build, args = extract_build_from_args(args) |
| 80 | if build: |
| 81 | gradle.RunGradle([ |
| 82 | 'copyMavenDeps', |
| 83 | 'compileTestJava', |
| 84 | ]) |
| 85 | cmd = [] |
Ian Zerny | 3f54e22 | 2019-02-12 10:51:17 +0100 | [diff] [blame] | 86 | cmd.append(jdk.GetJavaExecutable()) |
Ian Zerny | 0f5fc73 | 2018-11-15 14:34:41 +0100 | [diff] [blame] | 87 | if extra_args: |
| 88 | cmd.extend(extra_args) |
| 89 | if debug: |
| 90 | cmd.append('-ea') |
| 91 | cmd.extend(['-cp', ':'.join([ |
| 92 | utils.BUILD_MAIN_DIR, |
| 93 | utils.BUILD_TEST_DIR, |
| 94 | ] + glob.glob('%s/*.jar' % utils.BUILD_DEPS_DIR))]) |
| 95 | cmd.extend([tool]) |
| 96 | cmd.extend(args) |
| 97 | utils.PrintCmd(cmd) |
| 98 | return subprocess.call(cmd) |
| 99 | |
Mathias Rav | dd6a6de | 2018-05-18 10:18:33 +0200 | [diff] [blame] | 100 | def extract_build_from_args(input_args): |
| 101 | build = True |
| 102 | args = [] |
| 103 | for arg in input_args: |
| 104 | if arg in ("--build", "--no-build"): |
| 105 | build = arg == "--build" |
| 106 | else: |
| 107 | args.append(arg) |
| 108 | return build, args |
Søren Gjesse | c4e6a28 | 2018-10-04 12:37:03 +0200 | [diff] [blame] | 109 | |
| 110 | def extract_lib_from_args(input_args): |
| 111 | lib = None |
| 112 | args = [] |
| 113 | for arg in input_args: |
| 114 | if arg == '--lib-android': |
Søren Gjesse | 315b825 | 2018-12-13 16:28:42 +0100 | [diff] [blame] | 115 | lib = utils.get_android_jar(28) |
Søren Gjesse | c4e6a28 | 2018-10-04 12:37:03 +0200 | [diff] [blame] | 116 | elif arg == '--lib-java': |
| 117 | lib = utils.RT_JAR |
| 118 | else: |
| 119 | args.append(arg) |
| 120 | return lib, args |
Ian Zerny | ad5218a | 2021-01-21 16:07:58 +0100 | [diff] [blame] | 121 | |
| 122 | def extract_debug_agent_from_args(input_args): |
| 123 | agent = False |
| 124 | args = [] |
| 125 | for arg in input_args: |
| 126 | if arg in ('--debug-agent', '--debug_agent'): |
| 127 | agent = True |
| 128 | else: |
| 129 | args.append(arg) |
| 130 | return agent, args |