Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 1 | #!/bin/bash |
| 2 | |
| 3 | # Copyright 2024 Google Inc. All rights reserved. |
| 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 | ## Booting tests for ferrochrome |
| 18 | ## Keep this file synced with docs/custom_vm.md |
| 19 | |
| 20 | set -e |
| 21 | |
| 22 | FECR_GS_URL="https://storage.googleapis.com/chromiumos-image-archive/ferrochrome-public" |
Jaewan Kim | 4294ae1 | 2024-07-18 15:11:03 +0900 | [diff] [blame] | 23 | FECR_DEFAULT_VERSION="R128-15958.0.0" |
| 24 | FECR_TEST_IMAGE="chromiumos_test_image" |
| 25 | FECR_BASE_IMAGE="chromiumos_base_image" |
Jaewan Kim | 5ebeb22 | 2024-07-05 19:14:53 +0900 | [diff] [blame] | 26 | FECR_DEVICE_DIR="/data/local/tmp" |
Jaewan Kim | 4294ae1 | 2024-07-18 15:11:03 +0900 | [diff] [blame] | 27 | FECR_IMAGE_VM_CONFIG_JSON="chromiumos_base_image.bin" # hardcoded at vm_config.json |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 28 | FECR_CONFIG_PATH="/data/local/tmp/vm_config.json" # hardcoded at VmLauncherApp |
| 29 | FECR_CONSOLE_LOG_PATH="/data/data/\${pkg_name}/files/console.log" |
Jaewan Kim | 4294ae1 | 2024-07-18 15:11:03 +0900 | [diff] [blame] | 30 | FECR_TEST_IMAGE_BOOT_COMPLETED_LOG="Have fun and send patches!" |
| 31 | FECR_BASE_IMAGE_BOOT_COMPLETED_LOG="Chrome started, our work is done, exiting" |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 32 | FECR_BOOT_TIMEOUT="300" # 5 minutes (300 seconds) |
Jaewan Kim | 3ad58c3 | 2024-06-13 08:59:29 +0000 | [diff] [blame] | 33 | ACTION_NAME="android.virtualization.VM_LAUNCHER" |
Jaewan Kim | 4294ae1 | 2024-07-18 15:11:03 +0900 | [diff] [blame] | 34 | |
| 35 | # Match this with AndroidTest.xml and assets/vm_config.json |
| 36 | FECR_DEFAULT_IMAGE="${FECR_BASE_IMAGE}" |
| 37 | FECR_DEFAULT_BOOT_COMPLETED_LOG="${FECR_BASE_IMAGE_BOOT_COMPLETED_LOG}" |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 38 | |
| 39 | fecr_clean_up() { |
| 40 | trap - INT |
| 41 | |
Jaewan Kim | 8b82b4b | 2024-07-18 21:03:43 +0900 | [diff] [blame] | 42 | # Reset screen always on |
| 43 | adb shell svc power stayon false |
| 44 | |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 45 | if [[ -d ${fecr_dir} && -z ${fecr_keep} ]]; then |
| 46 | rm -rf ${fecr_dir} |
| 47 | fi |
| 48 | } |
| 49 | |
| 50 | print_usage() { |
Jaewan Kim | 3ad58c3 | 2024-06-13 08:59:29 +0000 | [diff] [blame] | 51 | echo "ferochrome: Launches ferrochrome image" |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 52 | echo "" |
Jaewan Kim | 4294ae1 | 2024-07-18 15:11:03 +0900 | [diff] [blame] | 53 | echo "By default, this downloads ${FECR_DEFAULT_VERSION} with version ${FECR_DEFAULT_VERSION}," |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 54 | echo "launches, and waits for boot completed." |
Jaewan Kim | 3ad58c3 | 2024-06-13 08:59:29 +0000 | [diff] [blame] | 55 | echo "When done, removes downloaded image on host while keeping pushed image on device." |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 56 | echo "" |
Jaewan Kim | 3ad58c3 | 2024-06-13 08:59:29 +0000 | [diff] [blame] | 57 | echo "Usage: ferrochrome [options]" |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 58 | echo "" |
| 59 | echo "Options" |
| 60 | echo " --help or -h: This message" |
Jaewan Kim | 3ad58c3 | 2024-06-13 08:59:29 +0000 | [diff] [blame] | 61 | echo " --dir DIR: Use ferrochrome images at the dir instead of downloading" |
| 62 | echo " --verbose: Verbose log message (set -x)" |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 63 | echo " --skip: Skipping downloading and/or pushing images" |
| 64 | echo " --version \${version}: ferrochrome version to be downloaded" |
| 65 | echo " --keep: Keep downloaded ferrochrome image" |
Jaewan Kim | 4294ae1 | 2024-07-18 15:11:03 +0900 | [diff] [blame] | 66 | echo " --test: Download test image instead" |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 67 | } |
| 68 | |
Jaewan Kim | 4294ae1 | 2024-07-18 15:11:03 +0900 | [diff] [blame] | 69 | fecr_version="${FECR_DEFAULT_VERSION}" |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 70 | fecr_dir="" |
| 71 | fecr_keep="" |
| 72 | fecr_skip="" |
| 73 | fecr_script_path=$(dirname ${0}) |
Jaewan Kim | 3ad58c3 | 2024-06-13 08:59:29 +0000 | [diff] [blame] | 74 | fecr_verbose="" |
Jaewan Kim | 4294ae1 | 2024-07-18 15:11:03 +0900 | [diff] [blame] | 75 | fecr_image="${FECR_DEFAULT_IMAGE}" |
| 76 | fecr_boot_completed_log="${FECR_DEFAULT_BOOT_COMPLETED_LOG}" |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 77 | |
| 78 | # Parse parameters |
| 79 | while (( "${#}" )); do |
| 80 | case "${1}" in |
Jaewan Kim | 3ad58c3 | 2024-06-13 08:59:29 +0000 | [diff] [blame] | 81 | --verbose) |
| 82 | fecr_verbose="true" |
| 83 | ;; |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 84 | --version) |
| 85 | shift |
| 86 | fecr_version="${1}" |
| 87 | ;; |
| 88 | --dir) |
| 89 | shift |
| 90 | fecr_dir="${1}" |
| 91 | fecr_keep="true" |
| 92 | ;; |
| 93 | --keep) |
| 94 | fecr_keep="true" |
| 95 | ;; |
| 96 | --skip) |
| 97 | fecr_skip="true" |
| 98 | ;; |
Jaewan Kim | 4294ae1 | 2024-07-18 15:11:03 +0900 | [diff] [blame] | 99 | --test) |
| 100 | fecr_image="${FECR_TEST_IMAGE}" |
| 101 | fecr_boot_completed_log="${FECR_TEST_IMAGE_BOOT_COMPLETED_LOG}" |
| 102 | ;; |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 103 | -h|--help) |
| 104 | print_usage |
| 105 | exit 0 |
| 106 | ;; |
| 107 | *) |
| 108 | print_usage |
| 109 | exit 1 |
| 110 | ;; |
| 111 | esac |
| 112 | shift |
| 113 | done |
| 114 | |
| 115 | trap fecr_clean_up INT |
| 116 | trap fecr_clean_up EXIT |
| 117 | |
Jaewan Kim | 3ad58c3 | 2024-06-13 08:59:29 +0000 | [diff] [blame] | 118 | if [[ -n "${fecr_verbose}" ]]; then |
| 119 | set -x |
| 120 | fi |
| 121 | |
| 122 | . "${fecr_script_path}/ferrochrome-precondition-checker.sh" |
| 123 | |
| 124 | resolved_activities=$(adb shell pm query-activities --components -a ${ACTION_NAME}) |
| 125 | |
| 126 | if [[ "$(echo ${resolved_activities} | wc -l)" != "1" ]]; then |
| 127 | >&2 echo "Multiple VM launchers exists" |
| 128 | exit 1 |
| 129 | fi |
| 130 | |
| 131 | pkg_name=$(dirname ${resolved_activities}) |
| 132 | |
| 133 | adb shell pm grant ${pkg_name} android.permission.USE_CUSTOM_VIRTUAL_MACHINE > /dev/null |
| 134 | adb shell pm clear ${pkg_name} > /dev/null |
| 135 | |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 136 | if [[ -z "${fecr_skip}" ]]; then |
| 137 | if [[ -z "${fecr_dir}" ]]; then |
| 138 | # Download fecr image archive, and extract necessary files |
| 139 | # DISCLAIMER: Image is too large (1.5G+ for compressed, 6.5G+ for uncompressed), so can't submit. |
| 140 | fecr_dir=$(mktemp -d) |
| 141 | |
Jaewan Kim | 94455ba | 2024-06-18 14:22:44 +0900 | [diff] [blame] | 142 | echo "Downloading & extracting ferrochrome image to ${fecr_dir}" |
Jaewan Kim | 4294ae1 | 2024-07-18 15:11:03 +0900 | [diff] [blame] | 143 | curl ${FECR_GS_URL}/${fecr_version}/${fecr_image}.tar.xz | tar xfJ - -C ${fecr_dir} |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 144 | fi |
| 145 | |
| 146 | echo "Pushing ferrochrome image to ${FECR_DEVICE_DIR}" |
| 147 | adb shell mkdir -p ${FECR_DEVICE_DIR} > /dev/null || true |
Jaewan Kim | 4294ae1 | 2024-07-18 15:11:03 +0900 | [diff] [blame] | 148 | adb push ${fecr_dir}/${fecr_image}.bin ${FECR_DEVICE_DIR}/${FECR_IMAGE_VM_CONFIG_JSON} |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 149 | adb push ${fecr_script_path}/assets/vm_config.json ${FECR_CONFIG_PATH} |
| 150 | fi |
| 151 | |
Jaewan Kim | 920d466 | 2024-07-09 05:02:36 +0000 | [diff] [blame] | 152 | echo "Ensure screen unlocked" |
Jaewan Kim | 8b82b4b | 2024-07-18 21:03:43 +0900 | [diff] [blame] | 153 | adb shell svc power stayon true |
| 154 | adb shell wm dismiss-keyguard |
Jaewan Kim | 920d466 | 2024-07-09 05:02:36 +0000 | [diff] [blame] | 155 | |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 156 | echo "Starting ferrochrome" |
Jaewan Kim | 3ad58c3 | 2024-06-13 08:59:29 +0000 | [diff] [blame] | 157 | adb shell am start-activity -a ${ACTION_NAME} > /dev/null |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 158 | |
Jaewan Kim | 56f3834 | 2024-07-03 07:54:15 +0000 | [diff] [blame] | 159 | if [[ $(adb shell getprop ro.fw.mu.headless_system_user) == "true" ]]; then |
| 160 | current_user=$(adb shell am get-current-user) |
| 161 | log_path="/data/user/${current_user}/${pkg_name}/files/console.log" |
| 162 | else |
| 163 | log_path="/data/data/${pkg_name}/files/console.log" |
| 164 | fi |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 165 | fecr_start_time=${EPOCHSECONDS} |
| 166 | |
| 167 | while [[ $((EPOCHSECONDS - fecr_start_time)) -lt ${FECR_BOOT_TIMEOUT} ]]; do |
Jaewan Kim | 4294ae1 | 2024-07-18 15:11:03 +0900 | [diff] [blame] | 168 | adb shell grep -soF \""${fecr_boot_completed_log}"\" "${log_path}" && exit 0 || true |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 169 | sleep 10 |
| 170 | done |
| 171 | |
Jaewan Kim | 3ad58c3 | 2024-06-13 08:59:29 +0000 | [diff] [blame] | 172 | >&2 echo "Ferrochrome failed to boot. Dumping console log" |
| 173 | >&2 adb shell cat ${log_path} |
| 174 | |
Jaewan Kim | b5fb969 | 2024-06-10 14:18:12 +0900 | [diff] [blame] | 175 | exit 1 |
Jaewan Kim | 4294ae1 | 2024-07-18 15:11:03 +0900 | [diff] [blame] | 176 | |