Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 1 | #!/bin/bash |
| 2 | |
| 3 | # Copyright (C) 2018 The Android Open Source Project |
| 4 | # |
| 5 | # Licensed under the Apache License, Version 2.0 (the "License"); |
| 6 | # you may not use this file except in compliance with the License. |
| 7 | # You may obtain a copy of the License at |
| 8 | # |
| 9 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 10 | # |
| 11 | # Unless required by applicable law or agreed to in writing, software |
| 12 | # distributed under the License is distributed on an "AS IS" BASIS, |
| 13 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 14 | # See the License for the specific language governing permissions and |
| 15 | # limitations under the License. |
| 16 | # |
| 17 | |
| 18 | # Run Android Runtime APEX tests. |
| 19 | |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 20 | # Status of whole test script. |
| 21 | exit_status=0 |
| 22 | # Status of current test suite. |
| 23 | test_status=0 |
| 24 | |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 25 | function say { |
| 26 | echo "$0: $*" |
| 27 | } |
| 28 | |
| 29 | function die { |
| 30 | echo "$0: $*" |
| 31 | exit 1 |
| 32 | } |
| 33 | |
| 34 | which guestmount >/dev/null && which guestunmount >/dev/null && which virt-filesystems >/dev/null \ |
| 35 | || die "This script requires 'guestmount', 'guestunmount', |
| 36 | and 'virt-filesystems' from libguestfs. On Debian-based systems, these tools |
| 37 | can be installed with: |
| 38 | |
| 39 | sudo apt-get install libguestfs-tools |
| 40 | " |
Pete Bentley | f34e743 | 2018-12-11 18:12:25 +0000 | [diff] [blame] | 41 | |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 42 | [[ -n "$ANDROID_PRODUCT_OUT" ]] \ |
| 43 | || die "You need to source and lunch before you can use this script." |
| 44 | |
| 45 | # Fail early. |
| 46 | set -e |
| 47 | |
| 48 | build_apex_p=true |
| 49 | list_image_files_p=false |
Roland Levillain | 04e83d1 | 2018-11-16 15:03:47 +0000 | [diff] [blame] | 50 | print_image_tree_p=false |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 51 | |
| 52 | function usage { |
| 53 | cat <<EOF |
| 54 | Usage: $0 [OPTION] |
| 55 | Build (optional) and run tests on Android Runtime APEX package (on host). |
| 56 | |
| 57 | -s, --skip-build skip the build step |
Roland Levillain | 04e83d1 | 2018-11-16 15:03:47 +0000 | [diff] [blame] | 58 | -l, --list-files list the contents of the ext4 image using `find` |
| 59 | -t, --print-tree list the contents of the ext4 image using `tree` |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 60 | -h, --help display this help and exit |
| 61 | |
| 62 | EOF |
| 63 | exit |
| 64 | } |
| 65 | |
| 66 | while [[ $# -gt 0 ]]; do |
| 67 | case "$1" in |
| 68 | (-s|--skip-build) build_apex_p=false;; |
| 69 | (-l|--list-files) list_image_files_p=true;; |
Roland Levillain | 04e83d1 | 2018-11-16 15:03:47 +0000 | [diff] [blame] | 70 | (-t|--print-tree) print_image_tree_p=true;; |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 71 | (-h|--help) usage;; |
| 72 | (*) die "Unknown option: '$1' |
| 73 | Try '$0 --help' for more information.";; |
| 74 | esac |
| 75 | shift |
| 76 | done |
| 77 | |
Roland Levillain | 04e83d1 | 2018-11-16 15:03:47 +0000 | [diff] [blame] | 78 | if $print_image_tree_p; then |
| 79 | which tree >/dev/null || die "This script requires the 'tree' tool. |
| 80 | On Debian-based systems, this can be installed with: |
| 81 | |
| 82 | sudo apt-get install tree |
| 83 | " |
| 84 | fi |
| 85 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 86 | |
| 87 | # build_apex APEX_MODULE |
| 88 | # ---------------------- |
| 89 | # Build APEX package APEX_MODULE. |
| 90 | function build_apex { |
| 91 | if $build_apex_p; then |
| 92 | local apex_module=$1 |
| 93 | say "Building package $apex_module" && make "$apex_module" || die "Cannot build $apex_module" |
| 94 | fi |
| 95 | } |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 96 | |
Roland Levillain | 04e83d1 | 2018-11-16 15:03:47 +0000 | [diff] [blame] | 97 | # maybe_list_apex_contents MOUNT_POINT |
| 98 | # ------------------------------------ |
| 99 | # If any listing/printing option was used, honor them and display the contents |
| 100 | # of the APEX payload at MOUNT_POINT. |
| 101 | function maybe_list_apex_contents { |
| 102 | local mount_point=$1 |
| 103 | |
| 104 | # List the contents of the mounted image using `find` (optional). |
| 105 | if $list_image_files_p; then |
| 106 | say "Listing image files" && find "$mount_point" |
| 107 | fi |
| 108 | |
| 109 | # List the contents of the mounted image using `tree` (optional). |
| 110 | if $print_image_tree_p; then |
| 111 | say "Printing image tree" && ls -ld "$mount_point" && tree -aph --du "$mount_point" |
| 112 | fi |
| 113 | } |
| 114 | |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 115 | function fail_check { |
| 116 | echo "$0: FAILED: $*" |
| 117 | test_status=1 |
| 118 | exit_status=1 |
| 119 | } |
| 120 | |
| 121 | function check_file { |
| 122 | [[ -f "$mount_point/$1" ]] || fail_check "Cannot find file '$1' in mounted image" |
| 123 | } |
| 124 | |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 125 | function check_binary { |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 126 | [[ -x "$mount_point/bin/$1" ]] || fail_check "Cannot find binary '$1' in mounted image" |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 127 | } |
| 128 | |
| 129 | function check_multilib_binary { |
| 130 | # TODO: Use $TARGET_ARCH (e.g. check whether it is "arm" or "arm64") to improve |
| 131 | # the precision of this test? |
| 132 | [[ -x "$mount_point/bin/${1}32" ]] || [[ -x "$mount_point/bin/${1}64" ]] \ |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 133 | || fail_check "Cannot find binary '$1' in mounted image" |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 134 | } |
| 135 | |
| 136 | function check_binary_symlink { |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 137 | [[ -h "$mount_point/bin/$1" ]] || fail_check "Cannot find symbolic link '$1' in mounted image" |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 138 | } |
| 139 | |
| 140 | function check_library { |
| 141 | # TODO: Use $TARGET_ARCH (e.g. check whether it is "arm" or "arm64") to improve |
| 142 | # the precision of this test? |
| 143 | [[ -f "$mount_point/lib/$1" ]] || [[ -f "$mount_point/lib64/$1" ]] \ |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 144 | || fail_check "Cannot find library '$1' in mounted image" |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 145 | } |
| 146 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 147 | # Check contents of APEX payload located in `$mount_point`. |
| 148 | function check_release_contents { |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 149 | # Check that the mounted image contains an APEX manifest. |
| 150 | check_file apex_manifest.json |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 151 | |
| 152 | # Check that the mounted image contains ART base binaries. |
| 153 | check_multilib_binary dalvikvm |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 154 | # TODO: Does not work yet (b/119942078). |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 155 | : check_binary_symlink dalvikvm |
| 156 | check_binary dex2oat |
| 157 | check_binary dexoptanalyzer |
| 158 | check_binary profman |
| 159 | |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 160 | # oatdump is only in device apex's due to build rules |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 161 | # TODO: Check for it when it is also built for host. |
| 162 | : check_binary oatdump |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 163 | |
Roland Levillain | 8d3d491 | 2019-01-07 15:19:50 +0000 | [diff] [blame] | 164 | # Check that the mounted image contains Android Runtime libraries. |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 165 | check_library libart-compiler.so |
Roland Levillain | 8d3d491 | 2019-01-07 15:19:50 +0000 | [diff] [blame] | 166 | check_library libart-dexlayout.so |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 167 | check_library libart.so |
Roland Levillain | 8d3d491 | 2019-01-07 15:19:50 +0000 | [diff] [blame] | 168 | check_library libartbase.so |
| 169 | check_library libdexfile.so |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 170 | check_library libopenjdkjvm.so |
| 171 | check_library libopenjdkjvmti.so |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 172 | check_library libprofile.so |
Roland Levillain | 8d3d491 | 2019-01-07 15:19:50 +0000 | [diff] [blame] | 173 | # Check that the mounted image contains Android Core libraries. |
| 174 | check_library libjavacrypto.so |
Roland Levillain | cb82d09 | 2018-11-02 18:50:15 +0000 | [diff] [blame] | 175 | check_library libopenjdk.so |
Roland Levillain | 8d3d491 | 2019-01-07 15:19:50 +0000 | [diff] [blame] | 176 | # Check that the mounted image contains additional required libraries. |
| 177 | check_library libadbconnection.so |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 178 | |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 179 | # TODO: Should we check for other libraries, such as: |
| 180 | # |
| 181 | # libbacktrace.so |
| 182 | # libbase.so |
| 183 | # liblog.so |
| 184 | # libsigchain.so |
| 185 | # libtombstoned_client.so |
| 186 | # libunwindstack.so |
| 187 | # libvixl.so |
| 188 | # libvixld.so |
| 189 | # ... |
| 190 | # |
| 191 | # ? |
| 192 | } |
| 193 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 194 | # Check debug contents of APEX payload located in `$mount_point`. |
| 195 | function check_debug_contents { |
| 196 | # Check that the mounted image contains ART tools binaries. |
| 197 | check_binary dexdiag |
| 198 | check_binary dexdump |
| 199 | check_binary dexlist |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 200 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 201 | # Check that the mounted image contains ART debug binaries. |
| 202 | check_binary dex2oatd |
| 203 | check_binary dexoptanalyzerd |
| 204 | check_binary profmand |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 205 | |
Roland Levillain | 8d3d491 | 2019-01-07 15:19:50 +0000 | [diff] [blame] | 206 | # Check that the mounted image contains Android Runtime debug libraries. |
| 207 | check_library libartbased.so |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 208 | check_library libartd-compiler.so |
Roland Levillain | 8d3d491 | 2019-01-07 15:19:50 +0000 | [diff] [blame] | 209 | check_library libartd-dexlayout.so |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 210 | check_library libartd.so |
Roland Levillain | 8d3d491 | 2019-01-07 15:19:50 +0000 | [diff] [blame] | 211 | check_library libdexfiled.so |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 212 | check_library libopenjdkjvmd.so |
| 213 | check_library libopenjdkjvmtid.so |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 214 | check_library libprofiled.so |
Roland Levillain | cb82d09 | 2018-11-02 18:50:15 +0000 | [diff] [blame] | 215 | # Check that the mounted image contains Android Core debug libraries. |
| 216 | check_library libopenjdkd.so |
| 217 | # Check that the mounted image contains additional required debug libraries. |
Roland Levillain | 8d3d491 | 2019-01-07 15:19:50 +0000 | [diff] [blame] | 218 | check_library libadbconnectiond.so |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 219 | } |
| 220 | |
| 221 | # Testing target (device) APEX packages. |
| 222 | # ====================================== |
| 223 | |
| 224 | # Clean-up. |
| 225 | function cleanup_target { |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 226 | guestunmount "$mount_point" |
| 227 | rm -rf "$work_dir" |
| 228 | } |
| 229 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 230 | # Garbage collection. |
| 231 | function finish_target { |
| 232 | # Don't fail early during cleanup. |
| 233 | set +e |
| 234 | cleanup_target |
| 235 | } |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 236 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 237 | # setup_target_apex APEX_MODULE MOUNT_POINT |
| 238 | # ----------------------------------------- |
| 239 | # Extract image from target APEX_MODULE and mount it in MOUNT_POINT. |
| 240 | function setup_target_apex { |
| 241 | local apex_module=$1 |
| 242 | local mount_point=$2 |
| 243 | local system_apexdir="$ANDROID_PRODUCT_OUT/system/apex" |
| 244 | local apex_package="$system_apexdir/$apex_module.apex" |
| 245 | |
| 246 | say "Extracting and mounting image" |
| 247 | |
| 248 | # Extract the payload from the Android Runtime APEX. |
| 249 | local image_filename="apex_payload.img" |
| 250 | unzip -q "$apex_package" "$image_filename" -d "$work_dir" |
| 251 | mkdir "$mount_point" |
| 252 | local image_file="$work_dir/$image_filename" |
| 253 | |
| 254 | # Check filesystems in the image. |
| 255 | local image_filesystems="$work_dir/image_filesystems" |
| 256 | virt-filesystems -a "$image_file" >"$image_filesystems" |
| 257 | # We expect a single partition (/dev/sda) in the image. |
| 258 | local partition="/dev/sda" |
| 259 | echo "$partition" | cmp "$image_filesystems" - |
| 260 | |
| 261 | # Mount the image from the Android Runtime APEX. |
| 262 | guestmount -a "$image_file" -m "$partition" "$mount_point" |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 263 | } |
| 264 | |
| 265 | # Testing release APEX package (com.android.runtime.release). |
| 266 | # ----------------------------------------------------------- |
| 267 | |
| 268 | apex_module="com.android.runtime.release" |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 269 | test_status=0 |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 270 | |
Roland Levillain | 04e83d1 | 2018-11-16 15:03:47 +0000 | [diff] [blame] | 271 | say "Processing APEX package $apex_module" |
| 272 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 273 | work_dir=$(mktemp -d) |
| 274 | mount_point="$work_dir/image" |
| 275 | |
| 276 | trap finish_target EXIT |
| 277 | |
| 278 | # Build the APEX package (optional). |
| 279 | build_apex "$apex_module" |
| 280 | |
| 281 | # Set up APEX package. |
| 282 | setup_target_apex "$apex_module" "$mount_point" |
| 283 | |
Roland Levillain | 04e83d1 | 2018-11-16 15:03:47 +0000 | [diff] [blame] | 284 | # List the contents of the APEX image (optional). |
| 285 | maybe_list_apex_contents "$mount_point" |
| 286 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 287 | # Run tests on APEX package. |
| 288 | say "Checking APEX package $apex_module" |
| 289 | check_release_contents |
| 290 | |
| 291 | # Clean up. |
| 292 | trap - EXIT |
| 293 | cleanup_target |
| 294 | |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 295 | [[ "$test_status" = 0 ]] && say "$apex_module tests passed" |
Roland Levillain | 04e83d1 | 2018-11-16 15:03:47 +0000 | [diff] [blame] | 296 | echo |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 297 | |
| 298 | # Testing debug APEX package (com.android.runtime.debug). |
| 299 | # ------------------------------------------------------- |
| 300 | |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 301 | apex_module="com.android.runtime.debug" |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 302 | test_status=0 |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 303 | |
Roland Levillain | 04e83d1 | 2018-11-16 15:03:47 +0000 | [diff] [blame] | 304 | say "Processing APEX package $apex_module" |
| 305 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 306 | work_dir=$(mktemp -d) |
| 307 | mount_point="$work_dir/image" |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 308 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 309 | trap finish_target EXIT |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 310 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 311 | # Build the APEX package (optional). |
| 312 | build_apex "$apex_module" |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 313 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 314 | # Set up APEX package. |
| 315 | setup_target_apex "$apex_module" "$mount_point" |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 316 | |
Roland Levillain | 04e83d1 | 2018-11-16 15:03:47 +0000 | [diff] [blame] | 317 | # List the contents of the APEX image (optional). |
| 318 | maybe_list_apex_contents "$mount_point" |
| 319 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 320 | # Run tests on APEX package. |
| 321 | say "Checking APEX package $apex_module" |
| 322 | check_release_contents |
| 323 | check_debug_contents |
| 324 | # Check for files pulled in from debug target-only oatdump. |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 325 | check_binary oatdump |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 326 | check_library libart-disassembler.so |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 327 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 328 | # Clean up. |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 329 | trap - EXIT |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 330 | cleanup_target |
Roland Levillain | 38a938e | 2018-09-21 10:55:51 +0100 | [diff] [blame] | 331 | |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 332 | [[ "$test_status" = 0 ]] && say "$apex_module tests passed" |
Roland Levillain | 04e83d1 | 2018-11-16 15:03:47 +0000 | [diff] [blame] | 333 | echo |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 334 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 335 | |
| 336 | # Testing host APEX package (com.android.runtime.host). |
| 337 | # ===================================================== |
| 338 | |
| 339 | # Clean-up. |
| 340 | function cleanup_host { |
| 341 | rm -rf "$work_dir" |
| 342 | } |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 343 | |
| 344 | # Garbage collection. |
| 345 | function finish_host { |
| 346 | # Don't fail early during cleanup. |
| 347 | set +e |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 348 | cleanup_host |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 349 | } |
| 350 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 351 | # setup_host_apex APEX_MODULE MOUNT_POINT |
| 352 | # --------------------------------------- |
| 353 | # Extract Zip file from host APEX_MODULE and extract it in MOUNT_POINT. |
| 354 | function setup_host_apex { |
| 355 | local apex_module=$1 |
| 356 | local mount_point=$2 |
| 357 | local system_apexdir="$ANDROID_HOST_OUT/apex" |
| 358 | local apex_package="$system_apexdir/$apex_module.zipapex" |
| 359 | |
| 360 | say "Extracting payload" |
| 361 | |
| 362 | # Extract the payload from the Android Runtime APEX. |
| 363 | local image_filename="apex_payload.zip" |
| 364 | unzip -q "$apex_package" "$image_filename" -d "$work_dir" |
| 365 | mkdir "$mount_point" |
| 366 | local image_file="$work_dir/$image_filename" |
| 367 | |
| 368 | # Unzipping the payload |
| 369 | unzip -q "$image_file" -d "$mount_point" |
| 370 | } |
| 371 | |
| 372 | apex_module="com.android.runtime.host" |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 373 | test_status=0 |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 374 | |
Roland Levillain | 04e83d1 | 2018-11-16 15:03:47 +0000 | [diff] [blame] | 375 | say "Processing APEX package $apex_module" |
| 376 | |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 377 | work_dir=$(mktemp -d) |
| 378 | mount_point="$work_dir/zip" |
| 379 | |
| 380 | trap finish_host EXIT |
| 381 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 382 | # Build the APEX package (optional). |
| 383 | build_apex "$apex_module" |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 384 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 385 | # Set up APEX package. |
| 386 | setup_host_apex "$apex_module" "$mount_point" |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 387 | |
Roland Levillain | 04e83d1 | 2018-11-16 15:03:47 +0000 | [diff] [blame] | 388 | # List the contents of the APEX image (optional). |
| 389 | maybe_list_apex_contents "$mount_point" |
| 390 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 391 | # Run tests on APEX package. |
| 392 | say "Checking APEX package $apex_module" |
| 393 | check_release_contents |
| 394 | check_debug_contents |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 395 | |
Roland Levillain | 996f42f | 2018-12-11 15:26:51 +0000 | [diff] [blame] | 396 | # Clean up. |
| 397 | trap - EXIT |
| 398 | cleanup_host |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 399 | |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 400 | [[ "$test_status" = 0 ]] && say "$apex_module tests passed" |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 401 | |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 402 | [[ "$exit_status" = 0 ]] && say "All Android Runtime APEX tests passed" |
Alex Light | da948ce | 2018-12-06 17:05:41 +0000 | [diff] [blame] | 403 | |
Roland Levillain | 43c08d2 | 2019-01-18 18:58:47 +0000 | [diff] [blame^] | 404 | exit $exit_status |