mirror of
https://github.com/topjohnwu/Magisk.git
synced 2024-11-30 13:35:27 +00:00
Update avd_test to support custom type
This commit is contained in:
parent
a89b9e6af1
commit
df6ada5ce3
@ -3,20 +3,17 @@
|
|||||||
emu="$ANDROID_SDK_ROOT/emulator/emulator"
|
emu="$ANDROID_SDK_ROOT/emulator/emulator"
|
||||||
avd="$ANDROID_SDK_ROOT/cmdline-tools/latest/bin/avdmanager"
|
avd="$ANDROID_SDK_ROOT/cmdline-tools/latest/bin/avdmanager"
|
||||||
sdk="$ANDROID_SDK_ROOT/cmdline-tools/latest/bin/sdkmanager"
|
sdk="$ANDROID_SDK_ROOT/cmdline-tools/latest/bin/sdkmanager"
|
||||||
emu_args_base='-no-window -no-audio -no-boot-anim -gpu swiftshader_indirect -read-only -no-snapshot -show-kernel -memory $memory'
|
emu_args_base='-no-window -no-audio -no-boot-anim -gpu swiftshader_indirect -read-only -no-snapshot -show-kernel'
|
||||||
lsposed_url='https://github.com/LSPosed/LSPosed/releases/download/v1.9.2/LSPosed-v1.9.2-7024-zygisk-release.zip'
|
lsposed_url='https://github.com/LSPosed/LSPosed/releases/download/v1.9.2/LSPosed-v1.9.2-7024-zygisk-release.zip'
|
||||||
boot_timeout=600
|
boot_timeout=600
|
||||||
emu_pid=
|
emu_pid=
|
||||||
|
|
||||||
export PATH="$PATH:$ANDROID_SDK_ROOT/platform-tools"
|
export PATH="$PATH:$ANDROID_SDK_ROOT/platform-tools"
|
||||||
|
|
||||||
min_api=23
|
|
||||||
max_api=34
|
|
||||||
atd_min_api=30
|
atd_min_api=30
|
||||||
atd_max_api=34
|
atd_max_api=34
|
||||||
lsposed_min_api=27
|
lsposed_min_api=27
|
||||||
huge_ram_min_api=26
|
huge_ram_min_api=26
|
||||||
i386_max_api=30
|
|
||||||
|
|
||||||
print_title() {
|
print_title() {
|
||||||
echo -e "\n\033[44;39m${1}\033[0m\n"
|
echo -e "\n\033[44;39m${1}\033[0m\n"
|
||||||
@ -29,10 +26,8 @@ print_error() {
|
|||||||
cleanup() {
|
cleanup() {
|
||||||
print_error "! An error occurred when testing $pkg"
|
print_error "! An error occurred when testing $pkg"
|
||||||
|
|
||||||
for api in $api_list; do
|
find $ANDROID_SDK_ROOT/system-images -name 'ramdisk.img' -exec cp -v {}.bak {} \; 2>/dev/null
|
||||||
set_api_env $api
|
find $ANDROID_SDK_ROOT/system-images -name 'advancedFeatures.ini' -exec cp -v {}.bak {} \; 2>/dev/null
|
||||||
restore_avd
|
|
||||||
done
|
|
||||||
|
|
||||||
"$avd" delete avd -n test
|
"$avd" delete avd -n test
|
||||||
pkill -INT -P $$
|
pkill -INT -P $$
|
||||||
@ -67,32 +62,9 @@ wait_for_boot() {
|
|||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
set_api_env() {
|
restore_backup() {
|
||||||
local memory
|
if [ -f "${1}.bak" ]; then
|
||||||
local type='default'
|
cp "${1}.bak" "$1"
|
||||||
if [ $1 -ge $atd_min_api -a $1 -le $atd_max_api ]; then
|
|
||||||
# Use the lightweight ATD images if possible
|
|
||||||
type='aosp_atd'
|
|
||||||
fi
|
|
||||||
# Old Linux kernels will not boot with memory larger than 3GB
|
|
||||||
if [ $1 -lt $huge_ram_min_api ]; then
|
|
||||||
memory=3072
|
|
||||||
else
|
|
||||||
memory=8192
|
|
||||||
fi
|
|
||||||
eval emu_args=\"$emu_args_base\"
|
|
||||||
pkg="system-images;android-$1;$type;$arch"
|
|
||||||
local img_dir="$ANDROID_SDK_ROOT/system-images/android-$1/$type/$arch"
|
|
||||||
ramdisk="$img_dir/ramdisk.img"
|
|
||||||
features="$img_dir/advancedFeatures.ini"
|
|
||||||
}
|
|
||||||
|
|
||||||
restore_avd() {
|
|
||||||
if [ -f "${ramdisk}.bak" ]; then
|
|
||||||
cp "${ramdisk}.bak" "$ramdisk"
|
|
||||||
fi
|
|
||||||
if [ -f "${features}.bak" ]; then
|
|
||||||
cp "${features}.bak" "$features"
|
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -164,11 +136,48 @@ test_emu() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
run_test() {
|
run_test() {
|
||||||
local api=$1
|
local ver=$1
|
||||||
|
local type=$2
|
||||||
|
|
||||||
set_api_env $api
|
# Determine API level
|
||||||
|
local api
|
||||||
|
case $ver in
|
||||||
|
[0-9]*) api=$ver ;;
|
||||||
|
TiramisuPrivacySandbox) api=33 ;;
|
||||||
|
UpsideDownCakePrivacySandbox) api=34 ;;
|
||||||
|
VanillaIceCream) api=35 ;;
|
||||||
|
*)
|
||||||
|
print_error "! Unknown system image version '$ver'"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# Determine image type
|
||||||
|
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'
|
||||||
|
else
|
||||||
|
type='default'
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# System image variable and paths
|
||||||
|
local pkg="system-images;android-$ver;$type;$arch"
|
||||||
|
local img_dir="$ANDROID_SDK_ROOT/system-images/android-$ver/$type/$arch"
|
||||||
|
local ramdisk="$img_dir/ramdisk.img"
|
||||||
|
local features="$img_dir/advancedFeatures.ini"
|
||||||
|
|
||||||
|
# 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
|
||||||
|
|
||||||
|
local emu_args="$emu_args_base -memory $memory"
|
||||||
|
|
||||||
# Setup emulator
|
# Setup emulator
|
||||||
"$sdk" --channel=3 $pkg
|
"$sdk" --channel=3 $pkg
|
||||||
@ -176,7 +185,8 @@ run_test() {
|
|||||||
|
|
||||||
# Launch stock emulator
|
# Launch stock emulator
|
||||||
print_title "* Launching $pkg"
|
print_title "* Launching $pkg"
|
||||||
restore_avd
|
restore_backup $ramdisk
|
||||||
|
restore_backup $features
|
||||||
"$emu" @test $emu_args &
|
"$emu" @test $emu_args &
|
||||||
emu_pid=$!
|
emu_pid=$!
|
||||||
wait_emu wait_for_bootanim
|
wait_emu wait_for_bootanim
|
||||||
@ -196,7 +206,8 @@ run_test() {
|
|||||||
# Cleanup
|
# Cleanup
|
||||||
kill -INT $emu_pid
|
kill -INT $emu_pid
|
||||||
wait $emu_pid
|
wait $emu_pid
|
||||||
restore_avd
|
restore_backup $ramdisk
|
||||||
|
restore_backup $features
|
||||||
}
|
}
|
||||||
|
|
||||||
trap cleanup EXIT
|
trap cleanup EXIT
|
||||||
@ -228,18 +239,20 @@ if [ -n "$FORCE_32_BIT" ]; then
|
|||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
|
|
||||||
api_list=$(seq $min_api $max_api)
|
|
||||||
|
|
||||||
yes | "$sdk" --licenses > /dev/null
|
yes | "$sdk" --licenses > /dev/null
|
||||||
curl -L $lsposed_url -o out/lsposed.zip
|
curl -L $lsposed_url -o out/lsposed.zip
|
||||||
"$sdk" --channel=3 tools platform-tools emulator
|
"$sdk" --channel=3 tools platform-tools emulator
|
||||||
|
|
||||||
if [ -n "$1" ]; then
|
if [ -n "$1" ]; then
|
||||||
run_test $1
|
run_test $1 $2
|
||||||
else
|
else
|
||||||
for api in $api_list; do
|
for api in $(seq 23 34); do
|
||||||
run_test $api
|
run_test $api
|
||||||
done
|
done
|
||||||
|
# Android 15 Beta
|
||||||
|
run_test 35 google_apis
|
||||||
|
# Run 16k page tests
|
||||||
|
run_test VanillaIceCream google_apis_ps16k
|
||||||
fi
|
fi
|
||||||
|
|
||||||
"$avd" delete avd -n test
|
"$avd" delete avd -n test
|
||||||
|
Loading…
Reference in New Issue
Block a user