diff options
Diffstat (limited to 'test/900-hello-plugin')
| -rwxr-xr-x | test/900-hello-plugin/run | 45 | ||||
| -rw-r--r-- | test/900-hello-plugin/run.py | 39 |
2 files changed, 39 insertions, 45 deletions
diff --git a/test/900-hello-plugin/run b/test/900-hello-plugin/run deleted file mode 100755 index a19a38cd95..0000000000 --- a/test/900-hello-plugin/run +++ /dev/null @@ -1,45 +0,0 @@ -#!/bin/bash -# -# Copyright 2016 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. - -plugin=libartagentd.so -if [[ "$@" == *"-O"* ]]; then - plugin=libartagent.so -fi - -# Adjust the agent path when running on device. -if [[ "$@" != *"--host"* ]]; then - if [[ -z "$ANDROID_BUILD_TOP" ]]; then - echo 'ANDROID_BUILD_TOP environment variable is empty; did you forget to run `lunch`?' - exit 1 - fi - - bitness_flag=--32 - if [[ "$@" == *"--64"* ]]; then - bitness_flag=--64 - fi - - # Path to native libraries installed on the device for testing purposes. - test_native_lib_path=$("$ANDROID_BUILD_TOP/art/test/utils/get-device-test-native-lib-path" \ - "$bitness_flag") - - # The linker configuration used for dalvikvm(64) in the ART APEX requires us - # to pass the full path to the agent to the runtime when running on device. - plugin=${test_native_lib_path}/${plugin} -fi - -./default-run "$@" --runtime-option -agentpath:${plugin}=test_900 \ - --runtime-option -agentpath:${plugin}=test_900_round_2 \ - --android-runtime-option -Xplugin:${plugin} diff --git a/test/900-hello-plugin/run.py b/test/900-hello-plugin/run.py new file mode 100644 index 0000000000..607a0e5d40 --- /dev/null +++ b/test/900-hello-plugin/run.py @@ -0,0 +1,39 @@ +#!/bin/bash +# +# Copyright 2016 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. + + +def run(ctx, args): + plugin = "libartagent.so" if args.O else "libartagentd.so" + + # Adjust the agent path when running on device. + if not args.host: + for i, opt in enumerate(args.runtime_option): + if opt.startswith("-Djava.library.path="): + libpath = opt.split("=")[-1] + assert libpath.startswith("/data/nativetest"), libpath + + # The linker configuration used for dalvikvm(64) in the ART APEX requires us + # to pass the full path to the agent to the runtime when running on device. + plugin = f"{libpath}/{plugin}" + break + + ctx.default_run( + args, + runtime_option=[ + f"-agentpath:{plugin}=test_900", + f"-agentpath:{plugin}=test_900_round_2" + ], + android_runtime_option=[f"-Xplugin:{plugin}"]) |