Magisk/scripts/avd_test.sh

120 lines
2.2 KiB
Bash
Raw Normal View History

2022-03-18 11:56:19 +00:00
#!/usr/bin/env bash
emu="$ANDROID_SDK_ROOT/emulator/emulator"
2022-04-16 14:21:02 +00:00
avd="$ANDROID_SDK_ROOT/cmdline-tools/latest/bin/avdmanager"
sdk="$ANDROID_SDK_ROOT/cmdline-tools/latest/bin/sdkmanager"
2022-03-18 11:56:19 +00:00
emu_args='-no-window -gpu swiftshader_indirect -no-snapshot -noaudio -no-boot-anim'
# Should be either 'google_apis' or 'default'
type='google_apis'
2022-09-16 02:45:58 +00:00
# We test these API levels for the following reason
# API 23: legacy rootfs w/o Treble
# API 26: legacy rootfs with Treble
# API 28: legacy system-as-root
# API 29: 2 Stage Init
# API 33: latest Android
api_list='23 26 28 29 33'
cleanup() {
echo -e '\n\033[41m! An error occurred\033[0m\n'
pkill -INT -P $$
wait
for api in $api_list; do
set_api_env $api
restore_avd
done
"$avd" delete avd -n test
}
2022-03-18 11:56:19 +00:00
wait_for_boot() {
while true; do
if [ -n "$(adb shell getprop sys.boot_completed)" ]; then
break
fi
sleep 2
done
}
2022-09-16 02:45:58 +00:00
set_api_env() {
pkg="system-images;android-$1;$type;$arch"
2022-09-16 02:45:58 +00:00
local img_dir="$ANDROID_SDK_ROOT/system-images/android-$1/$type/$arch"
2022-04-16 14:21:02 +00:00
ramdisk="$img_dir/ramdisk.img"
features="$img_dir/advancedFeatures.ini"
2022-09-16 02:45:58 +00:00
}
restore_avd() {
2022-03-18 11:56:19 +00:00
if [ -f "${ramdisk}.bak" ]; then
cp "${ramdisk}.bak" "$ramdisk"
fi
2022-04-16 14:21:02 +00:00
if [ -f "${features}.bak" ]; then
cp "${features}.bak" "$features"
fi
2022-09-16 02:45:58 +00:00
}
run_test() {
local pid
# Setup emulator
echo -e "\n\033[44m* Testing $pkg\033[0m\n"
"$sdk" $pkg
echo no | "$avd" create avd -f -n test -k $pkg
# Launch emulator and patch
restore_avd
2022-04-16 14:21:02 +00:00
"$emu" @test $emu_args &
2022-03-18 11:56:19 +00:00
pid=$!
timeout 60 adb wait-for-device
2022-04-16 14:21:02 +00:00
./build.py avd_patch -s "$ramdisk"
2022-03-18 11:56:19 +00:00
kill -INT $pid
wait $pid
# Test if it boots properly
2022-04-16 14:21:02 +00:00
"$emu" @test $emu_args &
2022-03-18 11:56:19 +00:00
pid=$!
timeout 60 adb wait-for-device
timeout 60 bash -c wait_for_boot
adb shell magisk -v
kill -INT $pid
wait $pid
2022-06-07 08:06:27 +00:00
2022-09-16 02:45:58 +00:00
restore_avd
2022-03-18 11:56:19 +00:00
}
2022-09-16 02:45:58 +00:00
trap cleanup EXIT
2022-03-18 11:56:19 +00:00
2022-09-16 02:45:58 +00:00
export -f wait_for_boot
2022-09-16 02:45:58 +00:00
set -xe
if grep -q 'ENABLE_AVD_HACK 0' native/src/init/init.hpp; then
echo -e '\n\033[41m! Please patch init.hpp\033[0m\n'
exit 1
fi
case $(uname -m) in
'arm64'|'aarch64')
arch=arm64-v8a
;;
*)
arch=x86_64
;;
esac
# Build our executables
./build.py all
2022-03-18 11:56:19 +00:00
2022-09-16 02:45:58 +00:00
for api in $api_list; do
set_api_env $api
run_test
2022-03-18 11:56:19 +00:00
done
2022-04-16 14:21:02 +00:00
"$avd" delete avd -n test
2022-03-18 11:56:19 +00:00
trap - EXIT