summaryrefslogtreecommitdiff
path: root/test/900-hello-plugin
diff options
context:
space:
mode:
Diffstat (limited to 'test/900-hello-plugin')
-rwxr-xr-xtest/900-hello-plugin/run45
-rw-r--r--test/900-hello-plugin/run.py39
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}"])