Magisk/scripts/avd.sh

238 lines
4.5 KiB
Bash
Raw Normal View History

2022-03-18 04:56:19 -07:00
#!/usr/bin/env bash
2025-05-15 02:28:25 -07:00
set -e
. scripts/test_common.sh
2025-04-13 21:43:11 -07:00
emu_port=5682
export ANDROID_SERIAL="emulator-$emu_port"
emu_args_base="-no-window -no-audio -no-boot-anim -gpu swiftshader_indirect -read-only -no-snapshot -port $emu_port -cores $core_count"
2025-05-15 02:28:25 -07:00
log_args="-show-kernel -logcat '' -logcat-output logcat.log"
emu_args=
2023-10-11 22:42:45 -07:00
emu_pid=
2022-03-18 04:56:19 -07:00
2023-11-16 14:29:45 -08:00
atd_min_api=30
2024-12-02 15:13:29 -08:00
atd_max_api=35
2024-01-28 00:46:03 -08:00
huge_ram_min_api=26
2022-09-15 19:45:58 -07:00
2025-05-15 02:28:25 -07:00
case $(uname -m) in
'arm64'|'aarch64')
if [ -n "$FORCE_32_BIT" ]; then
echo "! ARM32 is not supported"
exit 1
fi
arch=arm64-v8a
;;
*)
if [ -n "$FORCE_32_BIT" ]; then
arch=x86
else
arch=x86_64
fi
2022-09-15 19:45:58 -07:00
2025-05-15 02:28:25 -07:00
;;
esac
cleanup() {
2023-05-09 23:11:11 -07:00
pkill -INT -P $$
wait
2023-10-11 22:42:45 -07:00
trap - EXIT
2025-05-15 02:28:25 -07:00
rm -f magisk_*.img
"$avd" delete avd -n test
2023-10-11 22:42:45 -07:00
exit 1
}
2025-05-15 02:28:25 -07:00
test_error() {
print_error "! An error occurred"
cleanup
}
2022-03-18 04:56:19 -07:00
wait_for_boot() {
2024-12-02 15:13:29 -08:00
set -e
2023-05-09 23:11:11 -07:00
adb wait-for-device
2022-03-18 04:56:19 -07:00
while true; do
2023-10-11 22:42:45 -07:00
local result="$(adb exec-out getprop sys.boot_completed)"
if [ $? -ne 0 ]; then
exit 1
elif [ "$result" = "1" ]; then
2022-03-18 04:56:19 -07:00
break
fi
sleep 2
done
}
wait_emu() {
local which_pid
timeout $boot_timeout bash -c wait_for_boot &
local wait_pid=$!
2023-10-24 16:45:24 -07:00
# Handle the case when emulator dies earlier than timeout
wait -p which_pid -n $emu_pid $wait_pid
[ $which_pid -eq $wait_pid ]
}
2025-05-15 02:28:25 -07:00
dump_vars() {
local val
for name in $@; do
eval val=\$$name
echo $name=\"$val\"\;
done
2023-10-11 22:42:45 -07:00
}
2025-05-15 02:28:25 -07:00
resolve_vars() {
local arg_list="$1"
local ver=$2
local type=$3
2024-06-20 18:25:49 -07:00
# Determine API level
local api
case $ver in
[0-9]*) api=$ver ;;
TiramisuPrivacySandbox) api=33 ;;
UpsideDownCakePrivacySandbox) api=34 ;;
VanillaIceCream) api=35 ;;
2024-12-02 15:13:29 -08:00
Baklava) api=36 ;;
2024-06-20 18:25:49 -07:00
*)
print_error "! Unknown system image version '$ver'"
exit 1
;;
esac
2025-05-15 02:28:25 -07:00
# Determine default image type
2024-06-20 18:25:49 -07:00
if [ -z $type ]; then
if [ $api -ge $atd_min_api -a $api -le $atd_max_api ]; then
# Use the lightweight ATD images if possible
type='aosp_atd'
2025-05-15 02:28:25 -07:00
elif [ $api -gt $atd_max_api ]; then
# Preview/beta release, no AOSP version available
type='google_apis'
2024-06-20 18:25:49 -07:00
else
type='default'
fi
fi
# Old Linux kernels will not boot with memory larger than 3GB
local memory
if [ $api -lt $huge_ram_min_api ]; then
memory=3072
else
memory=8192
fi
2023-05-09 23:11:11 -07:00
2024-06-21 02:45:48 -07:00
emu_args="$emu_args_base -memory $memory"
2022-09-15 19:45:58 -07:00
2025-05-15 02:28:25 -07:00
# System image variable and paths
local avd_pkg="system-images;android-$ver;$type;$arch"
local sys_img_dir="$ANDROID_HOME/system-images/android-$ver/$type/$arch"
local ramdisk="$sys_img_dir/ramdisk.img"
# Dump variables to output
dump_vars $arg_list
}
setup_emu() {
local avd_pkg=$1
yes | "$sdk" --licenses > /dev/null 2>&1
"$sdk" --channel=3 platform-tools emulator $avd_pkg
2024-12-20 01:55:22 -08:00
echo no | "$avd" create avd -f -n test -k $avd_pkg
2025-05-15 02:28:25 -07:00
}
test_emu() {
local variant=$1
local magisk_args="-ramdisk magisk_${variant}.img -feature -SystemAsRoot"
if [ -n "$AVD_TEST_LOG" ]; then
rm -f logcat.log
"$emu" @test $emu_args $log_args $magisk_args > kernel.log 2>&1 &
else
"$emu" @test $emu_args $magisk_args > /dev/null 2>&1 &
fi
emu_pid=$!
wait_emu
run_setup $variant
adb reboot
wait_emu
run_tests
kill -INT $emu_pid
wait $emu_pid
}
test_main() {
local avd_pkg ramdisk
eval $(resolve_vars "emu_args avd_pkg ramdisk" $1 $2)
setup_emu "$avd_pkg"
# Restart ADB daemon just in case
adb kill-server
adb start-server
2022-09-15 19:45:58 -07:00
2023-10-11 22:42:45 -07:00
# Launch stock emulator
2024-12-20 01:55:22 -08:00
print_title "* Launching $avd_pkg"
2024-07-25 03:48:13 -07:00
"$emu" @test $emu_args >/dev/null 2>&1 &
2023-10-11 22:42:45 -07:00
emu_pid=$!
wait_emu
2023-04-25 04:54:46 +08:00
2025-05-15 02:28:25 -07:00
# Patch images
if [ -z "$AVD_TEST_SKIP_DEBUG" ]; then
./build.py -v avd_patch "$ramdisk" magisk_debug.img
fi
if [ -z "$AVD_TEST_SKIP_RELEASE" ]; then
./build.py -vr avd_patch "$ramdisk" magisk_release.img
2024-07-25 03:48:13 -07:00
fi
2025-05-15 02:28:25 -07:00
kill -INT $emu_pid
wait $emu_pid
if [ -z "$AVD_TEST_SKIP_DEBUG" ]; then
2025-05-15 02:28:25 -07:00
print_title "* Testing $avd_pkg (debug)"
test_emu debug
fi
2022-03-18 04:56:19 -07:00
if [ -z "$AVD_TEST_SKIP_RELEASE" ]; then
2025-05-15 02:28:25 -07:00
print_title "* Testing $avd_pkg (release)"
test_emu release
fi
2023-10-09 20:47:50 +08:00
2023-10-11 22:42:45 -07:00
# Cleanup
2025-05-15 02:28:25 -07:00
rm -f magisk_*.img
"$avd" delete avd -n test
2022-03-18 04:56:19 -07:00
}
2025-05-15 02:28:25 -07:00
run_main() {
local avd_pkg
eval $(resolve_vars "emu_args avd_pkg" $1 $2)
setup_emu "$avd_pkg"
"$emu" @test $emu_args 2>/dev/null
}
2025-05-15 02:28:25 -07:00
case "$1" in
test )
shift
trap test_error EXIT
export -f wait_for_boot
set -x
test_main "$@"
2022-09-15 19:45:58 -07:00
;;
2025-05-15 02:28:25 -07:00
run )
shift
trap cleanup EXIT
run_main "$@"
;;
* )
print_error "Unknown argument '$1'"
exit 1
2022-09-15 19:45:58 -07:00
;;
esac
2025-05-15 02:28:25 -07:00
# Exit normally, don't run through cleanup again
2022-03-18 04:56:19 -07:00
trap - EXIT